The stunnerd
daemon implements the STUNner gateway dataplane.
The daemon supports two basic modes. For quick tests stunnerd
can be configured as a TURN server
by specifying a TURN network URI on the command line. For more complex scenarios, and especially
for use in a Kubernetes cluster, stunnerd
can take configuration from a config origin, which can
either be a config file or from a remote server reached over WebSocket. In addition, stunnerd
implements a watch-mode, so that it can actively monitor the config origin for updates and
automatically reconcile the TURN server to any new configuration. This mode is intended for use
with the STUNner Kubernetes gateway operator:
the operator watches the Kubernetes Gateway API resources,
renders the active control plane configuration per each stunnerd
pod and dynamically updates the
dataplane using STUNner's config discovery service.
- Full Kubernetes integration for quick installation into any hosted or on-prem Kubernetes cluster.
- Dynamic reconciliation by enabling config-file watch mode.
- RFC 5389: Session Traversal Utilities for NAT (STUN)
- RFC 8656: Traversal Using Relays around NAT (TURN)
- RFC 6062: Traversal Using Relays around NAT (TURN) Extensions for TCP Allocations
- TURN transport over UDP, TCP, TLS/TCP and DTLS/UDP.
- TURN/UDP listener CPU scaling.
- Two authentication modes via the long-term STUN/TURN credential mechanism:
static
using a static username/password pair, andephemeral
with dynamically generated time-scoped credentials. - Peer port range filtering.
As easy as with any Go program.
cd stunner
go build -o stunnerd cmd/stunnerd/main.go
The below command will open a stunnerd
UDP listener at 127.0.0.1:5000
, set static
authentication using the username/password pair user1/passwrd1
, and raise the debug level to the maximum.
./stunnerd --log=all:TRACE turn://user1:[email protected]:5000
Alternatively, run stunnerd
in verbose mode with the config file taken from cmd/stunnerd/stunnerd.conf
. Adding the flag -w
will enable watch mode.
./stunnerd -v -w -c cmd/stunnerd/stunnerd.conf
Type ./stunnerd -h
to get a short description of the supported command line arguments.
In practice, you'll rarely need to run stunnerd
directly: just fire up the prebuilt container image in Kubernetes and you should be good to go. Or better yet, install the STUNner Kubernetes gateway operator that will readily manage the stunnerd
pods for each Gateway you create.
Using the below configuration, stunnerd
will open 4 STUNner listeners: two for accepting unencrypted connections at UDP/3478 and TCP/3478, and two for encrypted connections at TLS/TCP/3479 and DTLS/UDP/3479. The daemon will use ephemeral
authentication, with the shared secret taken from the environment variable $STUNNER_SHARED_SECRET
during initialization. The relay address will be taken from the $STUNNER_ADDR
environment variable.
version: v1alpha1
admin:
name: my-stunnerd
logLevel: all:DEBUG
realm: "my-realm.example.com"
static:
auth:
type: ephemeral
credentials:
secret: $STUNNER_SHARED_SECRET
listeners:
- name: stunnerd-udp
address: "$STUNNER_ADDR"
protocol: turn-udp
port: 3478
- name: stunnerd-tcp
address: "$STUNNER_ADDR"
protocol: turn-tcp
port: 3478
- name: stunnerd-tls
address: "$STUNNER_ADDR"
protocol: turn-tls
port: 3479
cert: "my-cert.cert"
key: "my-key.key"
- name: stunnerd-dtls
address: "$STUNNER_ADDR"
protocol: turn-dtls
port: 3479
cert: "my-cert.cert"
key: "my-key.key"
STUNner can run multiple parallel readloops for TURN/UDP listeners, which allows it to scale to practically any number of CPUs and brings massive performance improvements for UDP workloads. This can be achieved by creating a configurable number of UDP readloop threads over the same TURN listener. The kernel will load-balance allocations across the readloops per the IP 5-tuple and so the same allocation will always stay at the same CPU, which is important for correct TURN operations.
The feature is exposed via the command line flag --udp-thread-num=<THREAD_NUMBER>
. The below starts stunnerd
watching the config file in /etc/stunnerd/stunnerd.conf
using 32 parallel UDP readloops (the default is 16).
./stunnerd -w -c /etc/stunnerd/stunnerd.conf --udp-thread-num=32
Copyright 2021-2023 by its authors. Some rights reserved. See AUTHORS.
MIT License - see LICENSE for full text.