Healthcheck configuration
On roles that are running Traefik, Kamal will supply a default healthcheck to docker run
. For other roles, by default no healthcheck is supplied.
If no healthcheck is supplied and the image does not define one, they we wait for the container to reach a running state and then pause for the readiness delay.
The default healthcheck is curl -f http://localhost:<port>/<path>
, so it assumes that curl
is available within the container.
Healthcheck options
These go under the healthcheck
key in the root or role configuration.
healthcheck:
Command
The command to run, defaults to curl -f http://localhost:<port>/<path>
on roles running Traefik:
cmd: "curl -f http://localhost"
Interval
The Docker healthcheck interval, defaults to 1s
:
interval: 10s
Max attempts
The maximum number of times we poll the container to see if it is healthy, defaults to 7
. Each check is separated by an increasing interval starting with 1 second.
max_attempts: 3
Port
The port to use in the healthcheck, defaults to 3000
:
port: "80"
Path
The path to use in the healthcheck, defaults to /up
:
path: /health
Cords for zero-downtime deployments
The cord file is used for zero-downtime deployments. The healthcheck is augmented with a check for the existence of the file. This allows us to delete the file and force the container to become unhealthy, causing Traefik to stop routing traffic to it.
Kamal mounts a volume at this location and creates the file before starting the container. You can set the value to false
to disable the cord file, but this loses the zero-downtime guarantee.
The default value is /tmp/kamal-cord
:
cord: /cord
Log lines
Number of lines to log from the container when the healthcheck fails, defaults to 50
:
log_lines: 100