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.45.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 (v2.45.0)Integrity Checksum
sentry-cli-Darwin-arm64sha384-c3fa5ff75f8359bfa2ea7a46f5a402c8b82fab7124c01f0dcf58f37e6e970413
sentry-cli-Darwin-universalsha384-bec01e4afabfb88c30c9b86d92e1c4857c2dd3b6e6870e37380f1cc680a3dede
sentry-cli-Darwin-x86_64sha384-900545bdd9f56e30d45a8c267c995abc87b3760e6cded2f9bbbe8fb1f2c3cd89
sentry-cli-Linux-aarch64sha384-bcb31138b5b9581d1f61fbbcd31f4b7587407833651e31d265e54c227a25898e
sentry-cli-Linux-armv7sha384-965ee3b781f60da223af1f1dfd6d985b0ba97c6e38f48ec05105e5e7276d2def
sentry-cli-Linux-i686sha384-bf95215958a49e9da32d3d8123a1edd49f35fe00a40098eb6b3a7458a8735a98
sentry-cli-Linux-x86_64sha384-ed3db82f44ecdfb8fc17b163ce5580f3af67d335df63e9dd73c0c457a2346a3d
sentry-cli-Windows-aarch64.exesha384-90a79187fcbb10c4a945222a5562bd49d8c55e742af177f249c061d00eec14d7
sentry-cli-Windows-i686.exesha384-46dad8c72c44135014c43776fbd5b42dd7f53b58abd23f93b0b870081f7ceb4a
sentry-cli-Windows-x86_64.exesha384-80ea63208346995844a184604ad09bfc9a91f747704d176fa9c4515dcb269050
sentry_cli-2.45.0-py3-none-macosx_10_15_x86_64.whlsha384-242b2552d25294abd5102f194b6bddf665d04a128a1409c1c395b2de4c505b36
sentry_cli-2.45.0-py3-none-macosx_11_0_arm64.whlsha384-58fac9963574049478ca88b14a8905c5663adaa3b6ff02aa2ea834c8a2c2c518
sentry_cli-2.45.0-py3-none-macosx_11_0_universal2.whlsha384-3a2e8dde3bc8df3ac171aa1a1572c427a63bab6f19ef1c691a768a34cd467b86
sentry_cli-2.45.0-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-8bc3cf4202bd74105fe5b58529b2f81f0aca546821b7b0584288311da068edc3
sentry_cli-2.45.0-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-c6d81fa17c7395e48fa53d3bafd542623be364b9187446d7a4527df89ca7ff49
sentry_cli-2.45.0-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-48f646340a885daad36270d34a3c1279dd8ae7bb07df9d4a321a9a4e0ed54ca6
sentry_cli-2.45.0-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-c3b89fb15d0cff54c9e16940d6afacf72f83e12428fe9cae1aa87384288ffb59
sentry_cli-2.45.0-py3-none-win32.whlsha384-07d53498bd3b4edc441ccca95ef2c54c77e5a84d172b84102e0fdcb59ec424b1
sentry_cli-2.45.0-py3-none-win_amd64.whlsha384-b3991dfc7f3d837d60f14bb25f6b7b0a91fa390d9dfdad7ba3a781864c5d449f
sentry_cli-2.45.0-py3-none-win_arm64.whlsha384-6de8daeb2c8a5c9a5b94c93e63b574141362c37e61c5ad9b1d4e312d730e6e36
sentry_cli-2.45.0.tar.gzsha384-64b26d9afc9ff029a3f46505baba461b68341a1dbe09450cb58151c553890780

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