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="3.0.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 (v3.0.0)Integrity Checksum
sentry-cli-Darwin-arm64sha384-3ef5233083cf2c6f37b3850bf6f970ef1770fb55d4911a1c36e53d0a540956f5
sentry-cli-Darwin-universalsha384-b2eb3f411eef8082037fd3cd1e561178a9f084028820d74619195e10cfc5e4e8
sentry-cli-Darwin-x86_64sha384-627ee375b823459d31c1b3f84fed5a700d299cb34c699608379e57a43e8a7a3c
sentry-cli-Linux-aarch64sha384-815686a698e60e41a34035a00a0f11194db266e4b92259b979254a51eaf7bc12
sentry-cli-Linux-armv7sha384-b9c2de7bb303e304a046876cf82f7cc1f2c2a68353cdcae4ffa38b80004e5607
sentry-cli-Linux-i686sha384-74f9c694a165fe3884dcafd04a7f0e686c93cd0d999ec55d58ce363bd97abe93
sentry-cli-Linux-x86_64sha384-460d2053f273fdbd26d88ccb35965448447c4b3715ddc8c6b476a3d243e54430
sentry-cli-Windows-aarch64.exesha384-cbacd717d2980ca0bb5edecff369f168ecc8bd934f4cd9dd628a9973f6b92555
sentry-cli-Windows-i686.exesha384-e3dde3c0b24a3b2ab37f75846b7e89e8698c53db08bbdc73f7b37860e285afca
sentry-cli-Windows-x86_64.exesha384-4acb63ef42e59f9e1aee920e0b399d1781a91f8f25b666b75313a4444ca6a3dc
sentry_cli-3.0.0-py3-none-macosx_10_15_x86_64.whlsha384-6ce4db190ae00da2616c951e0ceccb3f925b2f1378fd0a20b3b84416e6126304
sentry_cli-3.0.0-py3-none-macosx_11_0_arm64.whlsha384-2bdbaab3016de209f7f5508510774cdcdfa890268b89562986e2a66101c19a8b
sentry_cli-3.0.0-py3-none-macosx_11_0_universal2.whlsha384-f3d13aa7cdf5096707cceb7de6e40fa80e9db300fcb0ed58f1289e1163c398a8
sentry_cli-3.0.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-d5e88d50cc19f9302214284777b385b3678c7fbdd3cfd84887660d271b6b9e94
sentry_cli-3.0.0-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-da892d25084ebb784c2f3bda38ba6cea6621440071183f84d254bf89967664f7
sentry_cli-3.0.0-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-6430b90d8924f9cf3838798d582fa4b70dc32cf3270560e3711a8d9c3ebbc5bc
sentry_cli-3.0.0-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-25b333444a4d9ae28568958fe0562ddff3aa63ce08a5ac64fcc5cb365944cbe4
sentry_cli-3.0.0-py3-none-win32.whlsha384-822dfc3aa1d7fb6038bf6c8a9bd9b0581621a3d9197033ebcb8fb8feb25b6f5b
sentry_cli-3.0.0-py3-none-win_amd64.whlsha384-b4ce17693ddbd8189697dd94d6b4ae21c44ba1a3d2ed13d6d4f6b53d188fdf5b
sentry_cli-3.0.0-py3-none-win_arm64.whlsha384-f48ef4ddd152f9e63e3e3634c174d198ce8c95488cd8f82c94264ccc7ed4cf24
sentry_cli-3.0.0.tar.gzsha384-bd9b4bb152b20c8e36d6e43d8be3c0a552255564a0ce2c045cd683a7ebb620ef

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