Healthchecks prepares its configuration in hc/settings.py. It reads configuration
from environment variables. Below is a list of environment variables it reads and uses.
ADMINSDefault: "" (empty string)
A comma-sepparated list of email addresses to send code error notifications to.
When DEBUG=False, Healthchecks will send the details of exceptions raised in the
request/response cycle to the listed addresses. Example:
ADMINS=alice@example.org,bob@example.org
Note: for error notifications to work, make sure you have also specified working
SMTP credentials in the EMAIL_... environment variables.
ALLOWED_HOSTSDefault: the domain part of SITE_ROOT
The host/domain names that this site can serve. Healthchecks populates this setting automatically with the domain part of SITE_ROOT. You do not need to set it unless you serve Healthchecks on more than one domain.
If you do serve the same Healthchecks instance on more than one domain, specify
them all in ALLOWED_HOSTS, separated by commas:
ALLOWED_HOSTS=first.example.org,second.example.org
Aside 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 engine 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: healthchecks@example.org
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_SSLDefault: False
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 a user adds an email integration, Healthchecks emails a verification link to the new address. The new integration becomes active only after the 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.
http_proxy and https_proxyDefault: "" (empty string)
Specifies the proxy server to use for outgoing HTTP and HTTPS requests. Supports different proxy server types. Examples:
https_proxy=http://example.org:1234
https_proxy=https://example.org:1234
https_proxy=socks4://example.org:1234
https_proxy=socks5://example.org:1234
Healthchecks uses libcurl as the HTTP client library for making HTTP(S) requests. For more information about the proxy functionality, please see libcurl documentation.
Note: If your proxy server has a private IP address, you will also need to
set the INTEGRATIONS_ALLOW_PRIVATE_IPS setting to True to use it.
INTEGRATIONS_ALLOW_PRIVATE_IPSDefault: False
A boolean that controls whether the integrations are allowed to make
HTTP(S) requests to private IP addresses (127.0.0.1, 192.168.x.x, ...). This setting
is set to False by default, because allowing users to define webhooks that probe
internal addresses is a security risk.
Only enable this setting if you run your Healthchecks instance in a trusted environment, and need to integrate with services running in your internal network.
This setting affects all integration types, not just webhooks. For example,
if you run a Gotify instance on localhost, you will need to enable
INTEGRATIONS_ALLOW_PRIVATE_IPS to be able to use it via the Gotify integration.
This setting affects all outbound HTTP requests, including those made while setting up new integrations (e.g. during the OAuth2 authorization flow).
This setting also affects connections to the proxy server when the http_proxy or
https_proxy environment variables are set. If your proxy server has a private
IP address, you will need to enable INTEGRATIONS_ALLOW_PRIVATE_IPS to use it.
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=hc.example.org
In this example, Healthchecks would generate ping email addresses similar
to 3f1a7317-8e96-437c-a17d-b0d550b51e86@hc.example.org.
This setting only controls how the ping email addresses are constructed, and does not by itself enable the ping-by-sending-email functionality. To receive emails, you will also need:
hc.example.org to your Healthchecks
  instance's IP address.manage.py smtpd (Healthchecks' SMTP listener service) running, listening
  on port 25, and reachable from the outside world. If you are using the
  official Docker image,
  see the instructions here for enabling the SMTP
  listener service.PING_ENDPOINTDefault: SITE_ROOT + /ping/
The base URL to use for constructing ping URLs for display. Healthchecks constructs ping
URLs by appending either an UUID value or <ping-key>/<slug> value to PING_ENDPOINT.
Notes:
PING_ENDPOINT value ends with a trailing slash. If a trailing slash
  is missing, Healthchecks will not add it implicitly.PING_ENDPOINT for formatting ping URLs for display.
  The PING_ENDPOINT value does not influence the routing of incoming HTTP requests.
  If you change the PING_ENDPOINT value, you will likely also need to add matching
  URL rewriting rules in your reverse proxy configuration.Example:
PING_ENDPOINT=https://ping.my-hc.example.org/
With this setting, Healthchecks will generate ping URLs similar to:
https://ping.my-hc.example.org/3f1a7317-8e96-437c-a17d-b0d550b51e86
https://ping.my-hc.example.org/1fj9XWM6Ns8vLGTmnPGk9g/dummy-slug
PROMETHEUS_ENABLEDDefault: True
A boolean that turns on/off the Prometheus integration. Enabled by default.
PUSHBULLET_CLIENT_IDDefault: None
The Pushbullet Client ID, required by the Pushbullet integration.
To set up the Pushbullet integration:
redirect_uri to your OAuth client. The URI format is
  SITE_ROOT/integrations/add_pushbullet/. 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_pushbullet/client_id and client_secret values. Put them
  in the PUSHBULLET_CLIENT_ID and PUSHBULLET_CLIENT_SECRET environment
  variables.Read more about setting up a Pushbullet OAuth client in the Pushbullet OAuth2 guide.
