Healthchecks prepares its configuration in hc/settings.py. It reads configuration
from environment variables. Below is a list of variables it reads and uses:
ALLOWED_HOSTSDefault: *
The host/domain names that this site can serve. You can specify multiple domain names by separating them with commas:
ALLOWED_HOSTS=my-hc.example.org,alternative-name.example.org
Apart from the comma-separated syntax, this is a standard Django setting. Read more about it in the Django documentation.
APPRISE_ENABLEDDefault: False
A boolean that turns on/off the Apprise integration.
Before enabling the Apprise integration, make sure the apprise package is installed:
pip install apprise
DBDefault: sqlite
The database enginge to use. Possible values: sqlite, postgres, mysql.
DB_CONN_MAX_AGEDefault: 0
This is a standard Django setting, read more in Django documentation.
DB_HOSTDefault: "" (empty string)
This is a standard Django setting, read more in Django documentation.
DB_NAMEDefault: hc (PostgreSQL, MySQL) or /path/to/projectdir/hc.sqlite (SQLite)
This is a standard Django setting, read more in Django documentation.
DB_PASSWORDDefault: "" (empty string)
This is a standard Django setting, read more in Django documentation.
DB_PORTDefault: "" (empty string)
This is a standard Django setting, read more in Django documentation.
DB_SSLMODEDefault: prefer
PostgreSQL-specific, details
DB_TARGET_SESSION_ATTRSDefault: read-write
PostgreSQL-specific, details
DB_USERDefault: postgres (PostgreSQL) or root (MySQL)
This is a standard Django setting, read more in Django documentation.
DEBUGDefault: True
A boolean that turns on/off debug mode.
Never run a Healthchecks instance in production with the debug mode turned on!
This is a standard Django setting, read more in Django documentation.
DEFAULT_FROM_EMAILDefault: [email protected]
This is a standard Django setting, read more in Django documentation.
DISCORD_CLIENT_IDDefault: None
The Discord Client ID, required by the Discord integration.
To set up the Discord integration:
SITE_ROOT/integrations/add_discord/. For example, if your SITE_ROOT
  is https://my-hc.example.org then the Redirect URI would be
  https://my-hc.example.org/integrations/add_discord/DISCORD_CLIENT_ID and DISCORD_CLIENT_SECRET environment
  variables.DISCORD_CLIENT_SECRETDefault: None
The Discord Client Secret, required by the Discord integration. Look it up at https://discordapp.com/developers/applications/me.
EMAIL_HOSTDefault: "" (empty string)
This is a standard Django setting, read more in Django documentation.
EMAIL_HOST_PASSWORDDefault: "" (empty string)
This is a standard Django setting, read more in Django documentation.
EMAIL_HOST_USERDefault: "" (empty string)
This is a standard Django setting, read more in Django documentation.
EMAIL_PORTDefault: 587
This is a standard Django setting, read more in Django documentation.
EMAIL_USE_TLSDefault: True
This is a standard Django setting, read more in Django documentation.
EMAIL_USE_VERIFICATIONDefault: True
A boolean that turns on/off a verification step when adding an email integration.
If enabled, whenever an user adds an email integration, Healthchecks emails a verification link to the new address. The new integration becomes active only after user clicks the verification link.
If you are setting up a private healthchecks instance where
you trust your users, you can opt to disable the verification step. In that case,
set EMAIL_USE_VERIFICATION to False.
LINENOTIFY_CLIENT_IDDefault: None
LINENOTIFY_CLIENT_SECRETDefault: None
MASTER_BADGE_LABELDefault: same as SITE_NAME
The label for the "Overall Status" status badge.
MATRIX_ACCESS_TOKENDefault: None
The Matrix bot user's access token, required by the Matrix integration.
To set up the Matrix integration:
MATRIX_ environment variables. Example:MATRIX_ACCESS_TOKEN=[a long string of characters returned by the login call]
MATRIX_HOMESERVER=https://matrix.org
MATRIX_USER_ID=@mychecks:matrix.org
MATRIX_HOMESERVERDefault: None
The Matrix bot's homeserver address, required by the Matrix integration.
MATRIX_USER_IDDefault: None
The Matrix bot's user identifier, required by the Matrix integration.
MATTERMOST_ENABLEDDefault: True
A boolean that turns on/off the Mattermost integration. Enabled by default.
MSTEAMS_ENABLEDDefault: True
A boolean that turns on/off the MS Teams integration. Enabled by default.
OPSGENIE_ENABLEDDefault: True
A boolean that turns on/off the Opsgenie integration. Enabled by default.
PAGERTREE_ENABLEDDefault: True
A boolean that turns on/off the PagerTree integration. Enabled by default.
PD_APP_IDDefault: None
PagerDuty application ID. If set, enables the PagerDuty
Simple Install Flow.
If None, Healthchecks will fall back to the even simpler flow where users manually
copy integration keys from PagerDuty and paste them in Healthchecks.
To set up:
https://your-domain.com/integrations/add_pagerduty/PD_APP_ID environment
  variablePD_ENABLEDDefault: True
