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.3" 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.3)Integrity Checksum
sentry-cli-Darwin-arm64sha384-5d055303380acc6065763e72dbb6408c7c9e8d6381c21c413b7689baafa2123f
sentry-cli-Darwin-universalsha384-db0ef52f3278b7fb8e0b9d23a17d407815771c4348c024740fa3482a764764b8
sentry-cli-Darwin-x86_64sha384-d7b2b7d9b34c12e8b7485c85536eb9e0162e4f021fa38e8b62bc37af560d7762
sentry-cli-Linux-aarch64sha384-1951e009ddb6a0ae71449f2ec479a04a29178511f0f7f8a70640f57ff0705758
sentry-cli-Linux-armv7sha384-f2da74096c31b79d60e96a1fe2d2dacef1896c60f024257e7a2dd14b7360fdbd
sentry-cli-Linux-i686sha384-505a669cfac38463e51b911adfd8f484fda428980c9ad59e5904878e8a5dfd7d
sentry-cli-Linux-x86_64sha384-560ccecdf6e95ffa206eba4ea57ee33a03f8ad38bc80ae4567438c11613d3b46
sentry-cli-Windows-aarch64.exesha384-1dd6d2d1d0aa35deb493892afd54cc552bb8beb22e7ace6e49949d701d2e03ad
sentry-cli-Windows-i686.exesha384-7162b551e2e6388c64546473a3b52d7923faaea65954068a55de878222334a8c
sentry-cli-Windows-x86_64.exesha384-5751252926fd27c5e420f35baf6bf260af7a031e13c6e923941cdb9a668a84f6
sentry_cli-3.3.3-py3-none-macosx_10_15_x86_64.whlsha384-43483c77071c4c00e6be1a873036edb813fb5f30a2b3a094848f66c61f7b3d48
sentry_cli-3.3.3-py3-none-macosx_11_0_arm64.whlsha384-37d235bf0b2bb5ce2526928d6584441879aa0bcf023e0bc4f43a52c043e996d8
sentry_cli-3.3.3-py3-none-macosx_11_0_universal2.whlsha384-01ce6362be4ff5ced2019133e2a63eb8267f2e6dd1d1f26f7e81f1285ba1344c
sentry_cli-3.3.3-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-9ba4b3199bcfefe40f9e9e7e6ee42f7ecd7b1702af743b2263a78fe8f363bbfd
sentry_cli-3.3.3-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-4f4f157416571db35e62e0325c49ede87cc5547b14ed85a68b08c4681bafe70c
sentry_cli-3.3.3-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-28e43f0537abe75dd88864ad840d96ffdbda3730426d37a038d8bdfff1f43155
sentry_cli-3.3.3-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-49f1d757778db87c40abb0d0b692938019c13a6d67e14976bd87b66f4ea9820b
sentry_cli-3.3.3-py3-none-win32.whlsha384-41098684f1e2a7661bcc875596561f618d06722733b3d3cfd9474a8c01c3bfc8
sentry_cli-3.3.3-py3-none-win_amd64.whlsha384-39ab2cd6adffe9aa99b424c93a464ee1fd9fb485401463cc80e25e2c0be0328e
sentry_cli-3.3.3-py3-none-win_arm64.whlsha384-33e8d98ad90435d39eabe11b40fec964b1f43f7010a992ff614e0cf09322a90c
sentry_cli-3.3.3.tar.gzsha384-6b8b0d8793a59e30c3a09ec2df0d61ad06f710ea2a5007a9ac258e5eb636a01c

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