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.43.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.43.0)Integrity Checksum
sentry-cli-Darwin-arm64sha384-e22e2df9d6b8c47f717ab4314aa689493ee8918aeeb04658537c3ec841e62d65
sentry-cli-Darwin-universalsha384-fe081198ff0717147db4f1947c63b90481c5130ae0500dfe40db6c0e52364950
sentry-cli-Darwin-x86_64sha384-6744c568dce3651c5f54eaccc209c9372fba93aa9a22027a41a5e36382c80006
sentry-cli-Linux-aarch64sha384-15a596b0ab099c5e42d779e46b76624064a460d6f12bd792af508a5abcd1d293
sentry-cli-Linux-armv7sha384-b98c772fdd1a1258aa1e3cb7671c85fae90ccaeb1381605a0d5ebb38a9c1d6a9
sentry-cli-Linux-i686sha384-3489497ae897e345b21ae0c1928419f58c8df4b5e2cfdb06ca49b225378dbd7d
sentry-cli-Linux-x86_64sha384-d9b5d6f98678cbd2d8fe1ade321125cb3a4baaa20463f72f0dc61083184ac85b
sentry-cli-Windows-aarch64.exesha384-83b2874e5c075be80b05cacdc3bef5972f1422b16206f412ce5c8bd5d3f2a5ad
sentry-cli-Windows-i686.exesha384-756e79d6c89ddff1a8107f654786c2130f73276650fa46a16b4ddc8cd5c244c8
sentry-cli-Windows-x86_64.exesha384-72d42103274135e0e3d0c77dae4632a2f6ebb2e4371b7f9af1aacf15e5d6e19c
sentry_cli-2.43.0-py3-none-macosx_10_15_x86_64.whlsha384-87e542162864330603044d1b75c1029c8f83ac19fccc158b5e3c4d2da7e560d6
sentry_cli-2.43.0-py3-none-macosx_11_0_arm64.whlsha384-8a91d72640e5a0079c97bb6911f1d569a6415726160e8abd0dbc1076f4990d70
sentry_cli-2.43.0-py3-none-macosx_11_0_universal2.whlsha384-d717597e73327a17977cb1a91fe0e7a2abdd3811d2659c3dbb64d851278a0f27
sentry_cli-2.43.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-2ac24710f3b25b8619c77d323524488676aac1494fc1a3bbaa8b0934acc79a6d
sentry_cli-2.43.0-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-2a9bb68a08ea3aafc99e3b622ded29160730830d0f6ac629d872b30185f9b6ee
sentry_cli-2.43.0-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-f3737da549107d078d5347df0d42e7a8ae12cffe139482d89f2fc600b9087631
sentry_cli-2.43.0-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-8c346793dd91f0f4260550fa699263ca7b9096fa78e06288c3d9676152661fbd
sentry_cli-2.43.0-py3-none-win32.whlsha384-2658fca522ca97d451493b0c7a63d26806e9b06b6df76eb631a7247fcf98e47c
sentry_cli-2.43.0-py3-none-win_amd64.whlsha384-8507ea0e7fd1e0fb33a71ab48d7ef613ade75ac57869921ef16c0880cd830d47
sentry_cli-2.43.0-py3-none-win_arm64.whlsha384-ce75ca454562a533ebf8892cf2004885b51135eb3dafd38db2e4c33cc7127c97
sentry_cli-2.43.0.tar.gzsha384-798daa2e6032cc8d3a8d1e1a6e530483cd1c2bb52a9091280161f5923c380e8f

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