Decrease Gentoo compilation times by leveraging spare resources, such as an Ubuntu or Windows box idling around. Docker is the only prerequisite.
- Flexible deployment
- Locally (in a private network)
- Remotely (over the internet)
- Out-of-the-box support for the following Gentoo architectures:
amd64
arm
arm64
ppc64
x86
- Server-side caching using ccache
- Cross-compilation support using crossdev
Note: Only the stable toolchain of these architectures is currently supported.
distcc can run over TCP or SSH connections. TCP connections are fast but relatively insecure, whereas SSH connections are secure but slower. In a trusted environment, such as a LAN, you should use TCP connections for efficiency; otherwise use SSH connections.
On the worker node(s), run the containerized distcc server (distccd):
docker run -d -p 3632:3632 --name gentoo-distcc-tcp --rm ksmanis/gentoo-distcc:tcp
distccd should now be accessible from all interfaces at port 3632
(0.0.0.0:3632
):
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
405bb6e87ce8 ksmanis/gentoo-distcc:tcp "tini -e 143 -- dock…" 2 seconds ago Up 2 seconds 0.0.0.0:3632->3632/tcp gentoo-distcc-tcp
Command-line arguments are passed on verbatim to distccd. For instance, you can turn on the built-in HTTP statistics server:
docker run -d -p 3632-3633:3632-3633 --name gentoo-distcc-tcp --rm ksmanis/gentoo-distcc:tcp --stats
The statistics server should now be accessible from all interfaces at port 3633
(0.0.0.0:3633
):
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
4e553e359782 ksmanis/gentoo-distcc:tcp "tini -e 143 -- dock…" 3 seconds ago Up 2 seconds 0.0.0.0:3632-3633->3632-3633/tcp gentoo-distcc-tcp
For a full list of options refer to distccd(1).
On the worker node(s), run the containerized SSH server (sshd):
docker run -d -p 30022:22 -e AUTHORIZED_KEYS="..." --name gentoo-distcc-ssh --rm ksmanis/gentoo-distcc:ssh
sshd should now be accessible from all interfaces at port 30022
(0.0.0.0:30022
):
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
5aa87c1eaf59 ksmanis/gentoo-distcc:ssh "docker-entrypoint.sh" 3 seconds ago Up 2 seconds 0.0.0.0:30022->22/tcp gentoo-distcc-ssh
Instead of including the public key verbatim in the above command, you may prefer to read it from a file on the Docker host:
docker run -d -p 30022:22 -e AUTHORIZED_KEYS="$(cat /path/to/key.pub)" --name gentoo-distcc-ssh --rm ksmanis/gentoo-distcc:ssh
Command-line arguments are passed on verbatim to sshd. For a full list of options refer to sshd(8).
The SSH server allows only public key authentication. More specifically, only
the distcc-ssh
user is accessible with the public key provided with the
required AUTHORIZED_KEYS
environment variable. The username is configurable
through the optional SSH_USERNAME
environment variable:
docker run -d -p 30022:22 -e SSH_USERNAME=bob -e AUTHORIZED_KEYS="..." --name gentoo-distcc-ssh --rm ksmanis/gentoo-distcc:ssh
If you share a worker instance between multiple clients, you might be interested
in enabling server-side caching with ccache
to avoid redundant recompilations.
To do so, pull the ccache
image variants, i.e., tcp-ccache
instead of tcp
,
and ssh-ccache
instead of ssh
:
# TCP
docker run -d -p 3632:3632 --name gentoo-distcc-tcp-ccache --rm ksmanis/gentoo-distcc:tcp-ccache
# SSH
docker run -d -p 30022:22 -e AUTHORIZED_KEYS="..." --name gentoo-distcc-ssh-ccache --rm ksmanis/gentoo-distcc:ssh-ccache
The directory /var/cache/ccache
automatically persists in an anonymous Docker
volume, but a named Docker volume or a bind mount may also be used for stronger
persistence guarantees.
Ccache statistics can be queried as follows:
# TCP
docker exec gentoo-distcc-tcp-ccache ccache -sv
# SSH
docker exec gentoo-distcc-ssh-ccache ccache -sv
All amd64
image variants support cross-compilation for the arm64
architecture (specifically the aarch64-unknown-linux-gnu
toolchain) and vice
versa: all arm64
image variants support cross-compilation for the amd64
architecture (specifically the x86_64-pc-linux-gnu
toolchain). In other words,
an amd64
desktop can be used to cross-compile for an arm64
Raspberry Pi and
vice versa.
Cross-compilation support is enabled out of the box without any user configuration. More architecture combinations can be added upon request.
A manual way to test the containers is to compile a sample C file:
#include <stdio.h>
int main() {
printf("Hello, distcc!\n");
return 0;
}
DISTCC_HOSTS="127.0.0.1:3632" DISTCC_VERBOSE=1 distcc gcc -c main.c -o /dev/null
DISTCC_HOSTS="@localhost-distcc" DISTCC_VERBOSE=1 distcc gcc -c main.c -o /dev/null
The localhost-distcc
host should be properly set up in your ~/.ssh/config
:
Host localhost-distcc
HostName 127.0.0.1
Port 30022
User distcc-ssh
IdentityFile ~/.ssh/distcc
StrictHostKeyChecking no
Note: StrictHostKeyChecking no
is required in the above configuration
because the host keys of the container are automatically regenerated upon
execution, if missing. If you wish to eliminate this potential security issue,
you should store the host keys in a volume and mount them upon execution so that
they are not regenerated.