Skip to content

Access your Synology NAS and its services remotely using Wireguard Easy

Last updated on 1 January 2025

Important or Recent Updates
UpdateDate
New guide released06/06/2024
Swapped the WireGuard container from LinuxServer to WG-Easy as it has a nice web UI! Also swapped the example Android Client to WG Tunnel.30/08/2024
Amendments made to the bcrypt password element to ensure the hash is formatted correctly and amended the wording relating to the password being optional but recommended.04/11/2024
Historic updates.


What are we doing?

I already have a guide on how to set up Tailscale on your NAS for remote access. In the interest of choice and as I am currently using this method this is an alternative using WireGuard (WG-Easy).

This guide has a number of key steps. I will take you through each one, if you already followed some of my other VPN related guides you may be able to skip sections!

  • Folder Setup
  • DDNS Address
  • TUN Script
  • WireGuard Kernel Module
  • Container Setup
  • Client Setup

A note on Double NAT or CGNAT
Unfortunately more ISPs are moving to these methods of address allocation as the IPv4 address space is getting low on available addresses.

You can test if this is the case by checking the WAN IP on your Router/Modem settings and then comparing it to the one shown on portchecker.co. If they are different you are likely Double NAT and will either need to see if you can pay your ISP for a standard IPv4 address or use Tailscale (see my other guide) or Cloudflare Tunnels for access.

Let’s Begin

In this guide I will take you through the steps to things up and running in Container Manager. We will be using the new Projects (Docker Compose) feature as it will save you time vs manual setup using the normal UI.

Folder Setup

Let’s start by getting some folders set up for the containers to use. Open up File Station create the following.

Folders
/docker/projects/wg-easy-compose
/docker/wg-easy

Next we need to setup a DDNS address in order to get connected.

DDNS and SSL

Before we start, make sure you have registered for a Synology Account as we are going to be using their DDNS service. https://account.synology.com/en-uk/register/ If you already have this set up move to the next step.

DDNS (Dynamic Domain Name System)

A DDNS address allows you to get external access to WireGuard via a domain provided by Synology, this is useful on home internet connections where your ISP will change your IP address on a regular basis. This will not put the NAS login screen on the internet by default as we won’t be opening the addition DSM ports on the router.

For some great hints and tips in relation to securing your NAS set Wundertechs recent guide.

In the DSM Control panel go to ‘External Access’ and then to the ‘DDNS’ tab

Click on ‘Add’, then fill out the following sections.

SectionValue
Service ProviderSynology
HostnameThis will be the address used to identify your NAS so make it personal to you not specific to this guide.
jellyseerr.synology.me = BAD
myawesomenas.synology,me =GOOD
Email:Log into your Synology account
External Address (IPv4)This should be filled in automatically
External Address (IPv6)This should be filled in automatically if your ISP is using IPv6
Get a Cert from Let’s EncryptTick this box
Enable HeartbeatTick this box

Now press OK, DSM will apply your settings. It can take a few moments to set up and the DSM interface will refresh. You will likely receive a certificate error which you will need to accept to get back into DSM.

Setting up the TUN start up script

In order for the VPN connection to work we need to make sure the TUN Interface is available. In order to ensure it is available even after a reboot we will set up a small ‘script’.

Please note if you already have GlueTUN running you have already done this 🙂 so jump ahead

Open up Control Panel and then click on Task Scheduler


Next click on Create, Triggered Task then User Defined Script.


Enter the following:

SectionSetting
Task:VPNTUN
User:root
Event:Boot-up
EnabledTick


On the Task Settings tab copy and paste the code below in the ‘User-Defined script’ section. It will look like screenshot.

Bash
#!/bin/sh -e

insmod /lib/modules/tun.ko


You can now press OK and agree to the warning message. Next run the script which will enable the TUN device.

You can now move on to the next step.

WireGuard Kernel Module (Required)

As DSM uses an older Kernel that does not have the required WireGuard modules we need to load them separately.

BlackVoid.club have put together a Kernel Module for Synology which allows the lower level Kernel to perform WireGuard duties, make sure you drop them a thanks as this would not be possible without them!

While on first glances it looks like a long installation process the page details a number of methods. I recommend having a read taking note of warnings and also if you want to build your own module it tells you how.

The TLDR is below.

  1. Find your model of NAS under the correct DSM version section (If you are following this guide it will be 7.2) and download the pre compiled .spk file
  2. Head into Package Center and click ‘Manual Install’ on the top right and install the .spk file and untick the box to run after install
  3. Reboot
  4. SSH Into your NAS (Just like in the User Setup guide) and elevate yourself to root by typing sudo -i and entering your password
  5. Enter this command and press enter to start up the module /var/packages/WireGuard/scripts/start

You should now be able to see the WireGuard package running in Package Center. Please note while I will try my best to support in relation to this module I may have to refer you on to BlackVoid if it is a specific technical issue.

On to the next part.

Container Manager

Next we are going to set up a ‘Project’ in Container Manager. Open up Container Manager and click on Project then on the right-hand side click ‘Create’.

In the next screen we will set up our General Settings, enter the following:

SectionSetting
Project Name:wg-easy
Path:/docker/projects/wg-easy-compose
Source:Create docker-compose.yml

Next we are going to drop in our docker compose configuration, copy all the code in the box below and paste it into line ‘1’ just like the screenshot.

YAML
services:
  wg-easy:
    image: ghcr.io/wg-easy/wg-easy
    container_name: wg-easy
    environment:
      - LANG=en
      - TZ=Europe/London
      - WG_HOST= #your ddns address
      - WG_PORT=51820 #
      - WG_DEFAULT_DNS=9.9.9.9
      - UI_TRAFFIC_STATS=true
      - UI_CHART_TYPE=1 # (0 Charts disabled, 1 # Line chart, 2 # Area chart, 3 # Bar chart)
	    - PASSWORD_HASH= #your bcrypt hash
    volumes:
      - /volume1/docker/wg-easy:/etc/wireguard
    ports:
      - 51820:51820/udp #wireguard port
      - 51821:51821/tcp #wg-easy UI
    cap_add:
      - NET_ADMIN
      - SYS_MODULE
    sysctls:
      - net.ipv4.conf.all.src_valid_mark=1
      - net.ipv4.ip_forward=1
    restart: unless-stopped

Environment Variables

We are now going to amend some key variables which define how the WireGuard connection will be set up and behave, I have covered the key settings here to get you up and running. You can find a full list of variables on the WG-Easy GitHub.

VariableValue
LANGDefaults to ‘en’ but there are a number of languages available (see the GitHub link above)
TZYou will need to change this line to your own timezone code – you can find the correct list of ones to use on wikipedia.org/wiki/List_of_tz_database_time_zones
WG_HOSTChange this to the DDNS address you setup in the previous steps
WG_PORTLeave this as it is
WG_DEFAULT_DNSThis is using quad9 by default you can amend to your preferred provider if you wish, this is also where you would put your AdGuard or PiHole IP.
UI_TRAFFIC_STATSYou can turn traffic stats on or off using ‘true’ or ‘false’
UI_CHART_TYPEIf you enabled the above then change the graph type.
‘0’ Charts disabled
‘1’ Line chart
‘2’ Area chart
‘3’ Bar chart
PASSWORD_HASHThis is optional but recommended to enable a password login for the web UI – see the extra info below on how to do it. If you don’t want to enable this remove the line.
Key Edits

Generating the web password

In order to enable the password for the Web UI you need to add a Bcrypt hash of your chosen password into the compose. Go to https://bcrypt.online/ to create the hash.

Enter the password in the ‘Plain Text Input’ box and then press the ‘Generate Hash’ button. Copy the generated hash next to the PASSWORD_HASH= line.

Finally you will need to slightly amend the $ signs in the hash to ensure it is read correctly from the compose by replacing any single $ to double $$ for example

$2y$10$Kpbc.6Ue5WClnHLxCxLOo.lNmJRg8inaNFu9tW03WaZpAGVLQRn76

becomes

$$2y$$10$$Kpbc.6Ue5WClnHLxCxLOo.lNmJRg8inaNFu9tW03WaZpAGVLQRn76

Once you have made the edits you can click ‘Next’