A boolean that turns on/off the PagerDuty integration. Enabled by default.
PING_BODY_LIMITDefault: 10000
The upper size limit in bytes for logged ping request bodies.
The default value is 10000 (10 kilobytes). You can adjust the limit or you can remove
it altogether by setting this value to None.
PING_EMAIL_DOMAINDefault: localhost
The domain to use for generating ping email addresses. Example:
PING_EMAIL_DOMAIN=ping.my-hc.example.org
In this example, Healthchecks would generate ping email addresses similar
to [email protected].
PING_ENDPOINTDefault: SITE_ROOT + /ping/
The base URL to use for generating ping URLs. Example:
PING_ENDPOINT=https://ping.my-hc.example.org
In this example, Healthchecks would generate ping URLs similar
to https://ping.my-hc.example.org/3f1a7317-8e96-437c-a17d-b0d550b51e86.
PROMETHEUS_ENABLEDDefault: True
A boolean that turns on/off the Prometheus integration. Enabled by default.
PUSHBULLET_CLIENT_IDDefault: None
PUSHBULLET_CLIENT_SECRETDefault: None
PUSHOVER_API_TOKENDefault: None
The Pushover API token, required by the Pushover integration.
To enable the Pushover integration:
https://my-hc.example.org/).PUSHOVER_API_TOKEN and PUSHOVER_SUBSCRIPTION_URL environment
  variables. The Pushover subscription URL should look similar to
  https://pushover.net/subscribe/yourAppName-randomAlphaNumericData.PUSHOVER_EMERGENCY_EXPIRATIONDefault: 86400 (24 hours)