PUSHBULLET_CLIENT_SECRETDefault: None
The Pushbullet Client Secret, required by the Pushbullet integration. Look it up at https://www.pushbullet.com/#settings/clients.
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 Pushover 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. If you use a reverse proxy that handles user authentication, and the reverse proxy can pass the authenticated user's email address in an HTTP request header, you can use this setting to integrate Healthchecks with it.
When REMOTE_USER_HEADER is set, Healthchecks will:
REMOTE_USER_HEADERThe header name in REMOTE_USER_HEADER must be specified in upper-case,
with any dashes replaced with underscores, and prefixed with HTTP_. For
example, if your authentication proxy sets a X-Authenticated-User request
header, you should set REMOTE_USER_HEADER=HTTP_X_AUTHENTICATED_USER.
Important: When this option is enabled, Healthchecks 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.
On using local_settings.py:
When Healthchecks reads settings from environment variables and encounters
the REMOTE_USER_HEADER environment variable, it sets two settings,
REMOTE_USER_HEADER and AUTHENTICATION_BACKENDS. This logic has already run by the
time Healthchecks reads local_settings.py. Therefore, if you configure Healthchecks
using the local_settings.py file instead of environment variables, and specify
REMOTE_USER_HEADER there, you will also need a line which sets the other setting,
AUTHENTICATION_BACKENDS:
REMOTE_USER_HEADER = "HTTP_X_AUTHENTICATED_USER"
AUTHENTICATION_BACKENDS = ["hc.accounts.backends.CustomHeaderBackend"]
ROCKETCHAT_ENABLEDDefault: True
A boolean that turns on/off the Rocket.Chat integration. Enabled by default.
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 an 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
The secret key of an account in S3 service.
S3_TIMEOUTDefault: 60
Timeout for individual S3 operations, in seconds.
S3_SECUREDefault: True
Whether to use secure (TLS) connection to S3 or not. To
use unencrypted HTTP requests, set this value to False.
SECRET_KEYDefault: ---
A secret key used for cryptographic signing. Should be set to a unique, unpredictable value.
This is a standard Django setting, read more in Django documentation.
SECURE_PROXY_SSL_HEADERDefault: None
Comma-separated HTTP header name and value that signifies a request is secure (made over https://). This information is important for CSRF protection.
If Healthchecks is running behind a proxy, the proxy may be "swallowing" whether the original request uses HTTPS or not. In this case, you may see HTTP 403 errors when submitting forms (for example, trying to log in).
If set, the value should contain the name of the header to look for and the required
value, separated with comma. The header name must be specified in upper-case,
with any dashes replaced with underscores, and prefixed with HTTP_. Example:
# environment variable
SECURE_PROXY_SSL_HEADER=HTTP_X_FORWARDED_PROTO,https
You should only set this environment variable if you control your proxy or have some other guarantee that it sets/strips this header appropriately.
Note on using local_settings.py:
When Healthchecks reads settings from environment variables, it expects
SECURE_PROXY_SSL_HEADER to contain header name and value, separated with comma.
If you set SECURE_PROXY_SSL_HEADER in local_settings.py, it should be a
a tuple with two elements instead:
# in local_settings.py
SECURE_PROXY_SSL_HEADER = ("HTTP_X_FORWARDED_PROTO", "https")
This environment variable maps to 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, or the hostname:port of the signal-cli TCP socket.
Example (UNIX socket):
SIGNAL_CLI_SOCKET=/tmp/signal-cli.socket
Example (TCP socket):
SIGNAL_CLI_SOCKET=example.org:7583
Healthchecks uses signal-cli to send Signal notifications. Healthcecks interacts with signal-cli over UNIX or TCP 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.
You can place a custom logo in /static/img/, run manage.py collectstatic, and
point SITE_LOGO_URL to it like so:
SITE_LOGO_URL=/static/img/my-custom-logo.png
Or you can serve the logo from another server, and point to it using an absolute URL:
SITE_LOGO_URL=https://example.org/cdn/my-custom-logo.png
Either way, Healthchecks will use the provided SITE_LOGO_URL value as-is in HTML
pages, and you should use an URL that the end user's browser will be able to
access directly. The logo image can use any image format supported by browsers
(PNG, SVG, JPG are all fine).
Docker note. You can build a custom Docker image with your logo "baked in". To do so, use a Dockerfile with the following contents, and with your logo.png placed next to it:
FROM healthchecks/healthchecks
COPY logo.png /opt/healthchecks/static-collected/img/
This overwrites the default placeholder logo, so, in this case, you do not need to
specify SITE_LOGO_URL. Notice that the logo must be placed in static-collected, not
static. This is because manage.py collectstatic has already been run in the base
image's build time, and the web server will not recognize any new files placed in the
static directory.
Please do not use the Healthchecks.io logo (the one with the dark green background) on self-hosted instances. This logo is not part of the Healthchecks open-source project.
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. Healthchecks also uses SITE_ROOT to set
several other settings, detailed below.
If the ALLOWED_HOSTS setting is not set, Healthchecks
automatically populates it with the domain part of SITE_ROOT. Under typical scenarios
you can use the automatically populated value and do not need to set
ALLOWED_HOSTS yourself.
If the SITE_ROOT contains a path (for example, http://localhost:8000/prefix),
then Healthchecks automatically sets the following additional Django settings:
LOGIN_URL=/prefix/accounts/login/. Required
for correct redirection to a log-in page when an unauthenticated user requests a
page that requires authentication. LOGIN_URL is a standard Django setting, read more
about it in
Django documentation.STATIC_URL=/prefix/static/. Required for correct
URL generation to static files (JS, CSS, images). STATIC_URL is a standard Django
setting, read more about it in
Django documentation.On using local_settings.py: Healthchecks only sets the above additional settings
if you specify SITE_ROOT via an environment variable. If you instead specify it in
local_settings.py, you will also need to set ALLOWED_HOSTS, LOGIN_URL, and
STATIC_URL there.
SLACK_CLIENT_IDDefault: None
The Slack Client ID, used by the Healthchecks integration for Slack.
The 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 ID 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 Healthchecks integration for Slack. 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 publicly 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 Account SID, required by the SMS, Call, and WhatsApp integrations.
TWILIO_AUTHDefault: None
Twilio Auth token, required by the SMS, Call, and WhatsApp integrations.
TWILIO_FROMDefault: None
The Twilio phone number to use as the sender for SMS and WhatsApp notifications, and as the caller for Call integrations.
Example:
TWILIO_FROM=+15017122661
TWILIO_MESSAGING_SERVICE_SIDDefault: None
The Twilio Messaging Service SID for sending SMS and WhatsApp notifications.
TWILIO_MESSAGING_SERVICE_SID is required for sending WhatsApp notifications.
TWILIO_MESSAGING_SERVICE_SID is optional for sending SMS notifications. If specified,
Healthchecks will pass it in the "MessagingServiceSid" field to Twilio API. This will
result in Twilio using a Messaging Service instead of a plain sender number to deliver
the SMS messages. If not specified, Healthchecks will fall back to using
the "From" field with the value configured in TWILIO_FROM.
Example:
TWILIO_MESSAGING_SERVICE_SID=MGe56e622d540e6badc52ae0ac4af028c6
TWILIO_USE_WHATSAPPDefault: False
A boolean that turns on/off the WhatsApp integration. For the WhatsApp integration to work, you will also need to specify:
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.
WHATSAPP_DOWN_CONTENT_SIDDefault: None
Identifier of the Twilio content template to use for WhatsApp "down" notifications. Required by the WhatsApp integration.
Meta requires WhatsApp message templates to be pre-registered and approved. Create a content template in your Twilio account with the following contents:
The check “{{1}}” is DOWN.
You can tweak the message contents as needed, but make sure it has a single placeholder similar to the above example.
WHATSAPP_UP_CONTENT_SIDDefault: None
Identifier of the Twilio content template to use for WhatsApp "up" notifications. Required by the WhatsApp integration.
Meta requires WhatsApp message templates to be pre-registered and approved. Create a content template in your Twilio account with the following contents:
The check “{{1}}” is now UP.
You can tweak the message contents as needed, but make sure it has a single placeholder similar to the above example.
ZULIP_ENABLEDDefault: True
A boolean that turns on/off the Zulip integration. Enabled by default.