Since docker-compose version 2.1 file format the healthcheck parameter has been introduced. This allows a check to be configured in order to determine whether or not containers for a service are "healthy."
This is a common problem and in earlier versions of docker-compose requires the use of additional tools and scripts such as wait-for-it and dockerize.
Using the healthcheck
parameter the use of these additional tools and scripts is often no longer necessary.
A particularly common use case is a service that depends on a database, such as PostgreSQL. We can configure docker-compose to wait for the PostgreSQL container to startup and be ready to accept requests before continuing.
The following healthcheck has been configured to periodically check if PostgreSQL reponds to the \l
list query.
healthcheck:
test: ["CMD-SHELL", "psql -h 'localhost' -U 'postgres' -c '\\l'"]
interval: 30s
timeout: 30s
retries: 3
If the check is successful the container will be marked as healthy
. Until then it will remain in an unhealthy
state.
For more details about the healthcheck parameters interval
, timeout
and retries
see the documentation here.
Services that depend on PostgreSQL can then be configured with the depends_on
parameter as follows:
depends_on:
postgres-database:
condition: service_healthy
In this complete example docker-compose waits for the PostgreSQL service to be "healthy" before starting Kong, an open-source API gateway.
Test it out with:
docker-compose up -d
Wait until both services are running:
Starting dockercomposehealthcheck_kong-database_1
Starting dockercomposehealthcheck_kong_1
Test by querying Kong's admin endpoint:
curl http://localhost:8001/
MIT License - see the LICENSE file for details