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.56.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.56.1)Integrity Checksum
sentry-cli-Darwin-arm64sha384-f91b37e40d6702ca00eaa24edcb82fdaa13e6573a25ba60f17a2e5a2a8910283
sentry-cli-Darwin-universalsha384-87788404f46205637f0713140bcb20269d9859c0706144fa7a8fbe6e7e02b776
sentry-cli-Darwin-x86_64sha384-d00bb8bd62ca17b61dd604db4cd2d444b029790510010a1a0b99ce2ad3b6ca43
sentry-cli-Linux-aarch64sha384-cc58bca49593cd6fcda4d934e1bf68f3bed9194156ba122cdb2e4cfd79a23878
sentry-cli-Linux-armv7sha384-636cf1211e55e816474e227282ebda032bcc75efe074a7f680abcedd092096ac
sentry-cli-Linux-i686sha384-c913b72fd887be3d1c6bf73161f19b85b7063418bfbc5390df21f9c421515f95
sentry-cli-Linux-x86_64sha384-be0bcbf4740c95330cf2d735769f31640d69fd297a2b74ad0cd9ed383814cafa
sentry-cli-Windows-aarch64.exesha384-d34275dfe92e74b9280dcc83dd9a7185618c0153f4c47e8b675ed3ca8e5a67f3
sentry-cli-Windows-i686.exesha384-1daea54f6f1c318c77091fdbcc8a596b263e71831787705c77f7ea09291a8697
sentry-cli-Windows-x86_64.exesha384-9a5d968428c9ae1ad03720b6f26d371c8571a0c1359ad4046b01893724ddfc97
sentry_cli-2.56.1-py3-none-macosx_10_15_x86_64.whlsha384-4a2f156f9fa5e7a6c903a2069edfa12565e9841263a5587c57f061c46a427009
sentry_cli-2.56.1-py3-none-macosx_11_0_arm64.whlsha384-07388a64ed2639044e8537394a171cf6428cb339619d35a38cb31bc19dad5f42
sentry_cli-2.56.1-py3-none-macosx_11_0_universal2.whlsha384-0c7cc3d29cd53eb32d4fff2759be81bd2c8986ebb4ed54dc9064a177e310a7ae
sentry_cli-2.56.1-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-63043d6975c0e6a0c34c3a78cc04707ab06c799a2ffdcc0ba9c66b9b58c32cf4
sentry_cli-2.56.1-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-214daabff5e585c50d4094fe22a0d7888c5a23f911835803faf02104c3552c2c
sentry_cli-2.56.1-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-453d9109997657e327031f19d20b24156661f7fb3b9ca8bd36d058a3202ed24e
sentry_cli-2.56.1-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-dbf88872585134e057f7c64bc1b4e89b203f89d4e0a4a1a90885b3202693b540
sentry_cli-2.56.1-py3-none-win32.whlsha384-15b59102f93a24a5eaacd88eabb7fd8c6543981169e32d6e90b7a1856507b604
sentry_cli-2.56.1-py3-none-win_amd64.whlsha384-291c9018ab42dd8f3be0be9f9be7441874e50bb27b8c1d9fd7f8eeb976f3613c
sentry_cli-2.56.1-py3-none-win_arm64.whlsha384-ea5f2c3358186225edfe4b2139c00bf3f8433049b845d7fc93714e423c5a8c75
sentry_cli-2.56.1.tar.gzsha384-a708dc20a5d73e54cb79d62e8d2def0f4d25fb2ed8f2c4237190251542b3c8b7

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