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.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.4.0)Integrity Checksum
sentry-cli-Darwin-arm64sha384-1d87693d5e349b3e20c68f41b886466ecd489ca38cfa78eaf4c933db9838a7d9
sentry-cli-Darwin-universalsha384-2c36031e19157e33a29661b241c4abf2c59a0d4e60bfe059ab48f88d93c881e9
sentry-cli-Darwin-x86_64sha384-e6b1a6474540177398d0032af15226f4e28b7a975781c3c1c5a99ed3806b1d4b
sentry-cli-Linux-aarch64sha384-1273fe22639e394e0c8d2bd097da13b25139e75e977c5ce44c6f54130664ea45
sentry-cli-Linux-armv7sha384-26a07175b5c19d18f1b83f25f6a2fe685d639554f0bde116a6afc42186083485
sentry-cli-Linux-i686sha384-09863f5ca5f8b7542e9ae28f59fa731f29e1a0548c6c46c27c5324d502bc639c
sentry-cli-Linux-x86_64sha384-803556dd09de4fe54639c4d2e696315fd5a67dda3f8fe8dfe52a942ead5a2ae1
sentry-cli-Windows-aarch64.exesha384-8ec96b6868db86e54b05e9ec558152f6621d36bfc07b09459faffb0012c5f22b
sentry-cli-Windows-i686.exesha384-d7d8fa73db70064465515cb5b136a0347db630472c16e2c4e3b07655ddccbb37
sentry-cli-Windows-x86_64.exesha384-264ada59dc3bd0b92281382c7e71a0e03a027daa55eaa77e81a147c6de81d58b
sentry_cli-3.4.0-py3-none-macosx_10_15_x86_64.whlsha384-3f2feba8905ed5c1731888643fd785e9e08a9c3d771e6896f7818b2ee76fd46d
sentry_cli-3.4.0-py3-none-macosx_11_0_arm64.whlsha384-87cd49b75d80a7af9d745506353043958c74b415982d864f18dd1752cd71f380
sentry_cli-3.4.0-py3-none-macosx_11_0_universal2.whlsha384-bcd07a48cbf33270f952a6e976606262eb675b91422039b50765fa9166fdca64
sentry_cli-3.4.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-7a8c9623aa72592010ab2b0539da11f48a8e6766c09fef5151ee61166949d844
sentry_cli-3.4.0-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-9b2cd6915ef8917ace779f18c1af78644b60fade7a2c20bade63752b06d40a67
sentry_cli-3.4.0-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-df51ca9aeb1444b245837b010576d376b8eee9ed321e7805acfea77665f7318b
sentry_cli-3.4.0-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-0dc9339d0e25408ab8a259b3cddb8ba29a64b10ec301a4d150cfa0da8eb0433c
sentry_cli-3.4.0-py3-none-win32.whlsha384-1d88eddc55a046ea125269c8262fdcd63a13f2012b9ad5506e696630004eb12d
sentry_cli-3.4.0-py3-none-win_amd64.whlsha384-27a6d96b55897b2ca6daea6cfee9c423487c344bebddbc63a96475aef5ef35a0
sentry_cli-3.4.0-py3-none-win_arm64.whlsha384-a4336cd6cb33a3703a356c3b408264010c55e8898b159ae6ff4e050e1fad2516
sentry_cli-3.4.0.tar.gzsha384-8cf22b7767ef59dec426bcef71d333d88d5b292fb5cbabb056e2316bba9ba5e4

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