this post was submitted on 21 Jul 2025
114 points (96.7% liked)

Selfhosted

52506 readers
2079 users here now

A place to share alternatives to popular online services that can be self-hosted without giving up privacy or locking you into a service you don't control.

Rules:

  1. Be civil: we're here to support and learn from one another. Insults won't be tolerated. Flame wars are frowned upon.

  2. No spam posting.

  3. Posts have to be centered around self-hosting. There are other communities for discussing hardware or home computing. If it's not obvious why your post topic revolves around selfhosting, please include details to make it clear.

  4. Don't duplicate the full text of your blog or github here. Just post the link for folks to click.

  5. Submission headline should match the article title (don’t cherry-pick information from the title to fit your agenda).

  6. No trolling.

Resources:

Any issues on the community? Report it using the report flag.

Questions? DM the mods!

founded 2 years ago
MODERATORS
 

Hello,

Some time ago, I started self-hosting applications, but only on my local network. So far, it's working fine, but I can't access them as soon as I go outside (which is completely normal).

For the past few days I've been looking for a relatively secure way of accessing my applications from outside.

I don't need anyone but myself to have access to my applications, so from what I've understood, it's not necessarily useful to set up a reverse-proxy in that case and it would be simpler to set up a VPN.

From what I've seen, Wireguard seems to be a good option. At first glance, I'd have to install it on the machine containing my applications, port-forward the Wireguard listening port and configure my other devices to access this machine through Wireguard

However, I don't have enough hindsight to know whether this is a sufficient layer of security to at least prevent bots from accessing my data or compromising my machine.

I've also seen Wireguard-based solutions like Tailscale or Netbird that seem to make configuration easier, but I have a hard time knowing if it would really be useful in my case (and I don't really get what else they are doing despite simplifying the setup).

Do you have any opinions on this? Are there any obvious security holes in what I've said? Is setting up a VPN really the solution in my case?

Thanks in advance for your answers!

top 50 comments
sorted by: hot top controversial new old
[–] friend_of_satan@lemmy.world 53 points 3 months ago* (last edited 3 months ago) (7 children)

Run WireGuard on some home machine. (Does not need to be the machine the app you want to access is hosted on.)

Run WireGuard on your road warrior system.

There is no step 3.

I'm doing this right now from halfway around the world from my house and it's been great. Been using iPhone, iPad, and macOS clients connected to linuxserver/WireGuard docker container. Been doing this on many WiFi networks and 5G, no difference.

[–] jaybone@lemmy.zip 6 points 3 months ago (1 children)

Is wire guard a service you pay for? Otherwise how does wire guard in your home machine not need your router to forward ports to it? And then the remote client need to be pointed at your home’s external IP?

[–] friend_of_satan@lemmy.world 32 points 3 months ago* (last edited 3 months ago) (1 children)

WireGuard is free. Obviously my instructions didn't go into detail about specifically how to set everything up. Port forwarding is required. Knowing your servers external IP address is required. You also need electricity, an ISP subscription, a home server (preferably running Linux), so on and so forth. This is /c/selfhosted after all.

[–] jaybone@lemmy.zip 7 points 3 months ago* (last edited 3 months ago) (1 children)

Yeah that’s fine. The steps were so simple I figured they could work without router config changes if they made some kind of connection handshake in a third party service’s server.

But given all that, I wonder if it makes sense to look into if your router has its own vpn server (or flash the firmware with one that does.)

[–] jobbies@lemmy.zip 3 points 3 months ago* (last edited 3 months ago) (2 children)

Apologies for the dumb noob question, but if your iOS device is VPNed to your home server, how does it access the open internet? Does it do this via the VPN?

[–] eszidiszi@lemmy.world 9 points 3 months ago* (last edited 3 months ago)

Depends on the client configuration. If you route all the traffic through vpn (so, simplified, 0.0.0.0/0) then all their client device network traffic would go through their vpn server at home and is seen as coming from there; otherwise, if you only route specific addressess (like your home network private addressess only) then only those go to their home network and everything else works like it would without a vpn.

