Installation

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

Manual Download

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.

Automatic Installation

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="{{ apps.version('sentry-cli') }}" 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

Installation via NPM

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

Downloading From a Custom Source

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

Available Installation Options

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.

Installation via Homebrew

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

Copied
brew install getsentry/tools/sentry-cli

Installation via Scoop

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

Copied
> scoop install sentry-cli

Docker Image

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

Updating and Uninstalling

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.

Build Checksums

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.17.5)Integrity Checksum
sentry-cli-Darwin-arm64sha384-ed1e4434ef62374ebc144cd7d6648fb3cc3222294390c90f27b092c30a064e07
sentry-cli-Darwin-universalsha384-7586993d8a686dfb3e42f81075e6cc44cfcc8e6b07b207b5e067a26e914c58a3
sentry-cli-Darwin-x86_64sha384-c20df0c10eecedd0eaf14bbdc052c1dc2e999797c896a40e3ae9390223bd4d4f
sentry-cli-Linux-aarch64sha384-2071c03f870fcce6f9e82cefcff004e92f6d1af250a31d157ba921c671a5f9ec
sentry-cli-Linux-armv7sha384-260c4dfc70a398d4c9993b5c51fe8eb44200cbbe2cdfc0cfedaf7980fe21ee11
sentry-cli-Linux-i686sha384-142824382e394f06a1a9b0bcb2276dd29fed17310fc01a24706724e6979749ff
sentry-cli-Linux-x86_64sha384-8200b8f0831535d5c21adfde947ca6d30930619eae36a650cbcf1005c68cd6dd
sentry-cli-Windows-i686.exesha384-718209c411305dc4d86676dba6bef09e7c69bce03ce457c09f3b05ae08e1126e
sentry-cli-Windows-x86_64.exesha384-4ee6d34cce58bed122acc1602d327c28c9b82fa9e64bcc73100012e644e6537a
sentry_cli-2.17.5-py3-none-macosx_10_15_x86_64.whlsha384-26c4bea21239ba72a2726670954d37483982f3c535199dd8004f21c9cff9e76a
sentry_cli-2.17.5-py3-none-macosx_11_0_arm64.whlsha384-60797cd6bccfa2d559fb7b179de48ed61e1d7ff421c9e8b4a34fd372f9af2505
sentry_cli-2.17.5-py3-none-macosx_11_0_universal2.whlsha384-2195453ecdce8a6c410a269680ac0073673ae0889790f6f0502a2fceff8b967d
sentry_cli-2.17.5-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-a9db2644b7cc508b5963f4a95c76eb60f2f31cdc28db7226e368ed683e4859d4
sentry_cli-2.17.5-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-63cbb1b24fc9ec2e899709edbe81f8a9f00b7d5b305f4d8faef1c196cabd82de
sentry_cli-2.17.5-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-73b1105a329f1fb143068112b186af6c9ba25532dc7e77648e0f6244f5f28638
sentry_cli-2.17.5-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-68ecde6ba5692616313b6de60e59aad72072700972200642e96dd652ef062ba0
sentry_cli-2.17.5-py3-none-win32.whlsha384-fbfb264b6cd9f34335a88d0313542858f78c393b62865f48aa58522f72e5f88b
sentry_cli-2.17.5-py3-none-win_amd64.whlsha384-ab53e13fef6556e20daf8b1888bb6d4b8246dc9130e2e1d248febbf39fecf453
sentry_cli-2.17.5.tar.gzsha384-61f98ec868f456b85f3a06ca1dc9051fa00b18c189210c54c72207108ce14f68

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.

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