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="2.58.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.58.3)Integrity Checksum
sentry-cli-Darwin-arm64sha384-ea482e900e249f9656f57cab31a40901ee4e02952550f809fcd2aae1f398971c
sentry-cli-Darwin-universalsha384-a53c85d540bfe160922d187a45274f0514df087c2a24c6af2bdf57d736405a0e
sentry-cli-Darwin-x86_64sha384-54d28a3327a69e86a8a073c4ff576c7305c3286151d464362143de109b623156
sentry-cli-Linux-aarch64sha384-30f95cf10ff96bdbbfdc1a25a7b65ee0a7f906f2c380c0cdde185d14d5535246
sentry-cli-Linux-armv7sha384-ae2c0ecee950055b388817bdb6dd543730c36d6def8794252c00314c3f0a7e18
sentry-cli-Linux-i686sha384-4a36158a3140a26e1e8fbbb72f80a836df3f49ebcb5787e05b360e0f9ee01b3c
sentry-cli-Linux-x86_64sha384-645e64af49e68a285b66d7ddf440d06b76f8a5603797060f61c0c487ac7e2a89
sentry-cli-Windows-aarch64.exesha384-ae190527ff55ed70c028d033408f446fa99c87b9fabe0ea7b1a336851940b77a
sentry-cli-Windows-i686.exesha384-024a72a8ff6e076cd500c17086a7a146dfb59e9469936eb16b8a1ba31cf7394a
sentry-cli-Windows-x86_64.exesha384-e26c363d45c572c6ae133a913657f995d171f7179aa221371da81966b0d5d2ef
sentry_cli-2.58.3-py3-none-macosx_10_15_x86_64.whlsha384-93e3e45e589dd1ca5774d46a5c2fb55c47aa28f3ad14253549cc26be5717512c
sentry_cli-2.58.3-py3-none-macosx_11_0_arm64.whlsha384-977bd46678dc52907136969e522f66c3e62cafa0b84f2451a4d6cc6815f0fe0c
sentry_cli-2.58.3-py3-none-macosx_11_0_universal2.whlsha384-7b72c108ac49ba4558b1fc7b46d8f464875bf281c8222d436fe3df8c90bcc01f
sentry_cli-2.58.3-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-a351f53c268760cc2b30e703bb7d992fbbc20557c28cf20387cf2387e475633f
sentry_cli-2.58.3-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-4ff2a55f7f58c2cd395bf6498303e5ba406c50193ae2588ee772cdbd1cdb169b
sentry_cli-2.58.3-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-88553611e59767d8882cd1cb8a639869fe5dc238ba5dcf3f4b35b43ffc6f4452
sentry_cli-2.58.3-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-34b53b2f12ba46ef3bd1a14fb51648c2ce54f46fb7cbb46fbae48aa47adfa5c0
sentry_cli-2.58.3-py3-none-win32.whlsha384-387ba88897350cde146a4fa7782ec4fbfc67d0aac4163879ce06ffb14d78fd7d
sentry_cli-2.58.3-py3-none-win_amd64.whlsha384-3d58d90863115c6c0297b61d0c1c803917d5ff420ea6241159c281ee8d6dc979
sentry_cli-2.58.3-py3-none-win_arm64.whlsha384-6a84022547f23827cdabecb772a685f1b822b7c080425d20b50979c527f236ff
sentry_cli-2.58.3.tar.gzsha384-0f172f71faa966a13a0ed96ecaca81fd712e162dd43473d0236818bed61afe34

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