WireGuard Easy is the easiest way to run WireGuard VPN + Web-based Admin UI.
Another more powerful alternative for a self-hosted WireGuard VPN server is Firezone. WireGuard Easy is easier, lighter and more compatible with various ARM devices.
This service requires the following other services:
- a Traefik reverse-proxy server
- a modern Linux kernel which supports WireGuard
To enable this service, add the following configuration to your vars.yml
file and re-run the installation process:
########################################################################
# #
# wg-easy #
# #
########################################################################
wg_easy_enabled: true
wg_easy_hostname: mash.example.com
wg_easy_path_prefix: /wg-easy
wg_easy_environment_variables_additional_variable_wg_host: mash.example.com
# Put a strong password below, generated with `pwgen -s 64 1` or in another way
wg_easy_environment_variables_additional_variable_password: ''
# The default WireGuard port is 51820.
# Uncomment and change the lines below to use another one.
#
# The port that wg-easy advertises for WireGuard connectivity in profile files.
# wg_easy_environment_variables_additional_variable_wg_port: 51820
#
# The port that is actually published from the container.
# wg_easy_container_wireguard_bind_port: 51820
# The default DNS is 1.1.1.1.
# Uncomment and change the line below to use another one.
# wg_easy_environment_variables_additional_variable_wg_default_dns: 1.1.1.1
########################################################################
# #
# /wg-easy #
# #
########################################################################
In the example configuration above, we configure the service to be hosted at https://mash.example.com/wg-easy
.
You can remove the wg_easy_path_prefix
variable definition, to make it default to /
, so that the service is served at https://mash.example.com/
.
In addition to ports 80
and 443
exposed by the Traefik reverse-proxy, the following ports will be exposed by the WireGuard containers on all network interfaces:
51820
over UDP, controlled bywg_easy_environment_variables_additional_variable_wg_port
andwg_easy_container_wireguard_bind_port
- used for Wireguard connections
Docker automatically opens these ports in the server's firewall, so you likely don't need to do anything. If you use another firewall in front of the server, you may need to adjust it.
For additional configuration options, see the upstream documentation's Options section.
You can inject additional environment variables with this additional configuration:
wg_easy_environment_variables_additional_variables: |
WG_DEFAULT_ADDRESS: 10.6.0.x
WG_MTU: 1420
After installation, you can go to the WireGuard Easy URL, as defined in wg_easy_hostname
and wg_easy_path_prefix
.
You can authenticate with the password set in wg_easy_environment_variables_additional_variable_password
.
You can then create various Clients and import the configuration for them onto your devices - either by downloading a file or by scanning a QR code.
- AdGuard Home - A network-wide DNS software for blocking ads & tracking