Skip to content

ngc7331/docker-derper

Repository files navigation

Docker-derper

An unofficial s6-overlay based Docker image for custom Tailscale Derp server with built-in acme.sh

Usage

docker run -d --name=derper \
    -p 80:80/tcp \ # Optional, see Note 2
    -p 443:443/tcp \
    -p 3478:3478/udp \ # Optional, see Note 2
    -e DERP_HOSTNAME=derp.example.com \
    -e DERP_CERTMODE=letsencrypt \
    -v /path/to/data:/data:rw \
    -v /path/to/cert:/data/cert:rw \ # Optional, see Note 1
    -v /var/run/tailscale/tailscaled.sock:/var/run/tailscale/tailscaled.sock:rw \ # Optional, see Note 3
    ngc7331/derper:latest

Notes:

  1. A standalone /data/cert mapping is not necessary, but recommended if you want to use the DERP_CERTMODE=manual, by which you can provide your own certificate and key files.
  2. If you want to disable HTTP or STUN server, you can remove the corresponding port mapping. Also don't forget to set DERP_ENABLE_HTTP or DERP_ENABLE_STUN to false.
  3. If DERP_VERIFY_CLIENTS is set to true, derp needs to communicate with the tailscale client via tailscaled.sock to verify the clients. So you must have a tailscale daemon running on host and mount tailscaled.sock inside the container.

Derp Environment Variables

Variable Default Description
DERP_HOSTNAME The hostname of the Derp server (MUST BE SET)
DERP_CERTMODE acme.sh The mode of certificate management, should be letsencrypt, acme.sh or manual
DERP_PORT_HTTP 80 The port of HTTP server
DERP_PORT_HTTPS 443 The port of HTTPS server
DERP_PORT_STUN 3478 The port of STUN server
DERP_ENABLE_HTTP true Enable HTTP server
DERP_ENABLE_STUN true Enable STUN server
DERP_VERIFY_CLIENTS false Verify client certificate, see official docs

Acme.sh Environment Variables

If DERP_CERTMODE is set to acme.sh, the following environment variables are also required:

Variable Default Description
ACME_SH_EMAIL The email address for ZeroSSL registration
ACME_SH_DNSAPI The API used to pass DNS challenge, see official docs
ACME_SH_CA letsencrypt The ACME server, see official docs
ACME_SH_FORCE_RENEW false Force renew certificate
Other variables required by API See official docs

Example using Cloudflare:

docker run ... \
    -e DERP_CERTMODE=acme.sh \
    -e ACME_SH_EMAIL=email@example.com \
    -e ACME_SH_DNSAPI=dns_cf \
    -e CF_Email=email@example.com \
    -e CF_Zone_ID=0123456 \
    -e CF_Token=abcdefg \
    ...

Note that DERP_CERTMODE=acme.sh can be used only with a DNS API to handle DNS chanllenge automatically.

Use DERP_CERTMODE=letsencrypt if you want to use HTTP challenge (as the standalone mode of acme.sh does).

Unsafe version

In some cases, tls handshake errors/certificate validation failures may be encountered with the default version (e.g. Using a unregistered domain in China mainland, or using a self-signed certificate).

You may want to just skip the certificate validation to make it work. In this case, you can use the unsafe version of the image by appending -unsafe to the tag (e.g. docker pull ngc7331/derper:latest-unsafe).

NOTE: As the name suggests, this may break the security of the connection and leave it vulnerable to man-in-the-middle attacks. Please use with caution.

Also, you may set InsecureForTests to true in your tailscale's ACL rules:

...
"derpMap": {
  "Regions": {
    "<region-id>": {
      ...
      "Nodes": [
        {
          ...
          "InsecureForTests": true,
        },
      ],
    },
  },
},

About

An unofficial Tailscale Derp server with built-in acme.sh

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages