Official bootstrap for running your own Sentry with Docker.
- Docker 17.05.0+
- Compose 1.23.0+
- You need at least 2400MB RAM
To get started with all the defaults, simply clone the repo and run ./install.sh
in your local check-out.
There may need to be modifications to the included example config files (sentry/config.example.yml
and sentry/sentry.conf.example.py
) to accommodate your needs or your environment (such as adding GitHub credentials). If you want to perform these, do them before you run the install script and copy them without the .example
extensions in the name (such as sentry/sentry.conf.py
) before running the install.sh
script.
The recommended way to customize your configuration is using the files below, in that order:
config.yml
sentry.conf.py
.env
w/ environment variables
We currently support a very minimal set of environment variables to promote other means of configuration.
If you have any issues or questions, our Community Forum is at your service! Everytime you run the install script, it will generate a log file, sentry_install_log-<ISO_TIMESTAMP>.txt
with the output. Sharing these logs would help people diagnose any issues you might be having.
If you want to install a specific release of Sentry, use the tags/releases on this repo.
We continously push the Docker image for each commit made into Sentry, and other services such as Snuba or Symbolicator to our Docker Hub and tag the latest version on master as :latest
. This is also usually what we have on sentry.io and what the install script uses. You can use a custom Sentry image, such as a modified version that you have built on your own, or simply a specific commit hash by setting the SENTRY_IMAGE
environment variable to that image name before running ./install.sh
:
SENTRY_IMAGE=getsentry/sentry:83b1380 ./install.sh
Note that this may not work for all commit SHAs as this repository evolves with Sentry and its satellite projects. It is highly recommended to check out a version of this repository that is close to the timestamp of the Sentry commit you are installing.
Sentry comes with a cleanup cron job that prunes events older than 90 days
by default. If you want to change that, you can change the SENTRY_EVENT_RETENTION_DAYS
environment variable in .env
or simply override it in your environment. If you do not want the cleanup cron, you can remove the sentry-cleanup
service from the docker-compose.yml
file.
If you'd like to protect your Sentry install with SSL/TLS, there are
fantastic SSL/TLS proxies like HAProxy
and Nginx. You'll likely want to add this service to your docker-compose.yml
file.
You need to be on at least Sentry 9.1.2 to be able to upgrade automatically to the latest version. If you are not, upgrade to 9.1.2 first by checking out the 9.1.2 tag on this repo.
The included install.sh
script is meant to be idempotent and to bring you to the latest version. What this means is you can and should run install.sh
to upgrade to the latest version available. Remember that the output of the script will be stored in a log file, sentry_install_log-<ISO_TIMESTAMP>.txt
, which you may share for diagnosis if anything goes wrong.
- Create a new pg db, ex:
hint-sentry-pg-v8.20
- Create a new redis db, ex:
hint-sentry-redis-v8.20
- Create a new app, ex:
hint-sentry-v8.20
- Follow the steps to ##Deploy
- Ssh into the Aptible's app (
aptible ssh --app hint-sentry-v8.20
) and generate a new secret key (sentry config generate-secret-key
) - Set the required env variables:
For version 8.20 those are:
- SENTRY_DB_NAME
- SENTRY_DB_PASSWORD
- SENTRY_DB_USER
- SENTRY_EMAIL_HOST, suggested value:
smtp.mailgun.org
- SENTRY_EMAIL_PASSWORD
- SENTRY_EMAIL_USER, suggested value:
[email protected]
- SENTRY_POSTGRES_HOST
- SENTRY_POSTGRES_PORT
- SENTRY_REDIS_HOST
- SENTRY_REDIS_PASSWORD
- SENTRY_REDIS_PORT
- SENTRY_SECRET_KEY
- SENTRY_SERVER_EMAIL, suggested value:
[email protected]
- SENTRY_SINGLE_ORGANIZATION, suggested value:
true
- SENTRY_URL_PREFIX
- SENTRY_USE_SSL, suggested value:
true
- Login to the Aptible app via ssh and execute:
sentry upgrade
- Clone this repository
git clone [email protected]:hinthealth/onpremise.git
- Add the Aptible's remote, ex:
git remote add aptible [email protected]:hint-production/hint-sentry-v8.20.git
- Push the code to the Aptible's remote
- Update this repo against upstream (
getsentry/onpremise
), if any conflicts where to happen it would only be on this README. - Add any new required env variables
- Backup database just in case the upgrade fails you need to rollback
- Follow the steps to ##Deploy
- Login to the Aptible app via ssh and execute:
sentry upgrade