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.36.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

This installation is not recommended however.

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.36.0)Integrity Checksum
sentry-cli-Darwin-arm64sha384-a9a4d6cd5fe9759ea7dd463f5811a05ee4040feb30243e5ce6a32b5071384b8e
sentry-cli-Darwin-universalsha384-c13b7500d11a2ef62e6c8b54b56ea90ddd4131f731b450f3a7fa6fd3e8e00af4
sentry-cli-Darwin-x86_64sha384-7e250ef6f2f4adf38d4a13069c110067f3a4835ad7bb00162c2cbf1828f8eb58
sentry-cli-Linux-aarch64sha384-93f8988e5c4c27ec47d5c03ea39edeb8a21f7816e82922aed2bfe01dc0a62a20
sentry-cli-Linux-armv7sha384-cef9b3e6a279fa9fc2a512168aa6fba9f953fcf2f0c9e5e72f2301caba83af9e
sentry-cli-Linux-i686sha384-5c9ec874801e8df5e1f5a39130035a3e4ac84e6b5cf541a6eb1b05b1763a3ded
sentry-cli-Linux-x86_64sha384-3a9ebce904a69bf42ef3f2f445b521765e68d1401524d2ed1d8def95db92b3b7
sentry-cli-Windows-i686.exesha384-107f1f85b3eb7394ea37f9fde6b3110269532288e5de327ebeee2df8a31d7ba3
sentry-cli-Windows-x86_64.exesha384-0c85361ff41d5fa863e9a0c93f72c1a3e90f2d1888c71223bb3c723f3c80fe81
sentry_cli-2.36.0-py3-none-macosx_10_15_x86_64.whlsha384-7899df3019a43581795c32057993b2b8a8e65deeb4e2a9d7de80e1a2050bc752
sentry_cli-2.36.0-py3-none-macosx_11_0_arm64.whlsha384-be0c66fe4e2f8b842f56f52433f0ce14a0af201bdb3dfca6e0a02f37105eab52
sentry_cli-2.36.0-py3-none-macosx_11_0_universal2.whlsha384-3331c86b5287efe0f3500500de4082001cc7ff1c2ba697cde5678dffe5d13b5a
sentry_cli-2.36.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-889af8b419c1cf536a6de26631a764ee8ac39b12df81faad94511aac611e145e
sentry_cli-2.36.0-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-fd1aa9bfa639d14642ed9da578ea615bb4b94fbfa9b31bf84ad7e29c6a95eaaf
sentry_cli-2.36.0-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-b78f355bb984387a9f33c2711a40b77bcb95c28def346486a8a0081f01c81fd6
sentry_cli-2.36.0-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-b7bdf960502b3aaa2ae2ec719c267e93a9e77c8d476d40f040d018fae5306ffe
sentry_cli-2.36.0-py3-none-win32.whlsha384-a82a99d19c139c54a9aee599fe390ba45e26483005cecdd3a94e5ef181ee54bf
sentry_cli-2.36.0-py3-none-win_amd64.whlsha384-e90113f412584d7dcc823000a5ab2e747ea0526355aa32e6a3ca9c69bf1317da
sentry_cli-2.36.0.tar.gzsha384-6668a1e545f084fb80a317e2384eae0b34e4c84833d914f59c737641b406de1d

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.

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