|
@@ -34,23 +34,23 @@ controlled entirely from the `docker run` parameters.
|
|
|
|
|
|
Start actual Redis server on one Docker host
|
|
Start actual Redis server on one Docker host
|
|
|
|
|
|
- big-server $ docker run -d -name redis crosbymichael/redis
|
|
|
|
|
|
+ big-server $ docker run -d --name redis crosbymichael/redis
|
|
|
|
|
|
Then add an ambassador linked to the Redis server, mapping a port to the
|
|
Then add an ambassador linked to the Redis server, mapping a port to the
|
|
outside world
|
|
outside world
|
|
|
|
|
|
- big-server $ docker run -d -link redis:redis -name redis_ambassador -p 6379:6379 svendowideit/ambassador
|
|
|
|
|
|
+ big-server $ docker run -d --link redis:redis --name redis_ambassador -p 6379:6379 svendowideit/ambassador
|
|
|
|
|
|
On the other host, you can set up another ambassador setting environment
|
|
On the other host, you can set up another ambassador setting environment
|
|
variables for each remote port we want to proxy to the `big-server`
|
|
variables for each remote port we want to proxy to the `big-server`
|
|
|
|
|
|
- client-server $ docker run -d -name redis_ambassador -expose 6379 -e REDIS_PORT_6379_TCP=tcp://192.168.1.52:6379 svendowideit/ambassador
|
|
|
|
|
|
+ client-server $ docker run -d --name redis_ambassador --expose 6379 -e REDIS_PORT_6379_TCP=tcp://192.168.1.52:6379 svendowideit/ambassador
|
|
|
|
|
|
Then on the `client-server` host, you can use a Redis client container
|
|
Then on the `client-server` host, you can use a Redis client container
|
|
to talk to the remote Redis server, just by linking to the local Redis
|
|
to talk to the remote Redis server, just by linking to the local Redis
|
|
ambassador.
|
|
ambassador.
|
|
|
|
|
|
- client-server $ docker run -i -t -rm -link redis_ambassador:redis relateiq/redis-cli
|
|
|
|
|
|
+ client-server $ docker run -i -t --rm --link redis_ambassador:redis relateiq/redis-cli
|
|
redis 172.17.0.160:6379> ping
|
|
redis 172.17.0.160:6379> ping
|
|
PONG
|
|
PONG
|
|
|
|
|
|
@@ -62,19 +62,19 @@ does automatically (with a tiny amount of `sed`)
|
|
On the Docker host (192.168.1.52) that Redis will run on:
|
|
On the Docker host (192.168.1.52) that Redis will run on:
|
|
|
|
|
|
# start actual redis server
|
|
# start actual redis server
|
|
- $ docker run -d -name redis crosbymichael/redis
|
|
|
|
|
|
+ $ docker run -d --name redis crosbymichael/redis
|
|
|
|
|
|
# get a redis-cli container for connection testing
|
|
# get a redis-cli container for connection testing
|
|
$ docker pull relateiq/redis-cli
|
|
$ docker pull relateiq/redis-cli
|
|
|
|
|
|
# test the redis server by talking to it directly
|
|
# test the redis server by talking to it directly
|
|
- $ docker run -t -i -rm -link redis:redis relateiq/redis-cli
|
|
|
|
|
|
+ $ docker run -t -i --rm --link redis:redis relateiq/redis-cli
|
|
redis 172.17.0.136:6379> ping
|
|
redis 172.17.0.136:6379> ping
|
|
PONG
|
|
PONG
|
|
^D
|
|
^D
|
|
|
|
|
|
# add redis ambassador
|
|
# add redis ambassador
|
|
- $ docker run -t -i -link redis:redis -name redis_ambassador -p 6379:6379 busybox sh
|
|
|
|
|
|
+ $ docker run -t -i --link redis:redis --name redis_ambassador -p 6379:6379 busybox sh
|
|
|
|
|
|
In the `redis_ambassador` container, you can see the linked Redis
|
|
In the `redis_ambassador` container, you can see the linked Redis
|
|
containers `env`:
|
|
containers `env`:
|
|
@@ -98,7 +98,7 @@ to the world (via the `-p 6379:6379` port mapping):
|
|
|
|
|
|
$ docker rm redis_ambassador
|
|
$ docker rm redis_ambassador
|
|
$ sudo ./contrib/mkimage-unittest.sh
|
|
$ sudo ./contrib/mkimage-unittest.sh
|
|
- $ docker run -t -i -link redis:redis -name redis_ambassador -p 6379:6379 docker-ut sh
|
|
|
|
|
|
+ $ docker run -t -i --link redis:redis --name redis_ambassador -p 6379:6379 docker-ut sh
|
|
|
|
|
|
$ socat TCP4-LISTEN:6379,fork,reuseaddr TCP4:172.17.0.136:6379
|
|
$ socat TCP4-LISTEN:6379,fork,reuseaddr TCP4:172.17.0.136:6379
|
|
|
|
|
|
@@ -107,14 +107,14 @@ Now ping the Redis server via the ambassador:
|
|
Now go to a different server:
|
|
Now go to a different server:
|
|
|
|
|
|
$ sudo ./contrib/mkimage-unittest.sh
|
|
$ sudo ./contrib/mkimage-unittest.sh
|
|
- $ docker run -t -i -expose 6379 -name redis_ambassador docker-ut sh
|
|
|
|
|
|
+ $ docker run -t -i --expose 6379 --name redis_ambassador docker-ut sh
|
|
|
|
|
|
$ socat TCP4-LISTEN:6379,fork,reuseaddr TCP4:192.168.1.52:6379
|
|
$ socat TCP4-LISTEN:6379,fork,reuseaddr TCP4:192.168.1.52:6379
|
|
|
|
|
|
And get the `redis-cli` image so we can talk over the ambassador bridge.
|
|
And get the `redis-cli` image so we can talk over the ambassador bridge.
|
|
|
|
|
|
$ docker pull relateiq/redis-cli
|
|
$ docker pull relateiq/redis-cli
|
|
- $ docker run -i -t -rm -link redis_ambassador:redis relateiq/redis-cli
|
|
|
|
|
|
+ $ docker run -i -t --rm --link redis_ambassador:redis relateiq/redis-cli
|
|
redis 172.17.0.160:6379> ping
|
|
redis 172.17.0.160:6379> ping
|
|
PONG
|
|
PONG
|
|
|
|
|
|
@@ -139,9 +139,9 @@ case `192.168.1.52:6379`.
|
|
# docker build -t SvenDowideit/ambassador .
|
|
# docker build -t SvenDowideit/ambassador .
|
|
# docker tag SvenDowideit/ambassador ambassador
|
|
# docker tag SvenDowideit/ambassador ambassador
|
|
# then to run it (on the host that has the real backend on it)
|
|
# then to run it (on the host that has the real backend on it)
|
|
- # docker run -t -i -link redis:redis -name redis_ambassador -p 6379:6379 ambassador
|
|
|
|
|
|
+ # docker run -t -i --link redis:redis --name redis_ambassador -p 6379:6379 ambassador
|
|
# on the remote host, you can set up another ambassador
|
|
# on the remote host, you can set up another ambassador
|
|
- # docker run -t -i -name redis_ambassador -expose 6379 sh
|
|
|
|
|
|
+ # docker run -t -i --name redis_ambassador --expose 6379 sh
|
|
|
|
|
|
FROM docker-ut
|
|
FROM docker-ut
|
|
MAINTAINER SvenDowideit@home.org.au
|
|
MAINTAINER SvenDowideit@home.org.au
|