You do not need to enable anything on the ‘Web portal settings’ screen click ‘Next’ again.

On the final screen click ‘Done’ which will begin the download of the container image and once downloaded it will be launched!

The image will now be downloaded and extracted. You should see ‘Code 0’ when it has finished.

Forward the WireGuard Port

Now the container is running it would be a good idea to head into your Routers settings and forward the port your set for the container (51820). Refer to the manual on how to do this, essentially the port will be forwarded to the NAS IP address.

Firewall Exceptions

(Skip if you don’t have the Firewall configured)

If you have the Synology Firewall enabled please see this additional guide for further info on exceptions and correct set up.

Client Set up

WireGuard Easy makes it super easy to set up each client. Go to the Web UI on your NAS IP port 51821

Simply click ‘New Client’ and the config details will be created automatically for you.

You have a couple of choices on how to add the config to your end device, for phones make use of a WireGuard app. For this guide I am using WG Tunnel on the Playstore, for iPhone users there is also a WireGuard app.

Open the App and Tap the + button in the bottom Right, then ‘WireGuard’ in the pop-up menu, then ‘Add from QR Code’. Scan the QR code from WG Easy.

You can now turn on the connection from within the app and when roaming away from home all your locally hosted services will just work like you are on Wi-Fi. Your internet traffic is also routed through the connection. I have found that battery impacts are negligible so leave the connection on 24/7.




Looking for some help, join our Discord community

If you are struggling with any steps in the guides or looking to branch out into other containers join our Discord community!

Buy me a beverage!

If you have found my site useful please consider pinging me a tip as it helps cover the cost of running things or just lets me stay hydrated. Plus 10% goes to the devs of the apps I do guides for every year.

Published inDockerRemote AccessSynology

