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.42.3" 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.42.3)Integrity Checksum
sentry-cli-Darwin-arm64sha384-2d88b9445c161e574837c745634078397efdd9dca50e63651abc64b1ab793271
sentry-cli-Darwin-universalsha384-807338701a53a6239958c81a796c0f61c7e4c25312e5be34779d057c631bffd4
sentry-cli-Darwin-x86_64sha384-9a24d6104615f4b853db302c18a35bb9e113d8324be96893aa2d4c8f898440f7
sentry-cli-Linux-aarch64sha384-428b6de82b25c9b5c6093719d0595090e7ec050e688f74b1edf669d24b3ff1a8
sentry-cli-Linux-armv7sha384-05c2dde2b8ebeb5ff148e2b4b11e6d15f985059fcb123faeae505f3324b46f78
sentry-cli-Linux-i686sha384-cc5c59f0cb2c4db4e9cf795361d6372cb612fa12ab886eb86ba84367f7fe3ff9
sentry-cli-Linux-x86_64sha384-fb12375ff28eedc04acbd4d3af500a2f479d9c6188bf60246eea563f35a8f98f
sentry-cli-Windows-i686.exesha384-39c13236eb7a8c24c6431264b9f60e68f5fe2b8f9840913b61eda52f33e22e25
sentry-cli-Windows-x86_64.exesha384-a2161480f821695bfd4edee67d84d3e4fa764336fcc5d42d13a55cbe7ab7bbd5
sentry_cli-2.42.3-py3-none-macosx_10_15_x86_64.whlsha384-914599a74f6c350a1cabf647b5d46c7242328a181de3e1d5c1b046da7c33055c
sentry_cli-2.42.3-py3-none-macosx_11_0_arm64.whlsha384-c311ba6a5e323319afec47d7395b6e1a313e0b4730e8708934a536360a1cd0af
sentry_cli-2.42.3-py3-none-macosx_11_0_universal2.whlsha384-4f877e1d7e4348315b97e4f28c6f013755c25a8e08539d3dc8b2f6c1cc5b28bb
sentry_cli-2.42.3-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-be4ae471d2a27f2f6b8073521d6709e87c302d5c3b0c9409a11e46c5f91c44aa
sentry_cli-2.42.3-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-897229c525b5f85d0e0466eb4c929c0811befe14471457057161c716d0cea07f
sentry_cli-2.42.3-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-22e225dee6586d563c83ab3091ecdd345b8b23870a958ef91528590ef57d4d0d
sentry_cli-2.42.3-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-97377653a82d0cc7170b24717525d5bda74116a4b67d522104129dda381c6d6f
sentry_cli-2.42.3-py3-none-win32.whlsha384-827fe0ca06d7a13af78a26142828394c7077f4e074c3fa35e0b32ceb7363be1d
sentry_cli-2.42.3-py3-none-win_amd64.whlsha384-81e4c4ef93ea811cae5df16625442f435366c015fffd0740bc37d6c2498cdb74
sentry_cli-2.42.3.tar.gzsha384-b488df904f593efb6e9a8f023b65eef6d8ca7573a6e863684a6492816a778fad

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