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 OS X 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="2.42.5" 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 (v2.42.5)Integrity Checksum
sentry-cli-Darwin-arm64sha384-833a7a87be13f4b28f52928b3890b1112684a8b3d148a3c0cdc0d1e3b65e80f7
sentry-cli-Darwin-universalsha384-4226fb582bd4551dfabf4d58b0713cc66825e6fd8071e9f59c2604373b28048c
sentry-cli-Darwin-x86_64sha384-5110eb2e6568d836901c3f8f0c02cc596fa36663fab37e2d5f995207e878f8aa
sentry-cli-Linux-aarch64sha384-2d4f9df6e567ffaf90aab1a6dd892b1ba9fd580edd8b9ffe7d8484e5530263eb
sentry-cli-Linux-armv7sha384-79ecfd56f0153e87ca3d4adf68d759d449c2e9af3593a26fd2151d3cf4b98bb3
sentry-cli-Linux-i686sha384-61ea5059835bb2d092afbf3193400270978506102700f5ab12f90c0880efbbb8
sentry-cli-Linux-x86_64sha384-ece674996d051b3d236bb3b3e2ae4c315d0aa55373fa3bcde2d6d474b7c6ba96
sentry-cli-Windows-aarch64.exesha384-f985cfd982c75441aa3b3e5c8e8c79e3a82570f407476d44f55a02d7e999f22f
sentry-cli-Windows-i686.exesha384-906b2c5cb3ad203fb795b44feb35d6a90adee9cdacb7359df9eaad39043395f9
sentry-cli-Windows-x86_64.exesha384-ea1f5a9ad24ed1ac43c238166857490772fb823d868997e874517648cace13d7
sentry_cli-2.42.5-py3-none-macosx_10_15_x86_64.whlsha384-ac34b3ed1330ff1bf0113eb01d2759f0ee378d3f2c5d74406f7ea55a2bb714a6
sentry_cli-2.42.5-py3-none-macosx_11_0_arm64.whlsha384-e5e8d81f6f68157a25df23a25ec131ad9245cfa3bea121f2139fb2b9576c5519
sentry_cli-2.42.5-py3-none-macosx_11_0_universal2.whlsha384-ded606913c925f05d4d0e7377d8903625dcc3182b4b2b48e12772fa4c5451ad6
sentry_cli-2.42.5-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-e9f0e6d4c5c0a610505d009311380c7905642d25973a41df39f09b394b5d42e4
sentry_cli-2.42.5-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-6e84d1e3c52a2c8189d9188b44ce3f0c06a1ff464ef19aa9c78c1d2adecc5241
sentry_cli-2.42.5-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-27d3026eb91acec90e065579a68a6044a5ce9858c2f8be479fff5b5a535cafb5
sentry_cli-2.42.5-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-83729b0ac8df62846e872c196121ce86cbd25c8dc9d765b55f4a10326e2414f0
sentry_cli-2.42.5-py3-none-win32.whlsha384-b7150d567da05f304429d3f7f0815f87162bd7a79a0a8ee1b0c76ea36402fcdd
sentry_cli-2.42.5-py3-none-win_amd64.whlsha384-b650a761aa274758fbff43bfcc207b05bb3a42ede810f3ee30acc45e6b449453
sentry_cli-2.42.5-py3-none-win_arm64.whlsha384-3e65b1309f2441caaffd625e18e3bb99bc58be6e4077d6b7b76eab3c922b6984
sentry_cli-2.42.5.tar.gzsha384-afab9f875aafa6f62b2450666d93f1df797f1ffc8ed486aad42c64ae7aae2862

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