Upgrade system and install kernel headers prior to wireguard installation. Without system upgrade, wireguard was unable to start with below error: ip link add dev wg0 type wireguard Error: Unknown device type. modprobe wireguard modprobe: FATAL: Module wireguard not found in directory Make log: DKMS make.log for wireguard-1.0.20200611 for kernel 4.15.0-101-generic (x86_64) Thu Aug 27 14:55:47 CST 2020 make: Entering directory '/usr/src/linux-headers-4.15.0-101-generic' CC [M] /var/lib/dkms/wireguard/1.0.20200611/build/main.o CC [M] /var/lib/dkms/wireguard/1.0.20200611/build/noise.o CC [M] /var/lib/dkms/wireguard/1.0.20200611/build/device.o CC [M] /var/lib/dkms/wireguard/1.0.20200611/build/peer.o CC [M] /var/lib/dkms/wireguard/1.0.20200611/build/timers.o CC [M] /var/lib/dkms/wireguard/1.0.20200611/build/queueing.o CC [M] /var/lib/dkms/wireguard/1.0.20200611/build/send.o CC [M] /var/lib/dkms/wireguard/1.0.20200611/build/receive.o CC [M] /var/lib/dkms/wireguard/1.0.20200611/build/socket.o /var/lib/dkms/wireguard/1.0.20200611/build/socket.c: In function 'send6': /var/lib/dkms/wireguard/1.0.20200611/build/socket.c:139:20: error: 'const struct ipv6_stub' has no member named 'ipv6_dst_lookup_flow'; did you mean $ dst = ipv6_stub->ipv6_dst_lookup_flow(sock_net(sock), sock, &fl, ^~~~~~~~~~~~~~~~~~~~ ipv6_dst_lookup scripts/Makefile.build:330: recipe for target '/var/lib/dkms/wireguard/1.0.20200611/build/socket.o' failed make[1]: *** [/var/lib/dkms/wireguard/1.0.20200611/build/socket.o] Error 1 Makefile:1577: recipe for target '_module_/var/lib/dkms/wireguard/1.0.20200611/build' failed make: *** [_module_/var/lib/dkms/wireguard/1.0.20200611/build] Error 2 make: Leaving directory '/usr/src/linux-headers-4.15.0-101-generic' |
||
---|---|---|
.github | ||
LICENSE | ||
README.md | ||
wireguard-install.sh |
WireGuard installer
This project is a bash script that aims to setup a WireGuard VPN on a Linux server, as easily as possible!
WireGuard is a point-to-point VPN that can be used in different ways. Here, we mean a VPN as in: the client will forward all its traffic trough an encrypted tunnel to the server. The server will apply NAT to the client's traffic so it will appear as if the client is browsing the web with the server's IP.
The script supports both IPv4 and IPv6. Please check the issues for ongoing development, bugs and planned features!
WireGuard does not fit your environment? Check out openvpn-install.
Requirements
Supported distributions:
- Ubuntu >= 16.04
- Debian 10
- Fedora
- CentOS
- Arch Linux
Usage
Download and execute the script. Answer the questions asked by the script and it will take care of the rest.
curl -O https://raw.githubusercontent.com/angristan/wireguard-install/master/wireguard-install.sh
chmod +x wireguard-install.sh
./wireguard-install.sh
It will install WireGuard (kernel module and tools) on the server, configure it, create a systemd service and a client configuration file.
Run the script again to add or remove clients!
Providers
I recommend these cheap cloud providers for your VPN server:
- Vultr: Worldwide locations, IPv6 support, starting at $3.50/month
- Hetzner: Germany, IPv6, 20 TB of traffic, starting at €3/month
- Digital Ocean: Worldwide locations, IPv6 support, starting at $5/month
- PulseHeberg: France, unlimited bandwidth, starting at €3/month