Wireguard sous Alpine Linux
Après avoir utilisé OpenVPN pendant plusieurs années, j'ai décidé de le remplacer pour un Wireguard qui a l'avantage d'être très simplifié et beaucoup plus rapide. J'en profite donc pour vous partager l'installation et sa configuration de base sous Alpine Linux.
Introduction
J'utilise donc un Alpine Linux en tant que micro serveur à la maison, et hébergé par l'intermédiaire de ma Freebox Delta (upgradé avec 8Go de ram). L'OS est vraiment très minime, consomme vraiment pas grand chose et donc ça tourne vraiment bien ! Un exemple de sa consommation actuelle avec quelques services :
Bien évidemment il vous faudra les accès root sur le serveur.
Installation
Le gestionnaire de package sous Alpine Linux c'est apk
, donc pour installer wireguard ce sera avec cette méthode (doc officielle) :
apk add -U wireguard-tools
Ensuite on édite le fichier /etc/network/interfaces
pour rajouter la nouvelle interface wg0 qui sera utilisée :
auto wg0
iface wg0 inet static
address 192.168.167.1
netmask 255.255.255.0
pre-up ip link add dev wg0 type wireguard
pre-up wg setconf wg0 /etc/wireguard/wg0.conf
post-up ip route add 192.168.167.0/24 dev wg0
post-down ip link delete dev wg0
On autorise le forward :
echo "net.ipv4.ip_forward = 1" >> /etc/sysctl.conf
echo "net.ipv6.conf.all.forwarding = 1" >> /etc/sysctl.conf
echo "net.ipv4.conf.all.proxy_arp = 1" >> /etc/sysctl.conf
On rajoute wireguard en module puis on redémarre le réseau :
echo wireguard >> /etc/modules
/etc/init.d/networking restart
A partir d'ici on a une interface wg0 qui est visible (status down mais c'est normal), on passe à la suite avec la configuration.
Configuration
La configuration est découpée en 2 parties, l'une étant le serveur et l'autre étant le(s) client(s).
Serveur
On génère maintenant une clé privée (privatekey) et publique (publickey) qu'utilisera notre serveur :
mkdir -p /etc/wireguard/server
cd /etc/wireguard/server
wg genkey | tee privatekey | wg pubkey > publickey
chmod 600 privatekey publickey
Puis on prépare le fichier de configuration /etc/wireguard/wg0.conf
lié à l'interface wg0 :
[Interface]
Address = 192.168.167.1
PrivateKey = <<server/privatekey>>
ListenPort = 33444
PostUp = iptables -A FORWARD -i wg0 -j ACCEPT; iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE
PostDown = iptables -D FORWARD -i wg0 -j ACCEPT; iptables -t nat -D POSTROUTING -o eth0 -j MASQUERADE
Et ensuite on active l'interface wg0 :
wg-quick up wg0
Client(s)
Comme pour la partie serveur, on génère à chaque fois une clé privée (privatekey) et publique (publickey) pour le(s) client(s), on mettra ça dans un dossier plutôt dédié au(x) client(s) :
mkdir -p /etc/wireguard/client/xorhak-macbook
cd /etc/wireguard/client/xorhak-macbook
wg genkey | tee privatekey | wg pubkey > publickey
Puis on créé un fichier de configuration /etc/wireguard/client/xorhak-macbook/config
avec une configuration de ce type :
[Interface]
PrivateKey = <<client/xorhak-macbook/privatekey>>
Address = 192.168.167.2/32
DNS = 1.1.1.1, 1.0.0.1, 8.8.8.8, 8.8.4.4
[Peer]
PublicKey = <<server/publickey>>
AllowedIPs = 0.0.0.0/0, ::1/128
Endpoint = <<ip_publique>>:33444
Maintenant que le premier client est créé, il faut mettre à jour la configuration du serveur, c'est une nouvelle rubrique Peer qu'on rajoutera :
[Peer]
PublicKey = <<client/xorhak-macbook/publickey>>
AllowedIPs = 192.168.167.2/32
Je redémarre toujours l'interface wg0 pour bien prendre en compte les modifications :
wg-quick down wg0
wg-quick up wg0
Pour afficher le status global (mais générique) :
wg show
C'est terminé ! Il ne reste plus qu'à importer le fichier de configuration sur le client. Si jamais une option d'importation par qrcode est possible, la solution est très simpe :
apk -U add libqrencode
qrencode -t ansiutf8 < /etc/wireguard/client/xorhak-macbook/config
Pour un accès depuis l'extérieur, on oublira pas de rediriger le port 33444/udp vers le serveur Wireguard, sinon évidemment ça fonctionnera pas.
N'hésitez pas dans les commentaires si vous avez des sugestions ou astuces intéressantes :)