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.50.2" 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.50.2)Integrity Checksum
sentry-cli-Darwin-arm64sha384-421ddd9d6efb690502af1ae4e7a55dffa7b0f8469f43083cd1aa8cf21d96ae8f
sentry-cli-Darwin-universalsha384-70ef2a02e303d6bdc12897105189f582b6b8f8b25c0fc00cad3f628022ceb8e4
sentry-cli-Darwin-x86_64sha384-0fc5dbb6403e61641e979d3f6cac9b98051c30cd8891a4e2bf1d84d207cb8c47
sentry-cli-Linux-aarch64sha384-872afe27ff00c71f1c346931d625e8fa2897bd1543d31be16075cc97f5ea99ab
sentry-cli-Linux-armv7sha384-9b6aba1b7ce655da6efdf19b037dcd9e46ce55042e9e41a8958c30a9a2a164f4
sentry-cli-Linux-i686sha384-d272ba5b1655ef0c851d9a74b574bcc3de1554ae26a94649045a215821c55bed
sentry-cli-Linux-x86_64sha384-d003d220e2fe07c84297f9586682fc2fbd848357833ae13de5e214ff42a62f16
sentry-cli-Windows-aarch64.exesha384-b9af9fcc4d5489c7295a3b39e97c3e55e3151dd498acddbb84f2a05b758a052b
sentry-cli-Windows-i686.exesha384-309d91881dd9c798c3744aecb6f1b61dd7fa837818a9989f8cd69ad9080fe848
sentry-cli-Windows-x86_64.exesha384-022d1e14fb76612a80cd209af4387ffeb0c02374910de5b61b0ecf3822b50947
sentry_cli-2.50.2-py3-none-macosx_10_15_x86_64.whlsha384-775fefee983710238ac9e97b5772404c37149b0f13d133aeb0a9f2253484d94d
sentry_cli-2.50.2-py3-none-macosx_11_0_arm64.whlsha384-cbb19dfb6c96d465859b6eeeb471236ab222999332024060485730d916784168
sentry_cli-2.50.2-py3-none-macosx_11_0_universal2.whlsha384-20953fdf06fdf03ad3df98a4e65cc4ba5777c96b87fc6479ed6b8097ea371278
sentry_cli-2.50.2-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-601128b2266dd453b03b6822ff5d92363ee2ba9fcd7e1d49069acec2f90e137a
sentry_cli-2.50.2-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-c191e800cb694c22adaadc7e259c17f11634d185917c2447faf318e30f4845b8
sentry_cli-2.50.2-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-3e22d1cad8c8d3f6f35505fd84c256c6fcc392deea14ac9e51e1fc23bf414bdf
sentry_cli-2.50.2-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-19d63756d6b6653c0a385d543078b05c6a26076961ae834f7b116ce7b4e523d6
sentry_cli-2.50.2-py3-none-win32.whlsha384-32b4e7c959a1645585765834e3ac5fee0ca24e8fd1de5816ab070007a0c2df10
sentry_cli-2.50.2-py3-none-win_amd64.whlsha384-7e969a708caff23fd1b962179aa29ec9098dd5f232185c6214f8f0bd5d4ad9c7
sentry_cli-2.50.2-py3-none-win_arm64.whlsha384-62c0a2f1583dbd3e1bba003e98a87ef22c3bc1c32b85de9999cd5c36c07d5a68
sentry_cli-2.50.2.tar.gzsha384-8f4215915413cece2d598a89c7b8a57e76c865e108bf0fcb334f363ae9657f49

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