| .. | ||
| docker-compose-slim.yml | ||
| docker-compose.yml | ||
| Dockerfile | ||
| Dockerfile-slim | ||
| entrypoint.sh | ||
| README.md | ||
| run.sh | ||
Docker Images of rpxy
The rpxy docker images are hosted both on Docker Hub and GitHub Container Registry.
Usage
There are several docker-specific environment variables.
- HOST_USER(default:- user): User name executing- rpxyinside the container.
- HOST_UID(default:- 900):- UIDof- HOST_USER.
- HOST_GID(default:- 900):- GIDof- HOST_USER
- LOG_LEVEL=debug|info|warn|error: Log level
- LOG_TO_FILE=true|false: Enable logging to the log file- /rpxy/log/rpxy.logusing- logrotate. You should mount- /rpxy/logvia docker volume option if enabled. The log dir and file will be owned by the- HOST_USERwith- HOST_UID:HOST_GIDon the host machine. Hence,- HOST_USER,- HOST_UIDand- HOST_GIDshould be the same as ones of the user who executes the- rpxydocker container on the host.
- WATCH=true|false(default:- false): Activate continuous watching of the config file if true.
Then, all you need is to mount your config.toml as /etc/rpxy.toml and certificates/private keys as you like through the docker volume option. If WATCH=true, You need to mount a directory, e.g., ./rpxy-config/, including rpxy.toml on /rpxy/config instead of a file to correctly track file changes. This is a docker limitation. Even if WATCH=false, you can mount the dir onto /rpxy/config rather than /etc/rpxy.toml. A file mounted on /etc/rpxy is prioritized over a dir mounted on /rpxy/config.
See docker-compose.yml for the detailed configuration. Note that the file path of keys and certificates must be ones in your docker container.
Custom CAs for upstream TLS connections
To add a custom certificate, you must use a non-webpki image. Then mount /usr/local/share/ca-certificates in the container with your desired CAs each in a file like myca.crt. The certificates are accepted in PEM format but file extension must be crt.
e.g. -v rpxy/ca-certificates:/usr/local/share/ca-certificates
Differences among image tags of Docker Hub and GitHub Container Registry
Differences among tags are summarized as follows.
Latest and versioned builds
Latest builds are shipped from the main branch when the new version is released. For example, when the version x.y.z is released, the following images are provided.
- latest,- x.y.z: Built with default features, running on Ubuntu.
- latest-slim,- slim,- x.y.z-slim: Built by- muslwith default features, running on Alpine.
- latest-s2n,- s2n,- x.y.z-s2n: Built with the- http3-s2nfeature, running on Ubuntu.
Additionally, images built with webpki-roots are provided in a similar manner to the above (e.g., latest-s2n-webpki-roots and s2n-webpki-roots tagged for the same image).
Nightly builds
Nightly builds are shipped from the develop branch for every push.
- nightly: Built with default features, running on Ubuntu.
- nightly-slim: Built by- muslwith default features, running on Alpine.
- nightly-s2n: Built with the- http3-s2nfeature, running on Ubuntu.
Additionally, images built with webpki-roots are provided in a similar manner to the above (e.g., nightly-s2n-webpki-roots).
Caveats
Due to some compile errors of s2n-quic subpackages with musl, nightly-s2n-slim or latest-s2n-slim are not yet provided.
See ./docker/README.md for the differences on image tags.
