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.1" 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.1)Integrity Checksum
sentry-cli-Darwin-arm64sha384-c4f396e64c62169f6a3e338b302504abf638fb895d9fc2bae91427e4537f5e50
sentry-cli-Darwin-universalsha384-d7fdd13384ce6ac1475db1cf49de2dad2012b598b5e581ee9fc30eebcd9e94ce
sentry-cli-Darwin-x86_64sha384-9739893666b9839dd99b72b068fd6e3e555e30bd1f1a1dd414bd5fb3d7f3089d
sentry-cli-Linux-aarch64sha384-a4f83670b82b50a2e19f7977c3662b9c2590f919b0ead9800e00202021035b95
sentry-cli-Linux-armv7sha384-7cbd069b5fc2d4931288ef9021ff8f378b52134ca0d4f2de3d96553955fcc69a
sentry-cli-Linux-i686sha384-cd8863733d1fd28cda778c207a4e2ebdee151a87d009544b8b620d5b8b4a5047
sentry-cli-Linux-x86_64sha384-f8572d045821911ac54a03c2fd94597c22655fd82df11e6734acbfef18945935
sentry-cli-Windows-aarch64.exesha384-17044bfc007e73315f3405554d0265084b479873bd567547140b8181b9964daa
sentry-cli-Windows-i686.exesha384-865f2994f1919b9ffcd1672f8483439991a8365781e57e0f4c7f03f5b2f2ebbc
sentry-cli-Windows-x86_64.exesha384-e3df9ac4efa1a8407bab95beaa2adde6f7addb39312c37796d9f2c9d12441a0a
sentry_cli-2.58.1-py3-none-macosx_10_15_x86_64.whlsha384-658d813450788c14e0416f8acd821d958498fe49e1ed5ff7ee3b381310b93b71
sentry_cli-2.58.1-py3-none-macosx_11_0_arm64.whlsha384-638f825835428d222ed818eff74c861b2c139459b2422fc8c3712a01f2b09832
sentry_cli-2.58.1-py3-none-macosx_11_0_universal2.whlsha384-911586e2a6ce93dbbf13438e858188c9fdf5cd453da45cd06a096ece04ed6066
sentry_cli-2.58.1-py3-none-manylinux_2_17_aarch64.manylinux2014_aarch64.musllinux_1_2_aarch64.whlsha384-2666dca129fec4a768edd52d0a2fd75a5d749926e78ba8cdea9db471444428aa
sentry_cli-2.58.1-py3-none-manylinux_2_17_armv7l.manylinux2014_armv7l.musllinux_1_2_armv7l.whlsha384-baa2d210a90a90d4f4272decb6d9eac340ff59325bd8f7d7b51ca155d1120790
sentry_cli-2.58.1-py3-none-manylinux_2_17_i686.manylinux2014_i686.musllinux_1_2_i686.whlsha384-3978de7ba38f56d17dd612f0cb426a611f4e0f97972bc65c7474c9e21bafd213
sentry_cli-2.58.1-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.musllinux_1_2_x86_64.whlsha384-c90322b661f0027bcf4e81fe2b1e99edb173e7cd8d9900a7e88ff92530fffa78
sentry_cli-2.58.1-py3-none-win32.whlsha384-29b333c1a4f49716b3ff3ff8db4a954e80340804481aec834201f1c0f8bdb233
sentry_cli-2.58.1-py3-none-win_amd64.whlsha384-c508b24f42b31997c4fdb7dd0a81fa99ad664e8b920b55c5df7b9db07f6d96d2
sentry_cli-2.58.1-py3-none-win_arm64.whlsha384-7ef028e9a56e707e34c39814f52afc59c29e473f2fa9fe1dd21107780d4301ce
sentry_cli-2.58.1.tar.gzsha384-dbc796c977b0c1e639272215c9907d5e26d3264f23b47022f1e279b070838fe2

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