Skip to content

Latest commit

 

History

History
90 lines (55 loc) · 3.76 KB

README.md

File metadata and controls

90 lines (55 loc) · 3.76 KB

Bindman Swarm Listener

Build Status Go Report Card

This project defines a Bindman-DNS Swarm Listener that listens to a Docker Swarm event stream and delegates its services' DNS binding updates to a Bindman DNS Manager.

Configuration

The BindmanDNS Swarm Listener is configurable through environment variables. The following are mandatory:

  1. BINDMAN_DNS_MANAGER_ADDRESS: the address of the DNS Manager which will manage the identified DNS updates. The DNS Manager should implement the Sandman DNS Webhook;

  2. BINDMAN_REVERSE_PROXY_ADDRESS: the address of the Reverse Proxy which will load balance requests to the Sandman managed hostnames.

  3. BINDMAN_DNS_TAGS: a comma-separated list of dns tags enabling this listener to choose which service updates its dns manager should deal with

By the default, the Bindman DNS Swarm Listener will query the docker host through its docker.sock (and thus should be mapped as a volume). That can be changed through the following optional environment varibles:

  1. DOCKER_HOST: docker server url, if necessary (e.g. remotely listening);

  2. DOCKER_API_VERSION: the version of the docker API to reach; defaults to latest when empty;

  3. DOCKER_TLS_VERIFY: enable or disable TLS verification, off by default;

  4. DOCKER_CERT_PATH: the path to load the TLS certificates from.

A TTL needs to be defined for the DNS rules being managed by the Sandman project. By default, the TTL is 3600 seconds. To change it, write to the BINDMAN_DNS_TTL environment variable.

The runtime mode can also be configured with the use of the BINDMAN_MODE environment variable: empty|PROD for production mode or DEBUG for debug mode.

DNS Rules

The DNS binding rules should be written as service rules according to the format expected by Traefik, the default Reverse Proxy and Load Balancer adopted by this project. That is, each swarm service should run with the following deployment labels defined:

...
deploy:
    ...
    labels:
        - traefik.frontend.rule=Host:<the service host name>
        - traefik.port=<the service exposed port>
        - traefik.frontend.entryPoints=<comma-separated dns tags>
    ...
...

This project delegates hostname management by adopting a Tag system, where each service launched by a Docke Swarm cluster is annotated with a set of Tags and each DNS listener is also run with its own set of Tags.

The intersection of these two Tag sets indicates which DNS Managers will manage which service hostname attribution.

It is through the label traefik.frontend.entryPoints that we are expecting these Tags to be defined, as a comma-separated list of strings.

Try it yourself

We provive a docker-compose.yml and hello.yml so you can see things happening.

The docker-compose.yml defines a bindman swarm listener and a dummy manager to handle the hostname additions and removals.

To start it, enable Docker Swarm on your host machine with a docker swarm init command and run:

docker stack deploy -c docker-compose.yml bindman

After that, deploy the provided hello service with:

docker stack deploy -c hello.yml hello

To check it works, a curl to the dummy manager should suffice:

$ curl <swarm host ip>:7070/records
[{"name":"hello.test.com","value":"0.0.0.0","type":"A"}]

If you run the commands above on your own machine, the <swarm host ip> should be localhost

Remove the hello stack with a docker stack rm hello command.

Check it works:

$ curl <swarm host ip>:7070/records
[]