/docker-wait-for-dependencies

Docker container that blocks until given endpoints are accessible over TCP

Primary LanguageShell

What's different compared to the original fork?

Just a minor thing - the script will notify when the service is ready. Without it, when the service is already available it looks as if it was frozen.

All kudos to orignal author. I created a pull request, but I needed that now, so I created my own image in docker hub (bartoszjarmuz/wait-for-dependencies)

https://hub.docker.com/repository/docker/bartoszjarmuz/wait-for-dependencies

Example usage:

Sample docker-compose.yml:

version: '2'
services:
  the_database:
    image: ubuntu:14.04
    command: >
      /bin/bash -c "
        sleep 5;
        nc -lk 0.0.0.0 5432;
      "
  another_service:
    image: ubuntu:14.04
    command: >
      /bin/bash -c "
        sleep 8;
        nc -lk 0.0.0.0 5555;
      "

  the_web_server:
    image: ubuntu:14.04
    depends_on:
      - the_database
      - another_service
    command: >
      /bin/bash -c "
        nc -z the_database 5432 &&
        echo Connected to DB and started!
      "

  start_dependencies:
    image: dadarek/wait-for-dependencies
    depends_on:
      - the_database
      - another_service
    command: the_database:5432 another_service:5555

Then, to guarantee that the_database and another_service are ready before running the_web_server:

$ docker-compose run --rm start_dependencies
# Some output from docker compose
$ docker-compose up the_web_server

By default, there will be a 2 second sleep time between each check. You can modify this by setting the SLEEP_LENGTH environment variable:

  start_dependencies:
    image: dadarek/wait-for-dependencies
    environment:
      - SLEEP_LENGTH: 0.5

By default, there will be a 300 seconds timeout before cancelling the wait_for. You can modify this by setting the TIMEOUT_LENGTH environment variable:

  start_dependencies:
    image: dadarek/wait-for-dependencies
    environment:
      - SLEEP_LENGTH: 1
      - TIMEOUT_LENGTH: 60