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.4.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 (v3.4.1)Integrity Checksum
sentry-cli-Darwin-arm64sha384-f06e3366c98c8489ea99912bbed08cca64a211c15ff63e4553b3b65305874866
sentry-cli-Darwin-universalsha384-3a6196e6d05aae930db0de2ed7440f1da0a0b7e3a94f7fd980d03fad05cef33f
sentry-cli-Darwin-x86_64sha384-5a1c50531303eb790c57e8675784f5a570145931a31694615bfcce4c9160a67b
sentry-cli-Linux-aarch64sha384-72adfddd95ae4dabd4989f25f77db959949d430d96f601389254517c7dcf4b53
sentry-cli-Linux-armv7sha384-a0d9ee5d6c84adaa4418d3b96ed28e0d5eae08495734136b2c4a4a81ecb8bfb1
sentry-cli-Linux-i686sha384-55c29ec42ed168de9b5260a3db9d300b699f690040ed97663bb54c20ea0295ed
sentry-cli-Linux-x86_64sha384-479f0929275176a191a5a5dd6522853c9e5c21fb305fcdf3123721221b2935e2
sentry-cli-Windows-aarch64.exesha384-9a6b8c14eede47adc114f5c51779a4000dd1b73f83cbe4143760c4d2622526d5
sentry-cli-Windows-i686.exesha384-cfacd68c59a19509c0c6c08bb7e4c043fc659397a0968ae3d3359ad68c7f4900
sentry-cli-Windows-x86_64.exesha384-e8448f165f34ba973daca7fee860f5a43f7cfe95c0044f2275716b7ff56cc960
sentry_cli-3.4.1-py3-none-macosx_10_15_x86_64.whlsha384-183fd6d392cf61ff0e17c6c6e7275114905482830142745e89759a76fa51d974
sentry_cli-3.4.1-py3-none-macosx_11_0_arm64.whlsha384-8e828cae95e2ead9c3042bc2fa10e50738275e6451b5ba350684f5412a0e5cb7
sentry_cli-3.4.1-py3-none-macosx_11_0_universal2.whlsha384-7b223ecd34bafca21630c024423753427878e1eee466dc0ca1e454a3ed0886d9
sentry_cli-3.4.1-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-d9efa5d4b4f8df5e35df42bdcd52a9136738912818c9a71aa0b66b9b60632aca
sentry_cli-3.4.1-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-c1bb36770d3d03b22f6d956aebdc5268ad3eb1046839f805e5e02eb49d4da965
sentry_cli-3.4.1-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-b0d1ab481481a72a19a2976df75088ed83edb69e061635c336bd65d2f81a5dd0
sentry_cli-3.4.1-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-26491fb08050e13f6d97da713a0a8dc8cefcafd669ab5404974115c39ac56096
sentry_cli-3.4.1-py3-none-win32.whlsha384-7bf8cd08445e3bdb21593df7f5c2aab51a5933fb5fb538ad2da0794da4b9e5fb
sentry_cli-3.4.1-py3-none-win_amd64.whlsha384-0129a60420e9015919e6e38d351a939bc4cb9d47fced61fc32ad2a97674e61a9
sentry_cli-3.4.1-py3-none-win_arm64.whlsha384-898d499563a1663cabf82daf006687a1cbd3e11d5cf211d3d5602fbeada98175
sentry_cli-3.4.1.tar.gzsha384-537da1895c57dd2d4057eb8856cf3d5348febd63106c1ef42ade3d3351bc12da

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