GitXplorerGitXplorer
R

openvpn3_linux_docker

public
7 stars
7 forks
0 issues

Commits

List of commits on branch main.
Unverified
8becfca802d631ec9db933ed288eb36cb8210a81

Fix newline, return to old forking style

RRaphMad committed 3 years ago
Unverified
6cde34e03e31568f3e0df5bfc87ba8ef98ec8438

Fork into the background

RRaphMad committed 3 years ago
Unverified
d84771832be97235db4ea01f9b8b35d3cc11f10d

Remove tini

RRaphMad committed 3 years ago
Unverified
324895d1fbff84774dd830b38a037b874e550f4d

Simplify initial setup

RRaphMad committed 3 years ago
Unverified
4aa96daab52f4ad6d6720b294a6bd6d08a434d14

Use default forking behaviour

RRaphMad committed 3 years ago
Unverified
3df219f43a4df3c02c425ae265e2779ec5ddc2c9

Handle signal correctly

RRaphMad committed 3 years ago

README

The README file for this repository.

This is a containerized version of the VPN client openvpn3-linux.

It can be used to provide VPN access to other containers (see example compose file below). In addition, a "killswitch"-type set of firewall rules prevent any outgoing traffic from not traversing the VPN tunnel.

Configuration can be provided via environment variables, but the defaults should be sensible for most common VPN configuration files.

The only required part is the ovpn file itself, which is expected to be mounted under /config.ovpn as well as the environment variable VPN_HOST, which will be used to generate a firewall exclusion for the initial DNS lookup of your VPN server.

Environment variables

Name Required Description
VPN_HOST Conditionally DNS-Hostname of the VPN endpoint (server) to connect to. Required if your configuration specifies the host by name and firewall rules are used.
VPN_EXTERNAL_IP Conditionally If your VPN provides a static external IP, you can set this variable to regularly verify your external IP in the healthcheck.
ENABLE_DCO No (Default false) Set to true to enable DCO if your kernel supports it.
DISABLE_FIREWALL No (Default false) Set to true to disable the creation of firewall rules.
VPN_PROTO No (Default udp) Modify if your VPN configuration uses tcp instead of udp.
VPN_PORT No (Default 1194) Modify if your VPN configuration uses a port different from the default 1194.

Expected bind mounts

Name Description
/config.ovpn OpenVPN configuration file.

Minimal docker-compose.yml

version: '3.9'

services:
  openvpn:
    image: raphmad/openvpn3_linux
    container_name: openvpn
    restart: unless-stopped
    privileged: true
    environment:
      VPN_HOST: <some.host>
    volumes:
      - <host_path_to_config.ovpn>:/config.ovpn:ro

  some_service:
    image: alpine
    container_name: some_service
    restart: unless-stopped
    network_mode: service:openvpn
    entrypoint: ["sleep", "infinity"]
    depends_on:
      - openvpn

Extended / annotated docker-compose.yml

version: '3.9'

services:
  openvpn:
    image: raphmad/openvpn3_linux
    container_name: openvpn
    restart: unless-stopped
    # It is a good practice to make containers read-only whenever possible and mount a tmpfs only for locations that need writing during runtime.
    read_only: true
    tmpfs:
      - /run/
      - /var/run/dbus/
    # For now this seems required by the design of OpenVPN, but `CAP_NET_ADMIN` should be enough to run unprivileged in the future.
    privileged: true
    # Set this if your VPN provides IPv6 access (and you want to use it).
    sysctls:
      - net.ipv6.conf.all.disable_ipv6=0
    # Your locally configured nameservers may not be accessible through the VPN tunnel.
    # Some VPN providers will "push" their DNS servers to you, but as a fallback you can always just configure one thats guaranteed to work from the VPN endpoint.
    dns:
      - 1.1.1.1
    environment:
      VPN_HOST: <some.host>
      # Setting the _expected_ external IP will verify it in the healthcheck of the VPN container.
      VPN_EXTERNAL_IP: <1.2.3.4>
      # This is an experimental feature, but feel free to use it if your kernel has support for it.
      ENABLE_DCO: 'true'
    volumes:
      - <host_path_to_config.ovpn>:/config.ovpn:ro

  some_service:
    image: alpine
    container_name: some_service
    restart: unless-stopped
    network_mode: service:openvpn
    entrypoint: ["sleep", "infinity"]
    depends_on:
      - openvpn