Installation

Learn about the different methods available to install `sentry-cli`.

Depending on your platform, there are different methods available to install sentry-cli.

You can find the list of releases on the GitHub release page. We provide executables for Linux, OS X and Windows. It’s a single file download and upon receiving the file you can rename it to just sentry-cli or sentry-cli.exe to use it.

If you are on macOS or Linux, you can use the automated downloader which will fetch the latest release version for you and install it:

Copied
curl -sL https://sentry.io/get-cli/ | sh

We do however, encourage you to pin the specific version of the CLI, so your builds are always reproducible. To do that, you can use the exact same method, with an additional version specifier:

Copied
curl -sL https://sentry.io/get-cli/ | SENTRY_CLI_VERSION="3.3.0" sh

This will automatically download the correct version of sentry-cli for your operating system and install it. If necessary, it will prompt for your admin password for sudo. For a different installation location or for systems without sudo (like Windows), you can export INSTALL_DIR=/custom/installation/path before running this command.

To verify it's installed correctly you can bring up the help:

Copied
sentry-cli --help

There is also the option to install sentry-cli via npm for specialized use cases. This, for instance, is useful for build servers. The package is called @sentry/cli and in the post installation it will download the appropriate release binary:

Copied
npm install @sentry/cli

You can then find it in the .bin folder:

Copied
./node_modules/.bin/sentry-cli --help

In case you want to install this with npm system wide with sudo you will need to pass --unsafe-perm to it:

Copied
sudo npm install -g @sentry/cli --unsafe-perm

By default, this package will download sentry-cli from the CDN managed by Fastly. To use a custom CDN, set the npm config property sentrycli_cdnurl. The downloader will append "/<version>/sentry-cli-<dist>".

Copied
npm install @sentry/cli --sentrycli_cdnurl=https://mymirror.local/path

