Skip to content

Latest commit

 

History

History
116 lines (82 loc) · 5.32 KB

README.md

File metadata and controls

116 lines (82 loc) · 5.32 KB

Docker Flow: Swarm Listener

The project listens to Docker Swarm events and sends requests when a change occurs. At the moment, the only supported option is to send a notification when a new service is created, or an existing service was removed from the cluster. More extensive feature support is coming soon.

Example

The example that follows will use the Swarm Listener to reconfigure the Docker Flow: Proxy whenever a new service is created.

I will assume that you already have a Swarm cluster set up.

Let's run a Proxy service. We'll use it as a way to demonstrate how Swarm Listener works.

docker network create --driver overlay proxy

docker service create --name proxy \
    -p 80:80 \
    -p 443:443 \
    -p 8080:8080 \
    --network proxy \
    -e MODE=swarm \
    vfarcic/docker-flow-proxy

Next, we'll create the swarm-listener service.

docker service create --name swarm-listener \
    --network proxy \
    --mount "type=bind,source=/var/run/docker.sock,target=/var/run/docker.sock" \
    -e DF_NOTIFY_CREATE_SERVICE_URL=http://proxy:8080/v1/docker-flow-proxy/reconfigure \
    -e DF_NOTIFY_REMOVE_SERVICE_URL=http://proxy:8080/v1/docker-flow-proxy/remove \
    --constraint 'node.role==manager' \
    vfarcic/docker-flow-swarm-listener

The service is attached to the proxy network (just as the proxy service), mounts the Docker socket, and declares the environment variables DF_NOTIFY_CREATE_SERVICE_URL and DF_NOTIFY_REMOVE_SERVICE_URL. We'll see the purpose of the variables soon.

Now we can deploy a service that will trigger the listener.

docker service create --name go-demo-db \
  --network proxy \
  mongo

docker service create --name go-demo \
  -e DB=go-demo-db \
  --network proxy \
  -l com.df.notify=true \
  -l com.df.servicePath=/demo \
  -l com.df.port=8080 \
  vfarcic/go-demo

Please note that we declared the label com.df.notify. Only services with this label (it can hold any value) will be eligible to receive notifications through Docker Flow: Swarm Listener. We also declared a couple of other labels (DF_servicePath and DF_port).

Before proceeding, we should wait until all the services are up and running. Please use the docker service ls command to check the status.

Please output the Docker Flow: Swarm Listener logs. You'll need to find the node the listener is running in, change your client to use Docker Engine running on that node, and, then, execute docker logs command. If you're using Docker Machine, the commands are as follows.

NODE=$(docker service ps swarm-listener | tail -n 1 | awk '{print $4}')

eval $(docker-machine env $NODE)

ID=$(docker ps -q -f ancestor=vfarcic/docker-flow-swarm-listener)

docker logs $ID

We found the ID of the container and displayed the logs. The output is as follows.

Starting Docker Flow: Swarm Listener
Starting iterations
Sending a service created notification to http://proxy:8080/v1/docker-flow-proxy/reconfigure?serviceName=go-demo&port=8080&servicePath=/demo

As you can see, the listener detected that the go-demo service has the label com.df.notify and sent the notification request. The address of the notification request is the value of the environment variable DF_NOTIFY_CREATE_SERVICE_URL declared in the swarm-listener service. The parameters are a combination of the service name and all the labels prefixed with DF_.

You might have seen few entries stating that the notification request failed and will be retried. Docker Flow: Swarm Listener has a built-in retry mechanism. As long as the output message does not start with ERROR:, the notification will reach the destination. Please see the Environment Variables for more info.

Let's see what happens if a service is removed.

docker service rm go-demo

docker logs $ID

The output of the docker logs commands is as follows.

Starting Docker Flow: Swarm Listener
Starting iterations
Sending a service created notification to http://proxy:8080/v1/docker-flow-proxy/reconfigure?serviceName=go-demo&port=8080&servicePath=/demo
Sending a service removed notification to http://proxy:8080/v1/docker-flow-proxy/remove?serviceName=go-demo

As you can see, the last output entry was the acknowledgment that the listener detected that the service was removed and that the notification was sent.

Environment Variables

The following environment variables can be used when creating the swarm listener service.

Name Description Default Value
DF_DOCKER_HOST Path to the Docker socket unix:///var/run/docker.sock
DF_NOTIFY_CREATE_SERVICE_URL The URL that will be used to send notification requests when a service is created
DF_NOTIFY_REMOVE_SERVICE_URL The URL that will be used to send notification requests when a service is removed
DF_INTERVAL Interval (in seconds) between service discovery requests 5
DF_RETRY Number of notification request retries 10
DF_RETRY_INTERVAL Interval (in seconds) between notification request retries 5