Docker on remote host && docker-compose
In my HomeLab I have two RancherOS hosts, and now I added 7 Raspberry Pi's and I'm planning on adding more hosts in the future. Initially I was just connecting via ssh
and executing commands on the hosts. For Rancher running docker-compose is a little extra work, as it doesn't have it available. The quickest solution I have vor it is:
docker run --rm -it -v ${PWD}:/rx -v /var/run/docker.sock:/var/run/docker.sock -w /rx docker/compose up -d
This command:
-
docker run
gets docker-compose container from docker hub --rm
removes the container after closing it, or after the command finishes-it
launches interactive terminal-v ${PWD}:/rx
mounts current directory as /rx on the container-v /var/run/docker.sock:/var/run/docker.sock
mounts local docker socket, so that the compose container can control your docker instance-w
sets the working directorydocker/compose
is the name of the image from docker hubup -d
is the command we send to the container
All this is equivalent to running docker-compose up -d
but without having compose installed
This approach is not optimal for having multiple remote hosts, so I was researching how could I use my local docker engine and control the remote hosts.
The quickest way is to run export DOCKER_HOST=ssh://username@<machine.ip>
, that makes docker use the remote HOST. There is a newer way using docker context
. It allows you to set and use multiple configs and easily switch between them.
To list the existing contexts run docker context ls
To create a new context run docker context create <context_name> --docker "host=ssh://<username>@<host or ip>"
To use the newly created context you can either run docker --context <context_name> command
for each command or run docker context use <context_name>
. Important note is that if you set DOCKER_HOST
variable it will override docker context, so make sure to unset it.
docker-compose
What about docker-compose? The new-new version supports docker contexts, but it's still in RC as I write this post, so the only other way is to set DOCKER_HOST
, it will use it automatically.
paramiko.ssh_exception.ChannelException: ChannelException(1, 'Administratively prohibited')
or similar errors are caused by sshd MaxSessions default value of 10, where docker-compose tries to open 25 connections. Solution is to edit /etc/ssh/sshd_config
and changing MaxSessions
to something above 25.
Links: