Introduction: What Is WireGuard?
WireGuard is a modern, efficient, and highly secure VPN (Virtual Private Network) protocol designed to simplify the complexities of traditional VPNs like L2TP/IPsec. It boasts lightweight architecture, faster performance, and seamless encryption, making it a popular choice for secure communication.
Key Benefits of WireGuard:
- Speed: Offers significantly faster performance compared to traditional VPN protocols.
- Simplicity: Designed with minimal code for easier implementation and auditing.
- Security: Employs state-of-the-art cryptography to ensure robust security.
- Cross-Platform: Works across multiple operating systems, including Linux, Windows, macOS, and mobile devices.
In this guide, we’ll walk you through setting up WireGuard on your MikroTik router.
Prerequisites
Before starting, ensure you have the following:
- A MikroTik router running RouterOS version 7.1 or later (WireGuard is not supported on earlier versions).
Step 1: Enable WireGuard Interface
- Create a new WireGuard interface and give it a name, leaving the rest default (optional to change Listen Port if required)
data:image/s3,"s3://crabby-images/f1004/f10045895570fbf88e26ce417a537147fbfb96e6" alt=""
/interface/wireguard add name=wireguard1
data:image/s3,"s3://crabby-images/0821b/0821b611f23a9e08602a1f97caed62e39ca46dd4" alt=""
Step 3: Configure the WireGuard Interface IP Address
- Assign an IP address to the WireGuard interface:
data:image/s3,"s3://crabby-images/2404b/2404b039a5ac9e5c30789e0df0f1d4bea1484eba" alt=""
/ip/address add address=10.3.254.1/24 interface=wireguard1
Replace
with your preferred subnet for WireGuard clients.10.3.254.1/24
Step 4: Configure Firewall Rules
Input Chain
- Add a rule to accept incoming WireGuard traffic:
data:image/s3,"s3://crabby-images/4abc8/4abc86903d722f9ed8a2baafb5902c8ed690f08b" alt=""
data:image/s3,"s3://crabby-images/cbe8c/cbe8c2e51b77ad0048b4d1ca631b96e2275f1af1" alt=""
/ip/firewall/filter add chain=input action=accept protocol=udp dst-port=51820
Forward Chain (optional)
If you are limiting access between internal LAN subnets, you’ll need to add a rule to allow access between the WireGuard subnet (10.3.254.0/24) to your local subnets. The below example uses address lists for local networks.
Add as many subnets as required
data:image/s3,"s3://crabby-images/51087/51087f9a233eaa20d47651cf046193a32682fe34" alt=""
ip firewall address-list add address=192.168.123.0/24 list=LOCAL
data:image/s3,"s3://crabby-images/a766e/a766e9fd4d64715a8e7f9a47da59dd6e9cbb284d" alt=""
data:image/s3,"s3://crabby-images/b8047/b8047f1fb0f050d72088c40ff72908ba1610f9b4" alt=""
Step 5: Add WireGuard Peers
Each client device connecting to the WireGuard VPN is considered a “peer.”
- Add a peer configuration:
Name: | wg-user1 | Any name |
Interface: | wireguard1 | The interface created earlier |
Private Key: | auto | Set to auto to automatically generate |
Endpoint Port: | 13231 | Default is 13231 unless changed earlier |
Allowed Address: | 10.3.254.20 | IP of the client |
Client Address: | 10.3.254.20 | IP of the client |
Client DNS: | 1.1.1.1 | Optional (if unset device will use locally acquired DNS) |
Client Endpoint: | 54.66.163.58 | Public IP of the WG server (the MIkroTik) |
data:image/s3,"s3://crabby-images/adbad/adbadb6cd9726146dffe4f3affb1b4934d890708" alt=""
/interface wireguard peers add allowed-address=10.3.254.20/32 client-address=10.2.254.20/32 client-dns=1.1.1.1 client-endpoint=54.66.163.58 endpoint-port=13231 interface=wireguard1 \name=wg-user1 private-key=auto
Once applied the keys will auto-generate and the Client Config will be populated
data:image/s3,"s3://crabby-images/ce45b/ce45bda454f0ecd3450b6b6a32b5255b279728bc" alt=""
Repeat this step for each additional client.
Step 6: Configure Client Devices
On the client device (e.g., phone, laptop), install the WireGuard application
The below options are the same on either Windows Client or Phone (Android/iOS) how the look and menu selection will be different but wording will be similar.
Option 1: CONF File
Open a notepad (Windows Notepad or Notepad++) and copy the content from the Client Config under the Peer you created. To do this double click on the content box (it won’t visibly highlight anything) and right-click and select copy:
data:image/s3,"s3://crabby-images/892b1/892b1955647ce388ed993da8ff8bd69a5a8f93d3" alt=""
Save the file as a .conf (if using Windows Notepad make sure you change the file type form .txt to all files)
data:image/s3,"s3://crabby-images/1f8ac/1f8acf9f9a0228def01915d5a3c864c6d86aa515" alt=""
On the Application select Add Tunnel > Import tunnel(s) from file… Then select the .conf file
data:image/s3,"s3://crabby-images/34df6/34df672536ed0eab7fe476479efe3823b3eee06f" alt=""
Option 2: Add Empty Tunnel
This option allows you to simply paste the config from the peer settings directly into a new peer connection
Click Add Tunnel > Add empty tunnel… and paste th
data:image/s3,"s3://crabby-images/63b0d/63b0d6a3d7e55639726f025f0097c0ac3276cc47" alt=""
data:image/s3,"s3://crabby-images/58588/585884f960656620b7bc3150ce2095b911de3f2f" alt=""
Step 7: Verify the Connection
- On the MikroTik router, check active WireGuard connections:
/interface/wireguard/peers print
- Test connectivity from the client device to the internet or internal network resources.
Troubleshooting Tips
- Ensure UDP port 51820 is open on any upstream firewalls or NAT devices.
- Verify the subnet and IP address configurations to avoid conflicts.
Conclusion
WireGuard is a powerful yet straightforward VPN solution that ensures secure and fast communication. By following this guide, you’ve successfully set up WireGuard on your MikroTik router, providing a reliable VPN solution for your network.
If you have any questions or need further assistance, feel free to leave a comment or explore more tutorials on MikroTik Masters. Don’t forget to subscribe to our YouTube channel for more networking tips!
Step 4, is the port really correct? Should it not be 13231?
Agreed – good pickup thanks!
You can choose what you want port number
Yes I believe you can change it to something else
I made it, finally thanks to your guide. Thank you! And what’s most important works for apple products too. yay 🙂