WAI Consul Middleware
This library assists you in monitoring Consul k/v data & with
proxying data to Consul safely from the Internet. The first use
case is receiving Github ‘push’ notifications when a repository is
updated and doing a git pull on all webservers to update content.
The example app shows GitHub Webhooks working.
┌─────────┐ ┌─────────┐
│ Github │ │ │
│ Repo │─────▶│ AWS ELB │
│ Webhook │ │ │
└─────────┘ └─────────┘
│
┌────────────┬──────┘─ ─ ─
│ │
▼ ▼ ▼
┌─────────┐ ┌─────────┐ ┌─────────┐
│ │ │ │ │ │
┌──│ WAI App │ │ WAI App │ │ WAI App │
│ │ │ │ │ │ │
│ └─────────┘ └─────────┘ └─────────┘
│ ▲ ▲
│ │ │
│ ┌────────────┴────────────┘
│ │
│ │
│ ┌─────────┐ ┌─────────┐ ┌─────────┐
│ │ │ │ │ │ │
└─▶│ Consul │──│ Consul │──│ Consul │
│ │ │ │ │ │
└─────────┘ └─────────┘ └─────────┘
Install
cabal install wai-middleware-consul
Or if you want to play with the example github webhook web-app:
cabal install -fexample wai-middleware-consul
Example
You’ll need to launch a small Consul cluster to try the example app.
It’s easy to do with Docker. Please use the following steps:
Launch 4 containers of Docker w/ Consul running on each
docker run -d --name node1 -h node1 progrium/consul -server -bootstrap-expect 3
sleep 10
JOIN_IP="$(docker inspect -f '{{.NetworkSettings.IPAddress}}' node1)"
docker run -d --name node2 -h node2 progrium/consul -server -join $JOIN_IP
docker run -d --name node3 -h node3 progrium/consul -server -join $JOIN_IP
docker run -d -p 8400:8400 -p 8500:8500 -p 8600:53/udp --name node4 -h node4 progrium/consul -join $JOIN_IP
sleep 10
-
Try out all the interfaces of Consul
-
Browse the Web UI Interface
-
Query Consul at the command line
consul members
-
Query the HTTP Interface
curl 0.0.0.0:8500/v1/catalog/nodes
-
Query the DNS Interface
dig @0.0.0.0 -p 8600 node1.node.consul
Setting up a Github Webhook
First we start `ngrok` to proxy HTTP requests from the Internet to
our local machine (most likely behind a firewall). Then we’ll start
the example web application to receive webhooks from Github.
Run the example application (in the root Github directory for
wai-middleware-consul). We need to be in this directory so our
example app can find/read cabal & Github version status.
./.cabal-sandbox/bin/wai-middleware-consul-example
Try navigating to the example app page. http://0.0.0.0:8080
Run ngrok to expose the example application to the Internet:
ngrok 8080 ;# take note of this public web address for Github
Set up the webhook for the repo on Github. Point it to the ngrok web
address and add the path /github onto that URL ( eg,
https://be2f75d.ngrok.com/github ). This is the specific route in
the example application for Github->Consul data updates.
Now that we have the application running and a proxy to the public
Internet established, we can receive webhook events.
Try pushing to the repository. You should see notifications that an
event was received in the web application STDOUT log. The event
should be pushed into Consul also. The web application will be
listening to events from Consul & this will fire also. You should
see it try to `git pull` the repository & you should see the changes
if you refresh the home page of the example app.
Cleanup (kill & remove Consul containers)
for n in $(seq 1 4); do
docker kill node$n
docker rm node$n
done