Service discovery for HAProxy.
This Docker image will create dynamically the haproxy.cfg
based on the labels defined in docker containers or from
a simple Yaml instead docker
- Enable or disable Stats on port 1936 with custom password
- Discover and setup haproxy from Docker Tag
- Discover and setup haproxy redirect from Docker Tag
- Setup HAProxy CFG from a Yaml file.
The Easy HAProxy will create the haproxy.cfg
automatically based on the containers or from a YAML provided.
The basic command line to run is:
docker run -d \
--name easy-haproxy-container \
-v /var/run/docker.sock:/var/run/docker.sock \
-e EASYHAPROXY_DISCOVER="swarm|docker|static" \
# + Environment Variables \
# + ports mapped to the host \
byjg/easy-haproxy
The mapping to /var/run/docker.sock
is necessary to discover the docker containers and get the labels;
The environment variables will setup the HAProxy.
Environment Variable | Description |
---|---|
EASYHAPROXY_DISCOVER | How haproxy.cfg will be created: static , docker or swarm |
EASYHAPROXY_LABEL_PREFIX | (Optional) The key will search to match resources. Default: easyhaproxy . |
HAPROXY_USERNAME | (Optional) The HAProxy username to the statistics. Default: admin |
HAPROXY_PASSWORD | The HAProxy password to the statistics. If not set disable stats. |
HAPROXY_STATS_PORT | (Optional) The HAProxy port to the statistics. Default: 1936 |
HAPROXY_CUSTOMERRORS. | (Optional) If HAProxy will use custom HTML errors. true/false. Default: false |
The environment variable EASYHAPROXY_DISCOVER
will define where is located your containers (see below more details):
- docker
- swarm
- static
Easy HAProxy can discover automatically the container services running in the same network of Docker or in a Docker Swarm cluster.
This method will use a regular docker installation to discover the containers and configure the HAProxy.
The only requirement is that containers and easy-haproxy must be in the same docker network.
The discover will occur every minute.
e.g.:
docker create networkd easyhaproxy
docker run --network easyhaproxy byjg/easyhaproxy
docker run --network easyhaproxy myimage
This method requires a functional Docker Swarm Cluster. The system will search for the labels in all containers on all swarm nodes.
The discover will occur every minute.
Important: easyhaproxy needs to be in the same network of the containers or otherwise will not access.
Tag | Description | Example |
---|---|---|
easyhaproxy.[definition].mode | (Optional) Is this http or tcp mode in HAProxy. (Defaults to http) |
http |
easyhaproxy.[definition].port | (Optional) What is the port that the HAProxy will listen to. (Defaults to 80) | 80 |
easyhaproxy.[definition].localport. | (Optional) What is the port that the container is listening. (Defaults to 80) | 8080 |
easyhaproxy.[definition].host | What is the host that the HAProxy will listen to. | somehost.com |
easyhaproxy.[definition].redirect | (Optional) Host redirects from connections in the port defined above. | foo.com--https://bla.com,bar.com--https://bar.org |
easyhaproxy.[definition].sslcert | (Optional) Cert PEM Base64 encoded. | |
easyhaproxy.[definition].health-check | (Optional) ssl , enable health check via SSL in mode tcp (Defaults to "empty") |
if you are deploying a stack in a Docker Swarm cluster set labels at the deploy
level:
services:
foo:
deploy:
labels:
easyhaproxy.my.host: "www.example.org"
easyhaproxy.my.localport: 8080
...
docker run \
-l easyhaproxy.webapi.port=80\
-l easyhaproxy.webapi.host=byjg.com.br \
....
docker run \
-l easyhaproxy.express.port=80 \
-l easyhaproxy.express.localport=3000 \
-l easyhaproxy.express.host=express.byjg.com.br \
-l easyhaproxy.admin.port=80 \
-l easyhaproxy.admin.localport=3001 \
-l easyhaproxy.admin.host=admin.byjg.com.br \
.... \
some/myimage
Used to pass on SSL-termination to a backend. Alternatively, you can enable health-check via SSL on the backend with the optional health-check
label:
docker run \
-l easyhaproxy.example.mode=tcp \
-l easyhaproxy.example.health-check=ssl \
-l easyhaproxy.example.port=443
.... \
some/tcp-service
docker run \
-l easyhaproxy.[definition].redirect=www.byjg.com.br--http://byjg.com.br,byjg.com--http://byjg.com.br
This method expects a YAML file to setup the haproxy.cfg
Create a YAML file and map to /etc/haproxy/easyconfig.yml
stats:
username: admin
password: password
port: 1936 # Optional (default 1936)
customerrors: true # Optional (default false)
easymapping:
- port: 80
hosts:
host1.com.br: container:5000
host2.com.br: other:3000
redirect:
www.host1.com.br: http://host1.com.br
- port: 443
ssl_cert: /path/to/ssl/certificate
hosts:
host1.com.br: container:80
- port: 8080
hosts:
host3.com.br: domain:8181
Running:
docker run -v /my/config.yml:/etc/haproxy/easyconfig.yml .... byjg/easyhaproxy
Map a folder containing valid HAProxy .cfg
files to /etc/haproxy/conf.d
. It will be concatenated to your HAProxy CFG.
docker run \
/* other parameters */
-v /your/local/conf.d:/etc/haproxy/conf.d \
-d byjg/easy-haproxy
You can attach a valid SSL certificate to the request.
- First Create a single PEM file including CA.
cat example.com.crt example.com.key > single.pem
cat single.pem
-----BEGIN CERTIFICATE-----
MIIEvAIBADANBgkqhkiG9w0BAQEFAASCBKYwggSiAgEAAoIBAQC5ZheHqmBnEJP+
U9r1gxYWKLzdqrMrcxtQN6M1hIH9n0peuJeIrybdcV7sMbStMXI=
-----END CERTIFICATE-----
-----BEGIN PRIVATE KEY-----
MIIEojCCA4qgAwIBAgIUegW2BimwuL4RzRZ2WYkHA6U5nkAwDQYJKoZIhvcNAQEL
3j4wz8/I5fdsk090j4s5KA==
-----END PRIVATE KEY-----
- Convert it to BASE64 in a single line:
cat single.pem | base64 -w0
- Use this string to define the label
easyhaproxy.[definition].sslcert
If enabled, map the volume : /etc/haproxy/errors-custom/
to your container and put a file named ERROR_NUMBER.http
where ERROR_NUMBER is the http error code (e.g. 503.http)
docker build -t byjg/easy-haproxy .