[–] friend_of_satan@lemmy.world 7 points 3 months ago* (last edited 3 months ago) (3 children)

WireGuard routes certain traffic from the client (your iPhone) through the server (the computer at your house). If you route all traffic, then when your iPhone accesses the internet, it's as if you were at home. Since that WireGuard server is sitting on your home LAN, it is able to route your phones traffic to anything else on that LAN, or out to the internet.

Wireguard clients have a setting called AllowedIPs that tells the client what IP subnets to route through the server. By default this is 0.0.0.0/0, ::/0, which means "all ipv4 and all ipv6 traffic". But If all you want to access are services on your home LAN, then you change that to 192.168.0.0/24 or whatever your home subnet is, and only traffic heading to that network will be routed through the WireGuard server at your house, but all other traffic goes out of your phone's normal network paths to the internet.

load more comments (3 replies)
load more comments (5 replies)
[–] Djamalius@lemmy.world 19 points 3 months ago (1 children)

Also a beginner here, I use Tailscale, and it's been a very easy setup!

[–] waterproof@sh.itjust.works 4 points 3 months ago (2 children)

Tailscale is very tempting, on one hand it should provide a pretty good layer of security without too much thinking and it is "free", and on another hand, it's a business solution, so it is probably not really free...

Thanks for the answer anyway confirming that Tailscale is pretty easy to setup !

[–] psycotica0@lemmy.ca 9 points 3 months ago

The tailscale clients are, I believe, open source. It's just the server that's not, and you can run the unofficial but well supported "headscale" as a server if you want. But this requires you to run this somewhere publicly accessible, like a VPS, for coordination and NAT-punching purposes.

But! I'm pretty sure as the business operates right now, that tailscale doesn't have access to the actual data connections or anything, it's all encrypted, they're basically just there for simplicity and coordination. And their business model is to offer simple things for free, like small numbers of devices, with the hope that you like the service and convince your business to pay for the fancy version for money. So I don't think it's quite as bad as the typical "free because I'm harvesting your data" models.

That all having been said, I run headscale 😛

[–] jasep@lemmy.world 3 points 3 months ago (1 children)

Headscale is an open source implementation of the Tailscale control server.

https://github.com/juanfont/headscale

Not an endorsement as I haven't used it (I do use Tailscale), but just thought I'd point it out.

load more comments (1 replies)
[–] ThunderLegend@sh.itjust.works 18 points 3 months ago (1 children)

Wireguard is the way to go. I like using wg-easy to use wireguard because its easy to set up in a docker container.

[–] k4j8@lemmy.world 5 points 3 months ago (3 children)

wg-easy

Agree, highly recommend this and/or Tailscale.

load more comments (3 replies)
[–] rtxn@lemmy.world 10 points 3 months ago* (last edited 3 months ago)

Managing Wireguard is just one of Tailscale's features.

It uses some UDP black magic fuckery to get through NAT and firewalls without having to open ports on the edge. Very useful if you're behind CGNAT and/or your ISP is a dickhead and locks down the firewall on your router (this is why I use it; eat a dick, Vodafone). If the UDP fuckery is not available, it reverts to simple relay servers. The client can also advertise subnets and route to hosts on it. You could install the Tailscale client on OPNSense/pfSense/OpenWRT and access your entire home network through that one device.

[–] conrad82@lemmy.world 10 points 3 months ago

Simple and fast solution is tailscale. tailscale is a business, but it works well

Personally i use opnsense and wireguard

[–] ikidd@lemmy.world 9 points 3 months ago

Tailscale is easier than Wireguard but if you're running OPNsense or OpenWRT it's not hard to do a wireguard infra of your own and avoid having to use an outside service. I ended up having to revert to wireguard anyway because Tailscale's android app wasn't reliable on my new phone, it would drop out every few hours which messed up my monitor/alert system.

But Tailscale is still the easier of the two solutions.

[–] monkeyman512@lemmy.world 8 points 3 months ago

