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.34.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

This installation is not recommended however.

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.34.0)Integrity Checksum
sentry-cli-Darwin-arm64sha384-5bfb92bf26f97d2cf42371a7743ac03e347d264fc6b282925ecf9e341124086a
sentry-cli-Darwin-universalsha384-6704130938b41b914d6dc3fb99130f860062a0e1fbb7870b178c5c842c85ed45
sentry-cli-Darwin-x86_64sha384-6198e6b5a998168d2d1d1d91f55202a69ebe31175d6330e82f01cdada8a56c62
sentry-cli-Linux-aarch64sha384-0e739e82848388f3319a506840ddada4b8d47a6ffcb12c9d70c588e3b037894c
sentry-cli-Linux-armv7sha384-eb8372143ce3a969e41f43c015f8cd0ac59237adf2d95083b2c5a49a1ec5e83f
sentry-cli-Linux-i686sha384-a2415db0edd7210a7325f1c63ba9c2b4221babf9684de16702bc24777ec940c0
sentry-cli-Linux-x86_64sha384-13b9338a927a6826ba455699dc0615678918a631c48e72b204fa7b65adb7d032
sentry-cli-Windows-i686.exesha384-1a47533a745b65e9e7337e79da7c988726d9009a5ff39e8f6572b97205b0fefe
sentry-cli-Windows-x86_64.exesha384-1af3cda13f9c78013b0b427bb97e6f4fe7294489e062900ce0b306cbfe27af12
sentry_cli-2.34.0-py3-none-macosx_10_15_x86_64.whlsha384-4706daeffd495d3cc63b6f6d202a9d183739d37f9f72d94b0a489c9401b3dad2
sentry_cli-2.34.0-py3-none-macosx_11_0_arm64.whlsha384-e4134cdec3e6c7ef70d09425ddd08c3542dbfe27cf309a3b7f575f848b78756f
sentry_cli-2.34.0-py3-none-macosx_11_0_universal2.whlsha384-1ab9c44d28b0e8bc7706bba8b4a77738ddc5a8cc5889d7107a092fa4796fca21
sentry_cli-2.34.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-f3d3ea2fde16c65ef3c61f76e3b62345ee03e444adc9d1a18bb799971ca7420c
sentry_cli-2.34.0-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-bb2f7aca9dfc212118465534808c2a1376cbc5e2ec5e5273c60400fe55bcc5e8
sentry_cli-2.34.0-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-0158541124aea8ea6b7126c76fb754e6e4ed6e4f210b07f6abe70accdb76b41a
sentry_cli-2.34.0-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-d8270c1a891fc3273f8f2d1f457b08c308eba8a97aedc9decb35b60c4cd004e5
sentry_cli-2.34.0-py3-none-win32.whlsha384-1c408565017de0ac5e95b03c47e5d29301ef634e352abfcad5e81d92b61b9536
sentry_cli-2.34.0-py3-none-win_amd64.whlsha384-0f1951ee0a0fb01f967e682cff57c5044437c20ded089b2a2f2707487ae26eb3
sentry_cli-2.34.0.tar.gzsha384-8fef9300a3d6ac34f6e82e9df6706e8c547556c72641dc932eafd2ff83d43b08

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.

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