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.58.4" 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.58.4)Integrity Checksum
sentry-cli-Darwin-arm64sha384-3f5065e7177188f9c193c66ca788eb956ef95a864845876552c51f5aa577ed30
sentry-cli-Darwin-universalsha384-5a1c1121b45c48504d2ae58af11c743c5663ea8979db3258961838a16cf90c08
sentry-cli-Darwin-x86_64sha384-87149438e1c4becdb54a8302832cacc9429638eadefd09d370b4806bec20a078
sentry-cli-Linux-aarch64sha384-672cb986b0c5d84ef724f39b3aa189be802bceb8bc7dc8c5776a0ca90fcf41bd
sentry-cli-Linux-armv7sha384-e8df469ae35f6d8cd788fe2967c5420633bb09348ad09953d5176615cf1bead0
sentry-cli-Linux-i686sha384-1b05efec7bc2ebf4dca8f3e6ededa8ffedf8ee2dd49e23d434a20885bc9a50cf
sentry-cli-Linux-x86_64sha384-a4932b4315b192b3d037678a16eb2a5a8731609f671fc4008e643b85c3c74cb6
sentry-cli-Windows-aarch64.exesha384-4e18e8d293366096d26573e31d03544ea16d9310f12450db1618ba55acfef8c4
sentry-cli-Windows-i686.exesha384-e7314b4b95b969378a46be45b087dfe8cc5c017aceb43a5bbcab3d5e7d6730ea
sentry-cli-Windows-x86_64.exesha384-6183f8ef1d4823290ba95656654714a3c5c216914229b3914acd99a8b4be812d
sentry_cli-2.58.4-py3-none-macosx_10_15_x86_64.whlsha384-44c48ce915ba9c4af962c23a5af473cd5191718f511ea8336eeef20a826a85be
sentry_cli-2.58.4-py3-none-macosx_11_0_arm64.whlsha384-11079c54febda9f6c5bc98e23a47f3225274aa354828c54875fa63b177a59e79
sentry_cli-2.58.4-py3-none-macosx_11_0_universal2.whlsha384-661218ebaa4e1e5fdd3a62e0da3bcfc49246ba24ffec272de5b22e08feacf29e
sentry_cli-2.58.4-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-8a6aecbc55283b7ebfaa463912597bb726c5875730274e36ff9e4b8897d0fcbc
sentry_cli-2.58.4-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-fff8ed6471f49457ade9a7563fdd121e6c69749441b5298cbc3fae70313ff28c
sentry_cli-2.58.4-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-bcdc260c105d10ed2c7dd03bd45a67d265cd3263a66eabb2bcabf20570b8acf7
sentry_cli-2.58.4-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-fc953e0000db1122c284fa58d3a7db570b6bfd635c49012f488e2bbfbce4bb60
sentry_cli-2.58.4-py3-none-win32.whlsha384-13dd8a0c73946d9d6b74acf8e439f43131a130a071419a314d65ff1044d3f1a2
sentry_cli-2.58.4-py3-none-win_amd64.whlsha384-ef9aff888e754fdb46424e2c05d52861c87e6c569a007f467f3a07cae6772fa8
sentry_cli-2.58.4-py3-none-win_arm64.whlsha384-912ace07bd208a730d17fafc96ad37bc8658699b489734f717466de36c214737
sentry_cli-2.58.4.tar.gzsha384-8d41f54b6470a59d8033762ebf3208549bc0f834376edd73f2a05c1cc79efaf5

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