Tailscale. You can make a free account and they have clients for most things. If you want to self host, Headscale.

[–] DetachablePianist@lemmy.ml 8 points 3 months ago* (last edited 3 months ago) (1 children)

I rarely if ever see ZeroTier mentioned as a solution, but it's a self-hostable encrypted virtual mesh network (with a small free tier for corp-hosted), super secure, and really easy to setup. I use ZTnet instead of the free-tier corp-hosted controller

load more comments (1 replies)
[–] spaghettiwestern@sh.itjust.works 7 points 3 months ago* (last edited 3 months ago) (3 children)

I self-host various applications and have been really happy with Wireguard. After watching just how hard my firewall gets hammered when I have any detectable open ports I finally shut down everything else. The WG protocol is designed to be as silent as possible and doesn't respond to remote traffic unless it receives the correct key, and the open WG port is difficult to detect when the firewall is configured correctly.

Everything - SSH, HTTP, VNC and any other protocol it must first go through my WG tunnel and running it on an OpenWRT router instead of a server means if the router is working, WG is working. Using Tasker on Android automatically brings the tunnel up whenever I leave my house and makes everything in my home instantly accessible no matter what I'm doing.

Another thing to consider is there's no corporation involved with WG use. So many companies have suddenly decided to start charging for "free for personal use" products and services, IMO it has made anything requiring an account worth avoiding.

[–] Scorpoon@feddit.org 4 points 3 months ago

If you use Tasker only as VPN switch you could have a look at WG Tunnel from zaneschepke on Github. It has a built in function to switch to the tunnel when your local WIFI is not connected.

https://github.com/zaneschepke/wgtunnel

load more comments (2 replies)
[–] sugar_in_your_tea@sh.itjust.works 6 points 3 months ago (1 children)

If your traffic is pretty low, rent a VPS for $5/month or whatever and set up a Wireguard server on it, have your devices maintain a connection to it (search keepalive for Wireguard), and set up HAProxy to do SNI-based routing for your various subdomains to the appropriate device.

Benefits:

  • you control everything, so switching to a new provider is as simple as copying configs instead of reconfiguring everything
  • most VPN companies only route traffic going out, not in; you can probably find one that does, but it probably costs more than the DIY option
  • easy to share with others, just give a URL

Downsides:

  • more complicated to configure
  • bandwidth limitations

If you only need access on devices you control, something like Tailscale could work.

Benefits:

  • very simple setup - Tailscale supports a ton of things
  • potentially free, depending on your needs

Downsides:

  • no public access, so you'd need to configure every device that wants to access it
  • you don't control it, so if Tailscale goes evil, you'd need to change everything

I did the first and it works well.

[–] deathbird@mander.xyz 5 points 3 months ago (1 children)

I would not recommend relying on Tailscale. They have been soliciting a lot of venture capital lately and are probably going to go for an IPO sooner or later. I would not put a lot of trust in that company. The investors are going to want their money.

load more comments (1 replies)
[–] Kagu@lemmy.ml 6 points 3 months ago

Not running anything myself but am part of a self hosting discord that swears by Netbird because its basically Tailscale but with a bunch more ease of use features apparently

[–] Ptsf@lemmy.world 6 points 3 months ago (4 children)

Zero tier. I went tailscale originally, and they're good, but their mdns support doesn't exist and several services rely on it. (For me, the showstopper was time machine backups)

load more comments (4 replies)
[–] damnthefilibuster@lemmy.world 6 points 3 months ago (2 children)

You got two options which I’ve tried -

  1. A solution like tailscale or zerotier. Simple setup, easy to turn on and just go. Tailscale is newer and has a nicer interface and features like using an actual VPN like Mullvad as an “endpoint” (or whatever they call it). Their Mullvad connection also basically gives you a discount as they charge only $5 for the vpn instead of €5. The catch is that Mullvad charges you that price for 5 devices. So if a sixth device connects to the VPN through tailscale, you get charged $10 for that month.
  2. A cloudflare tunnel with zero trust on top. More work to setup. But makes it easy to access your apps without any vpn. They’re basically exposed to the internet at that point, but locked in behind cloudflare’s authentication. You can literally set it up for one or two email IDs. Yours and a family member’s. Much simpler for others to wrap their heads around. But some people dislike cloudflare for some reason or the other.