58 Comments

  1. Mario Mario

    I’ve setup wg-easy and able to connect but cannot access my synology on 192.168.1.121:5000 nor any docker packages, namely radarr on 192.168.1.121:7878. Accessing the router on 192.168.1.254 works fine though. Also, docker containers are only accessible through 172.18.0.1 or 172.20.0.1

    Locally, accessing 192.168.1.121:5000 works and any docker service through 192.168.1.121:PORT but cannot do so using 172.18.0.1 nor 172.20.0.1.

    Not really sure why I cannot access 192.168.1.121:5000 nor docker packages using this address while connecting remotely. To address this I’ve changed the YAML to try and fix this, however, still not able to overcome the issue.
    – WG_DEFAULT_DNS=192.168.1.254
    – WG_ALLOWED_IPS= 192.168.1.0/24, 192.168.1.121/32, 172.18.0.0/16, 172.20.0.0/16

    Any hints?

    • Dr_Frankenstein Dr_Frankenstein

      Hey Mario – I am currently fighting something similar on my Win 11 laptop – Where as my Android devices all work perfectly! Can you try the default Allowed IP setting to see if that then changes things – being able to access the other containers via their internal IP kind of makes sense as you are exiting within the Docker networking stack. I will do some further searching while you try the default setting (you will need to either regenerate the config)

  2. locobiker locobiker

    I am running into a problem here, when i use my pi-hole adress (192.168.1.129) for WG_Default_ DNS i can connect to my network but dont have internet access. Changing my DNS to 1.1.1.1 for example will give me access to my network and i have internet access but i my traffic is not going through pi-hole.

    In pi-hole settings i checked the box that PiHole needs to watch over all interfaces (found on reddit in wireguard sub as sollution) but that also did not solve the problem.. Do have an idea what else to try?

    thank you in advance

      • locobiker locobiker

        Yes, i followed your guide for pi hole set up. This is my yaml network part (pi-hole):

        macvlan:
        name: macvlan
        driver: macvlan
        driver_opts:
        parent: ovs_eth0
        ipam:
        config:
        – subnet: “192.168.1.0/24”
        ip_range: “192.168.1.254/24”
        gateway: “192.168.1.1”

        • Dr_Frankenstein Dr_Frankenstein

          OK – This makes sense as the host system cannot access the MACVLAN by design, so the only way to use it is to switch to either Bridge or Host network mode for the Pi-hole, and then it will work with Tailscale.

          • Martin Martin

            Thank you for your reply, my knowledge is of yaml is not enough to fix this by myself, can you help me what i have to change in my yaml. And are there downsides from putting my pi-hole in bridge or host?

            • Dr_Frankenstein Dr_Frankenstein

              Essentially you just need to go back to the Pi-hole guide and re-follow through, try using the bridge mode, however you may lose stats for individual devices – this is only a real issue if you had custom lists for specific devices etc..

              • locobiker locobiker

                Thank you this now it works, putting it in host did the job although i am not quite sure what to put at FTLCONF_LOCAL_IPV4: I put my ip of the syno here (and it works) , was some time ago i installed pi-hole and dint check there after, your sollution was in the guide!!

                Thx again and keep the guides comming and enjoy your coffee.

  3. Corey Janson Corey Janson

    Hello!
    First of all, thank you for your amazing guides. I’ve attempted to set my NAS up using a lot of guides online and yours are consistently the best.

    That said, I’ve followed this guide, setting up Wireguard and have gotten nearly to the finish line… only to get a “Handshake did not complete after 5 seconds” error in the Wireguard app on my client (android) device, despite everything appearing to connect properly.

    Also, while connected to the Wireguard VPN connection on my client device, I can’t seem to connect to the internet or interface with my NAS (where my wireguard is tunneling into).

    I feel like I’m so close to getting this up and working, only to stumble at the finish line.
    I’m using the Synology DDNS and that address is my WG_HOST in the wg-easy yaml.
    As far as I can tell, all my relevant ports are forwarded in my router and my Synology firewall.

    I’m happy to share logs with you if you have the time. In the meantime, I’m going to keep poking at settings and troubleshooting. There’s a good chance I misses something somewhere.

    I’d say I’m a noob at this, but following your guides over this last year makes me feel like at least a solid “novice”.
    Cheers.

    • Dr_Frankenstein Dr_Frankenstein

      Hi Corey – Try ruling out the Firewall by disabling it for your testing just to see if you get connection, it should just need the two ports 51820 and 51821 on the allow list. Do you see any network activity in the WG Easy UI (Red dot and traffic showing)

      Router wise should just require the 51820 port forwarding to the NAS IP just to be sure.

      Happy to have a look at logs they are not very verbose by default drop them on my private paste site

      https://paste.drfrankenstein.co.uk and drop the link in your reply.. I will remove before publishing.

  4. jmanko16 jmanko16

    Any options to use Wireguard with an Apple TV for plex access?

    I had been using tailscale but moving to wireguard (the iOS app actually works much better than tailscale and my work blocks tailscale ports so need it anyhow), and slowly moving over to VPN not just for using home assistant, qbit, and now the synology apps via wireguard EZ rather than quick connect (I use adguard for local DNS of my nginx with a SSL certificate for https, and with the wireguard setup just use that DNS server). The only thing that doesn’t work for my setup is my parents and sisters Apple TV and plex usage. While tailscale can work, my dad has t mobile home internet and seems that the tailscale connection doesn’t work on his end. I don’t see a client for Apple TV yet for wireguard?

    • Dr_Frankenstein Dr_Frankenstein

      Hey jmanko16

      Personally I do a split setup using WG for 99% of services, with Plex and Overseerr being the exception. This is purely from a usability perspective for a couple of Family members as it’s probably a step too far for getting them to set up WG or Tailscale just to watch stuff on their end devices.

      I don’t have much Apple experience we are an Android household but seen this mentioned to have been working on TV OS https://apps.apple.com/us/app/vpn-client-bee-for-any-vpn/id6467501461

  5. Sam Sam

    Thanks for the great guides! I went through and did the Tailscale setup a while back and it works well most of the time. . Curious if you think it’s worth swapping for WG considering it’s the service you are using yourself?

    • Dr_Frankenstein Dr_Frankenstein

      Hey – It really depends on your use case – if you want to use internal https domains that are provided by Tailscale they are useful for Vaultwarden etc. I am using my own domain with DNS Challenge for HTTPS, so a bit of a different setup, but for basic connecting into your network to just IP addresses WG is great

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.

drfrankenstein.co.uk – writing Synology Docker Guides since 2016 – Join My Discord!