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.44.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.44.0)Integrity Checksum
sentry-cli-Darwin-arm64sha384-9d1dedeac34bb93ed4d556ec3bd6a62f5027867bedda114b41d7453e93e341fd
sentry-cli-Darwin-universalsha384-73bb1d6e53a92a33bd31e473b419ed30d6b0e0618c320bc62ec50bf8bc5097a2
sentry-cli-Darwin-x86_64sha384-9e0f72ae74bc6cb1a4ba8560f9adf6f247b3b7727e9ad5574f1c56793e978f64
sentry-cli-Linux-aarch64sha384-98d98edc82c96c29e63175890e7b04077258bb109df98c826bc276fce367f292
sentry-cli-Linux-armv7sha384-c6d105d1b088a4e5115a18c96aa45a5379d05e845e0772f10f7c5fc7010de7b3
sentry-cli-Linux-i686sha384-a29e04547c2e6da315ab0b64e176f617e8aa13c323da3b250e960392047c0eb9
sentry-cli-Linux-x86_64sha384-1961fe5654a20541ed887880a705278c0913d63705c74b48f6835524ce415d1b
sentry-cli-Windows-aarch64.exesha384-5a9a85d8498c88611f509f99691ac7fa21af5815f8d02bf5040507a6fc89cd66
sentry-cli-Windows-i686.exesha384-c954486554851e8efc421d17096a3166e27b1268c765539364548d1345954dfa
sentry-cli-Windows-x86_64.exesha384-e9a3416fa401e5a4e92c8d9d69ceda075218297ca8d890a01b05628f596ea261
sentry_cli-2.44.0-py3-none-macosx_10_15_x86_64.whlsha384-350917d8d7cf931e5a77c2000b35be65b2f23470efbf15225cbf523c42acd7fd
sentry_cli-2.44.0-py3-none-macosx_11_0_arm64.whlsha384-fe2826faa6124e60c9e83afe10180ba80f3ca5716929353b5466d7a1f202d8fe
sentry_cli-2.44.0-py3-none-macosx_11_0_universal2.whlsha384-699198abe00677bdf2b2c7a55a82f5402ff402600081b62f9eb89f946f4bbc00
sentry_cli-2.44.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-b0713fea884362c2ced1c1523e6edc39f47d1a132654c4ad39d00e1dcdef93bb
sentry_cli-2.44.0-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-aa742278d12b508a815aefbf129345d892bcb4c9af068b166ce1c0fec1b9be25
sentry_cli-2.44.0-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-335c52f7cafaf17db77ed2b4e2587425bf3795501a38e91d76f5df9310e51afc
sentry_cli-2.44.0-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-30b571450456f80f9de39b1136c7051c5bee28f303963083956b3a195df56a0f
sentry_cli-2.44.0-py3-none-win32.whlsha384-dbecde0b2576aa7f948f087a9d412b14a9b6c6d77beb5dff8a052870eb45c759
sentry_cli-2.44.0-py3-none-win_amd64.whlsha384-f005e2931e52411ff427b4e0da7f11d2a4bbdefc49b10aeabfdcb358c6896d63
sentry_cli-2.44.0-py3-none-win_arm64.whlsha384-8dd03b5478da932a534f6fe4af78347e4c6b9820a6366b9b377d15f2831527c2
sentry_cli-2.44.0.tar.gzsha384-13a24db4eeea4457f006a0fa67891feb110c38850ad1daad5e4a1e0dc6123a96

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