[–] BruisedMoose@piefed.social 7 points 3 months ago (1 children)

I'm in camp #2. Only my Gmail address can access my apps from outside my home. It's a little bit of a pain to configure the rules, but once it's done it's done. I've been happy with it.

You do need to have a domain name though.

load more comments (1 replies)
[–] nfreak@lemmy.ml 6 points 3 months ago (4 children)

The variant version of number 2, which is more work to set up of course, is Pangolin on a VPS. Basically serves the same purpose but skips Cloudflare entirely.

I'm in the process of setting up Pangolin and Headscale on a VPS to expose a small handful of services and to replace my wg-easy setup. Currently chaining wg-easy through a gluetun container, so with a single VPN connection I get LAN access and protect my outbound traffic, but I can't for the life of me get the same setup working on wg-easy v15, so I'm going to give tailscale/headscale a try with a gluetun exit node.

[–] damnthefilibuster@lemmy.world 2 points 3 months ago (1 children)

haven't looked at Pangolin, but thanks for the info! I might explore it in the future if my current setup gives me any issues.

load more comments (1 replies)
load more comments (3 replies)
[–] Tywele@lemmy.dbzer0.com 5 points 3 months ago (1 children)

I use the built-in Wireguard feature of my Fritzbox to connect to my home network.

load more comments (1 replies)
[–] phillipp@discuss.tchncs.de 5 points 3 months ago

I’m in the same boat and currently run WireGuard to access my services. However the more I extend my stack of services, the more I have use-cases to expose certain services to friends and family. For that I’m currently looking into using Pangolin.

[–] Atherel@lemmy.dbzer0.com 5 points 3 months ago

Wireguard with WG Tunnel on my phone so it automatically connects when I leave my WiFi. Some Apps excluded to use it like Android Auto because it doesn't work with an active vpn.

[–] Tinkerer@lemmy.ca 4 points 3 months ago (3 children)

I used wireguard self hosted for a bit but my work network is pretty locked down and I couldn't find a UDP port that wasn't blocked. How are you guys setting up wireguard in your home network? Or is it better to host it on a cloud VM?

I'm using tailscale right now because it punches through every firewall but I don't like using external providers and I'm worried it will eventually enshittify. I have a cloudflare domain but I can't really use any UDP port for my VPN as it's blocked.

load more comments (3 replies)
[–] JohnSmithon@lemmy.world 4 points 3 months ago

1 pangolin 2 whatever is already on your router 3 wireguard

Pangolin also does RP with traefik so it's a win win

[–] Bort@hilariouschaos.com 4 points 3 months ago (1 children)
[–] mumblerfish@lemmy.world 2 points 3 months ago

I would recommend this too. This was the easiest to setup. I only had an issue with docker compose which made the pihole not being accessible while on wireguard. Once I put the pihole and wg-easy on the same docker network it started working.

[–] randombullet@programming.dev 4 points 3 months ago

I use a mixture of tailscale and zerotier. Both are pretty powerful.

[–] DieserTypMatthias@lemmy.ml 3 points 3 months ago (1 children)

Tailscale. You don't need to open up ports + you can set up exit nodes, which are useful if you're sailing the seven seas.

load more comments (1 replies)
[–] BCsven@lemmy.ca 3 points 3 months ago

Tailscale is great in that config is super simple. Downsides tailscale ssh has to be called at launch if you want ssh access over that network... Could be a benefit for security...however its a tailscale specific ssh and not everything is available.
Data servers moved to the USA a few ears back.

Wireguard is more setup, but a better (self host option ). There is also Headscale if you want to selfhost a tailscale type server

[–] muusemuuse@sh.itjust.works 3 points 3 months ago

WireGuard is the fastest method, it’s free, there is no reason not to use it.

load more comments
view more: next ›