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.1" 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.1)Integrity Checksum
sentry-cli-Darwin-arm64sha384-e7c7e20c397c28e8e73d6131cfba01033d847bd8b730774feaf6337fd5dba982
sentry-cli-Darwin-universalsha384-431ed8b2234a222b03734a2aa1fe2347fa81f8410e51202d632c2e494f277670
sentry-cli-Darwin-x86_64sha384-3d7266737151e54375ce167b54df67fa26ae3b50b6e0fb6e443dc1dcf12a61cc
sentry-cli-Linux-aarch64sha384-88fb060ef75f668dd60400948907ae980e7f41aa0c50459627769a3979b08dfd
sentry-cli-Linux-armv7sha384-ef5a2e53a003d8f9af151d3f03e93f62ccb1b14b5ad98f7662ae975b693e6b05
sentry-cli-Linux-i686sha384-1815cdf66bfa69a2a365bf0dde99307cf767c62ab09729490e093d31b597d209
sentry-cli-Linux-x86_64sha384-5b905d5a94e88bab5237a92e309070dc0cf832f76ff7eef0abb4ace3eaf084ad
sentry-cli-Windows-aarch64.exesha384-bf5b6e8da8752ebcb0ce55f0a38848e685955f422d666008d94e5b1db229bbc2
sentry-cli-Windows-i686.exesha384-228f8054af508521e844b01ca58f0aa9350a230efd3dace551521174a1f40c3d
sentry-cli-Windows-x86_64.exesha384-009efe0ed92481f4213778703ba5cd6105ce72486e7a037755325a8887612029
sentry_cli-2.43.1-py3-none-macosx_10_15_x86_64.whlsha384-eb8f706dc239824536b674e35be021e8c83df639a1a7bf5473f24e15fcfb03da
sentry_cli-2.43.1-py3-none-macosx_11_0_arm64.whlsha384-57742d1b253b103e862102f1724b6e7da1ed70308e0668928aa2d347c6d33aea
sentry_cli-2.43.1-py3-none-macosx_11_0_universal2.whlsha384-4955da59b394c4c72a5f1c7d4f1fe436e60b7b8c887c8089901f496d8cda5927
sentry_cli-2.43.1-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-023b77c85c528f09df0da96fdfde84b67204ec37609d5cf63aff991181ffe150
sentry_cli-2.43.1-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-594db65447cd491499ec4890e85ce12d6b8c4112ae989c1ab73f73334d1660c5
sentry_cli-2.43.1-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-67b4a418aeff4bd6bc43f54a3f7e4f452527e10da9a0c079dad60858f1b32768
sentry_cli-2.43.1-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-6468ca624ca42dbab7b205cfaeb08fa423bf2cca329ffb77415069b56927de5c
sentry_cli-2.43.1-py3-none-win32.whlsha384-e35d1a672f8bf87682fdbebbd480d988125eb6a82ea7fa9b1f20b9fa10061a9e
sentry_cli-2.43.1-py3-none-win_amd64.whlsha384-aaeb6a531f99cc3e988523e21099990232d3cb98d9c66051b4e4ac0f51eab450
sentry_cli-2.43.1-py3-none-win_arm64.whlsha384-fa5ab66c1aa647923cb7c2536bca764c3d873df22322f7bf1be7bfb012d82335
sentry_cli-2.43.1.tar.gzsha384-78f8633eec07c2843b637a36b36fd8acf85d3132346703e5a7a87ccf3fe48edd

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