Simple TCP Proxy for Redis in a Docker Container using HAproxy
Sometimes you may need to forward a TCP connection and don't want to setup IPTables or a complicated application proxy. This container was originally created to route Redis requests to an AWS Elasticache backend from a network that did not have access to the VPC elasticache was configured in.
AWS documentation recommends setting up a NAT instance with iptable rules. This container makes it possible to setup a simple HAproxy configuration that proxies requests instead.
When running the container two Environment Variables are required
BACKEND_HOST
- IP or hostname to proxy connections to
BACKEND_PORT
- The port number to proxy connections to
STATS_PORT
- The port number for haproxy's stats endpoint
docker build -t docker-redis-proxy .
The following example forward TCP requests on port 6379
to an Elasticache instance on my-elasticache.domain.com:6379
docker run -it -p 6379:6379 -p 9090:9090 --rm -e "BACKEND_HOST=my-elasticache.domain.com" -e "BACKEND_PORT=6379" -e "STATS_PORT=9090" docker-redis-proxy