Or add property into your .npmrc file (https://docs.npmjs.com/files/npmrc)

Copied
sentrycli_cdnurl=https://mymirror.local/path

Another option is to use the environment variable SENTRYCLI_CDNURL.

Copied
SENTRYCLI_CDNURL=https://mymirror.local/path npm install @sentry/cli

Options listed below control how sentry-cli install script behaves, when installed through npm.

SENTRYCLI_CDNURL:

If set, the script will use given URL for fetching the binary. Defaults to https://downloads.sentry-cdn.com/sentry-cli.

SENTRYCLI_USE_LOCAL:

If set to 1, sentry-cli binary will be discovered from your $PATH and copied locally instead of being downloaded from external servers. It will still verify the version number, which has to match.

SENTRYCLI_SKIP_DOWNLOAD:

If set to 1, the script will skip downloading the binary completely.

SENTRYCLI_SKIP_CHECKSUM_VALIDATION:

If set to 1, the script will skip the checksum validation phase. You can manually verify the checksums by visiting Build Checksums page.

SENTRYCLI_NO_PROGRESS_BAR:

If set to 1, the script will not display download progress bars. This is a default behavior for CI environments.

SENTRYCLI_LOG_STREAM:

If set, the script will change where it writes its output. Possible values are stdout and stderr. Defaults to stdout.

If you are on OS X, you can install sentry-cli via homebrew:

Copied
brew install getsentry/tools/sentry-cli

If you are on Windows, you can install sentry-cli via Scoop:

Copied
> scoop install sentry-cli

For unsupported distributions and CI systems, we offer a Docker image that comes with sentry-cli preinstalled. It is recommended to use the latest tag, but you can also pin to a specific version. By default, the command runs inside the /work directory. Mount relevant project folders and build outputs there to allow sentry-cli to scan for resources:

Copied
docker pull getsentry/sentry-cli
docker run --rm -v $(pwd):/work getsentry/sentry-cli --help

You can use sentry-cli update and sentry-cli uninstall to update or uninstall the sentry-cli binary. These commands may be unavailable in certain situations, generally when sentry-cli has been installed by a tool like homebrew or yarn, either directly or as a dependency of another package. In those cases, the same tool will need to be used for updating and removal. If you find that sentry-cli update and sentry-cli uninstall aren't working and you don't know how the package was installed, running which sentry-cli will often provide a clue as to which tool to use.

When downloading an executable from a remote server, it's often a good practice to verify, that what has been downloaded, is in fact what we expect it to be. To make sure that this is the case, we can use checksum validation. A checksum is the value calculated from the contents of a file, in a form of hash, in our case SHA256, and it acts as the data integrity check, as it's always producing the same output, for a given input.

Below is the table of SHA256 checksums for all available build targets that our CLI supports. To calculate the hash of a downloaded file, you can use sha256sum utility, which is preinstalled in OSX and most Linux distributions.

Filename (v3.3.0)Integrity Checksum
sentry-cli-Darwin-arm64sha384-f8611ffd31192a53c33dde0345009bab418184856bc0cfa76abfcfd902521653
sentry-cli-Darwin-universalsha384-dcede3b42632886a32753ad9d763f785d46afd5fa4580b5c979aad2d465d1cf5
sentry-cli-Darwin-x86_64sha384-f45745c055ecb6c6cbbeba935f49e29120bd2a5ace19ad8e6d6d4ffd041c314f
sentry-cli-Linux-aarch64sha384-66ac0b802e82fcef7610dc29559f18efc1eef67bf9610a19705a844ed0697dd4
sentry-cli-Linux-armv7sha384-82f55fbaa54ba7b0a3ec1104560333bdd01897feb75ba323ae4e68de93ad4d61
sentry-cli-Linux-i686sha384-37dd336b6545e557d1e7bcba46f53c37f96108036420578042434d396d67417a
sentry-cli-Linux-x86_64sha384-5563b71cc28cd8b1e2cd1037f8e377083992ec112c9bf1ff0efd26dfe3b1e67e
sentry-cli-Windows-aarch64.exesha384-b26583764957e61373ff2ec98a1637199339ac133c8bc527cafad7306c1f8342
sentry-cli-Windows-i686.exesha384-94bb198bf4cae41fc77d0535652869b5259b54a1608075e76bc032de15e222e1
sentry-cli-Windows-x86_64.exesha384-25b938d377ef946ccec89d9b03c4f49ef6970c717404839d44c683313ec71c88
sentry_cli-3.3.0-py3-none-macosx_10_15_x86_64.whlsha384-3cd7bb174afa9fb7c7691308d371d55d92cba63cb55ea3354cfb32ffcb053a87
sentry_cli-3.3.0-py3-none-macosx_11_0_arm64.whlsha384-db4e9e642797a1836c73686ec5c36e68f7ffecdfa4bddc5cf95a046079ae27a6
sentry_cli-3.3.0-py3-none-macosx_11_0_universal2.whlsha384-eb0207f96502e9419ce0b0a1225d3d331fbbfcb696cd7a8717fc43d6129ff595
sentry_cli-3.3.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-c570186c74ac3918cefa1efaf4106ece6a912980b6c95101ed28bba6055575c4
sentry_cli-3.3.0-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-c0f4e4db5c3a1014922bec3af64d6ab39ed847ab2098331eeba0ef995a670ff3
sentry_cli-3.3.0-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-f75ce27fafd4ebc541bea488716c5c869102e9c94c454e0bfca14e4bf757d684
sentry_cli-3.3.0-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-5c146d0cd2eba74e5701dd94b65e0e0e20f9c1d15d46bb88baf0c4add4ab1f2e
sentry_cli-3.3.0-py3-none-win32.whlsha384-4cb6ea6e17ecd715f5df1a654f052837f283c233074d0921c2bc2d5f678110ba
sentry_cli-3.3.0-py3-none-win_amd64.whlsha384-c0e6aa36fe10b682fd1299fa2e01a1a1295d7d96039f9d7160d6c0a9be326bec
sentry_cli-3.3.0-py3-none-win_arm64.whlsha384-c00424bd0da1ad24232f6304812c69d46cdff8640ec8d69de9d59aa2f6586f52
sentry_cli-3.3.0.tar.gzsha384-04e9864859d3979c149feea79fe473aecd561a37b0a67f2ea90dd74ac70bc672

If you would like to verify checksums for historic versions of the sentry-cli, please refer to our release registry directly, which can be found at https://release-registry.services.sentry.io/apps/sentry-cli/{version}. For example, https://release-registry.services.sentry.io/apps/sentry-cli/1.74.4.

Was this helpful?
Help improve this content
Our documentation is open source and available on GitHub. Your contributions are welcome, whether fixing a typo (drat!) or suggesting an update ("yeah, this would be better").