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.1.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.1.0)Integrity Checksum
sentry-cli-Darwin-arm64sha384-4b436130e5600d446b8f7633443516fbba8b20fa6e74d5db9645907009e4e982
sentry-cli-Darwin-universalsha384-56144785a1894467662643b8090d0620e18e6831a93228260538b4e944ab9e72
sentry-cli-Darwin-x86_64sha384-50cd21d8e7645fd8b43ad24f4e95ab322d2818e6a739bbd1037c732f8f96cac6
sentry-cli-Linux-aarch64sha384-279c5db7601ecb028461a6c735926cf5616b192df42eb9e55d46cc300e5f5161
sentry-cli-Linux-armv7sha384-25e15889846b94ab65ac4fe9d05a16f83c325b598c525a3e99865aad8b6c2fc4
sentry-cli-Linux-i686sha384-2f8502dee540eda7dc3cc4e7d72ff38d9fc20c295c80b85077a7fbe1dc67b434
sentry-cli-Linux-x86_64sha384-7fdf7be2875a6fdb7bc2a3802bf3276ed776a89b66fbb00f977bc73358c2bc3d
sentry-cli-Windows-aarch64.exesha384-e5c64d26780d62cb2edc775744864032dafbe2e465e0883c6dc5082f1693173a
sentry-cli-Windows-i686.exesha384-52b2d33de223e0a459181fedc9d4841429fe1568c0d5d110695cccd76dafb6c7
sentry-cli-Windows-x86_64.exesha384-4bf13ff4116fe4ef80a35e962b83c1b60bf128a26fd431b29ae31893e4ed6f4d
sentry_cli-3.1.0-py3-none-macosx_10_15_x86_64.whlsha384-3ce836dfaa1afe51b567390c3fb0cd7de2c9d28b3e960571b51b7d3e49239529
sentry_cli-3.1.0-py3-none-macosx_11_0_arm64.whlsha384-1d8764eecf9ea7b6b5362bb81a297d7419de0618cc0305061a3ac80ab0df6e48
sentry_cli-3.1.0-py3-none-macosx_11_0_universal2.whlsha384-e55eb96b3749951f869ee020be2154d9630bebb2c9b4b32cd2224015e344de6f
sentry_cli-3.1.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-7f82d14ad5774e7586c2ec6345f02464c501c3ca04136ecfea73ca6d1e38f61f
sentry_cli-3.1.0-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-c7ff85c2b90806882c29ec617ef36ff464451e29ec8e2bb192abe7ac3ade2bba
sentry_cli-3.1.0-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-98c6459431b4b2b22f7638f60145d435c13611fbb58f2fed1a189efba8ce9f7c
sentry_cli-3.1.0-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-8dbd75494ed846f327eadac437143a1d5216a7f86668859d8e5b8157ae06f5ee
sentry_cli-3.1.0-py3-none-win32.whlsha384-67776e8a70845aafe7aa0c4be719541decb35cc6e4d10768b2eba2392655ed83
sentry_cli-3.1.0-py3-none-win_amd64.whlsha384-1bc5868f382c33bfe31a70e47455dbc7eb8b7b2a8b3f6038f84a2a62da4144f9
sentry_cli-3.1.0-py3-none-win_arm64.whlsha384-cc0ff3742a8a658a03ed9a7a31fee31bde551b438948e9ddf93e218dd45f3fcd
sentry_cli-3.1.0.tar.gzsha384-7f788f833f9b75b879f80e045f7631b83936ea746c989b0ecfb918a26be0d115

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").