Specifies how many seconds an emergency Pushoover notification will continue to be retried for.
More information in Pushover API documentation.
PUSHOVER_EMERGENCY_RETRY_DELAYDefault: 300 (5 minutes)
Specifies how often (in seconds) the Pushover servers will send the same notification to the user.
More information in Pushover API documentation.
PUSHOVER_SUBSCRIPTION_URLDefault: None
The Pushover Subscription URL, required by the Pushover integration.
REGISTRATION_OPENDefault: True
A boolean that controls whether site visitors can create new accounts.
Set it to False if you are setting up a private Healthchecks instance, but
it needs to be publicly accessible (so, for example, your cloud services
can send pings to it).
If you close new user registration, you can still selectively invite users to your team account.
REMOTE_USER_HEADERDefault: None
Specifies the request header to use for external authentication.
Healthchecks supports external authentication by means of HTTP headers set by reverse proxies or the WSGI server. This allows you to integrate it into your existing authentication system (e.g., LDAP or OAuth) via an authenticating proxy. When this option is enabled, Healtchecks will trust the header's value implicitly, so it is very important to ensure that attackers cannot set the value themselves (and thus impersonate any user). How to do this varies by your chosen proxy, but generally involves configuring it to strip out headers that normalize to the same name as the chosen identity header.
To enable this feature, set the REMOTE_USER_HEADER value to a header you wish to authenticate with. HTTP headers will be prefixed with HTTP_ and have any dashes converted to underscores. Headers without that prefix can be set by the WSGI server itself only, which is more secure.
When REMOTE_USER_HEADER is set, Healthchecks will:
RP_IDDefault: None
The Relying Party identifier, required by the WebAuthn second-factor authentication feature.
Healthchecks optionally supports two-factor authentication using the WebAuthn
standard. To enable WebAuthn support, set the RP_ID setting to a non-null value.
Set its value to your site's domain without scheme and without port. For example,
if your site runs on https://my-hc.example.org, set RP_ID to my-hc.example.org.
Note that WebAuthn requires HTTPS, even if running on localhost. To test WebAuthn
locally with a self-signed certificate, you can use the runsslserver command
from the django-sslserver package.
S3_ACCESS_KEYDefault: None
Access key of an account in S3 service.
Healthchecks can optionally upload ping request body data to S3-compatible object storage instead of storing it in the database. To use this feature, provide valid credentials to a S3-compatible service by setting the following environment variables:
S3_ACCESS_KEY (example: AKIAFIXMEFIXME)S3_BUCKET (example: my-bucket)S3_ENDPOINT (example: s3.eu-central-1.amazonaws.com)S3_REGION (example: eu-central-1)S3_SECRET_KEYS3_BUCKETDefault: None
Name of the bucket in S3 service for storing ping request body data.
S3_ENDPOINTDefault: None
URL to the S3-compatible service.
S3_REGIONDefault: None
Region name of buckets in S3 service.
S3_SECRET_KEYDefault: None
Secret key of an account in S3 service.
S3_TIMEOUTDefault: 60
Timeout for each individual S3 operatio, in seconds.
SECRET_KEYDefault: ---
A secret key used for cryptographic signing, and should be set to a unique, unpredictable value.
This is a standard Django setting, read more in Django documentation.
SHELL_ENABLEDDefault: False
A boolean that turns on/off the "Shell Commands" integration.
The "Shell Commands" integration runs user-defined local shell commands when checks
go up or down. This integration is disabled by default, and can be enabled by setting
the SHELL_ENABLED environment variable to True.
Note: be careful when using "Shell Commands" integration, and only enable it when
you fully trust the users of your Healthchecks instance. The commands will be executed
by the manage.py sendalerts process, and will run with its system permissions.
SIGNAL_CLI_SOCKETDefault: None
The path to the signal-cli UNIX socket.
Healthchecks uses signal-cli to send Signal notifications. Healthcecks interacts with signal-cli over UNIX socket (requires signal-cli 0.10.0 or later).
To enable the Signal integration:
signal-cli -a +xxxxxx daemon --socket /tmp/signal-cli-socketSIGNAL_CLI_SOCKET environment variable.SITE_LOGO_URLDefault: None
An URL pointing to the image you want to use as the site logo. If not set,
Healthchecks will use a fallback image (/static/img/logo.png).
Example:
SITE_LOGO_URL=https://example.org/my-custom-logo.svg
SITE_NAMEDefault: Mychecks
The display name of this Healthchecks instance. Healthchecks uses it throughout its web UI and documentation.
SITE_ROOTDefault: http://localhost:8000
The base URL of this Healthchecks instance. Healthchecks uses SITE_ROOT whenever
it needs to construct absolute URLs.
SLACK_CLIENT_IDDefault: None
The Slack Client ID, used by the Slack integration.
The Slack integration can work with or without the Slack Client ID. If the Slack Client ID is not set, in the "Integrations - Add Slack" page, Healthchecks will ask the user to provide a webhook URL for posting notifications.
If the Slack Client is set, Healthchecks will use the OAuth2 flow to get the webhook URL from Slack. The OAuth2 flow is more user-friendly. To set it up, go to https://api.slack.com/apps/ and create a Slack app. When setting up the Slack app, make sure to:
SITE_ROOT/integrations/add_slack_btn/.
  For example, if your SITE_ROOT is https://my-hc.example.org then the
  Redirect URL would be https://my-hc.example.org/integrations/add_slack_btn/.SLACK_CLIENT_SECRETDefault: None
The Slack Client Secret. Required if SLACK_CLIENT_ID is set.
Look it up at https://api.slack.com/apps/.
SLACK_ENABLEDDefault: True
A boolean that turns on/off the Slack integration. Enabled by default.
SPIKE_ENABLEDDefault: True
A boolean that turns on/off the Spike.sh integration. Enabled by default.
TELEGRAM_BOT_NAMEDefault: ExampleBot
The Telegram bot name, required by the Telegram integration.
To set up the Telegram integration:
TELEGRAM_BOT_NAME and TELEGRAM_TOKEN environment variables.settelegramwebhook management command. This command tells Telegram
where to forward channel messages by invoking Telegram's
setWebhook API call:$ ./manage.py settelegramwebhook
Done, Telegram's webhook set to: https://my-monitoring-project.com/integrations/telegram/bot/
For this to work, your SITE_ROOT must be publicy accessible and use the "https://"
scheme.
TELEGRAM_TOKENDefault: None
The Telegram bot user's authentication token, required by the Telegram integration.
TRELLO_APP_KEYDefault: None
The Trello app key, required by the Trello integration.
To set up the Trello integration, get a developer API key from
https://trello.com/app-key and put it in the
TRELLO_APP_KEY environment variable.
TWILIO_ACCOUNTDefault: None
TWILIO_AUTHDefault: None
TWILIO_FROMDefault: None
TWILIO_USE_WHATSAPPDefault: False
USE_PAYMENTSDefault: False
A boolean that turns on/off billing features.
VICTOROPS_ENABLEDDefault: True
A boolean that turns on/off the Splunk On-Call (VictorOps) integration. Enabled by default.
WEBHOOKS_ENABLEDDefault: True
A boolean that turns on/off the Webhooks integration. Enabled by default.
ZULIP_ENABLEDDefault: True
A boolean that turns on/off the Zulip integration. Enabled by default.