Ngicon is a dynamic reverse-proxy, using NGINX, that provides routes to services registered to a Consul service discovery system. It gives you the ability to register ephemeral ports, eliminating the need to explicitly register host ports to services. In doing so, one can register multiple instances of the same service on the same host.
Ngicon utilizes consul-template to synchronize with Consul's service directory. Ngicon offers the ability to update a cluster of ngicon's NGINX configs just by updating a consul key/value pair.
Each service responds to a KV namespace matching the service name. For example, to modify a service's NGINX service block, create a service_block_config
key for the service's namespace and add configuration that you need as that key's value.
Ngicon also supports location_block_config
which modifies configuration at the root /
location for a service.
Ngicon supports TCP proxying. To enable TCP proxying, register the tag tcp
to the Consul service requiring TCP proxying. Then add a key tcp_listen
to the namespace of the respective service with the value of the port you would like the service to be accessed through.
docker run -d \
--net host \
--name ngicon \
djenriquez/ngicon
- CONSUL_ADDRESS: The address of Consul. It is recommended to point Ngicon at the local Consul service. Defaults to
localhost
- CONSUL_PORT: The port to access Consul. Defaults to
8500
- CT_ARGS: Additional arguments to pass into consul-template CLI, ex:
-dedup
. - APP: Optional identifier used for the StatsD health check as a dimension.
Templates to be parsed should be mounted to /etc/consul-templates/
and end in .tmpl.go
. Ngicon will take the file, strip off the .tmpl.go
and place the new file in /etc/nginx/conf.d/
.
NGICON runs a check against the nginx -t
command against the configuration. This test will run every minute through cron AND everytime consul-template attempts to process a change to the config.
Results of the test are sent to localhost:8125/udp as the metric nginx.conf.ok
, with an optional dimension of app
, which reads in the environment variable $APP
. This assumes an optional StatsD listener exists. The test returns:
Result | Status |
---|---|
0 | Good |
1 | Unknown |
2 | Bad |