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="2.57.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 (v2.57.0)Integrity Checksum
sentry-cli-Darwin-arm64sha384-7a3da0a6f4fd3805286880160e697240ef84b26794a3f13ab8b5a3a9d81308fe
sentry-cli-Darwin-universalsha384-e5d890e92b5cef66b93898d2d81aad89ed9ec9a962364fd164eff0cef77ef99f
sentry-cli-Darwin-x86_64sha384-d4fad9ceb5b682a6140c185845bce057122e30d251d38162d3684b9c96b63901
sentry-cli-Linux-aarch64sha384-cb3ce12b59dd6cb5d516a3d3ac07b79d99544856f49ebd88b022851cbba71c2d
sentry-cli-Linux-armv7sha384-7d3acba06f184069418a4fa9d24145d12669786115e51ce66b179943c0e7e6ae
sentry-cli-Linux-i686sha384-76199ca9c0db562c741b5d6a63d402de1678cbf107e94d181d14e2248600d932
sentry-cli-Linux-x86_64sha384-c214ddd4b3e1143018c23c040ae347ecba0ed9a0ff4826679bc21d9796e9a96a
sentry-cli-Windows-aarch64.exesha384-62e2f879c593fa8846c0a81548317ebeff877fee1fed7bd5720606693462464b
sentry-cli-Windows-i686.exesha384-1ea475d2014f4dfb658cd2b5a3bbdfa9b3d2eebba81ec784ccb80a386cf10145
sentry-cli-Windows-x86_64.exesha384-cfb6881493e41272ce2fa77fa77bbbb0b3f5360bdca684c11f393d9af00d0954
sentry_cli-2.57.0-py3-none-macosx_10_15_x86_64.whlsha384-9d25b511fb42c76d585af0ed9620449f30944c884eba404b948275013a6675fd
sentry_cli-2.57.0-py3-none-macosx_11_0_arm64.whlsha384-64801cc472a6394fbf75f91962211591dcf676aa043c340a6f8a3d2d87eaeff3
sentry_cli-2.57.0-py3-none-macosx_11_0_universal2.whlsha384-b38861307c5f330d52832f1b303fdacd3d16d85322d1fe7c03b8a8a3b69e1346
sentry_cli-2.57.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-70ff43b8fe0ea5c811cedb4dbf11636e2cb65612e56e9915b6d66ec65abf77a9
sentry_cli-2.57.0-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-9891209d5cee14b23007cf987e71c79222f71031ff6ffab2c83d635c1e592e04
sentry_cli-2.57.0-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-5ae98bf37b310f45e51f976166a62a64c613af67365dfdd3ff2815f070b60eb4
sentry_cli-2.57.0-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-b28b77e369e04572c317cda0909b5a087327b6c685ab8e7d7894301f67ea296d
sentry_cli-2.57.0-py3-none-win32.whlsha384-5d82ef2cc5b4cfc5e0bb7df20550fe2d61e7b462faf4b98c75c85763f96bedd6
sentry_cli-2.57.0-py3-none-win_amd64.whlsha384-f28842f162cdc306a3671d26fe7d87528fa74c1c9f42244b7b3aef81ba869714
sentry_cli-2.57.0-py3-none-win_arm64.whlsha384-5cf5838f141e283462fe810a0099c9c8a63588a0cca721eff62255715fc60161
sentry_cli-2.57.0.tar.gzsha384-9b1170f99cd29633eb544512e0369e7a8a5b2a4a2fe60ab55ceb773ffca3934d

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