this post was submitted on 08 Jun 2025
57 points (96.7% liked)

Selfhosted

52498 readers
1268 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
 

Hi, I live in Germany and only have public IPv6. My address changes only very, very rarely and has never changed in the time I've been self-hosting.

I also have a very small, pretty cheap VPS with static IPv4/IPv6 – which would seem like a great fit for some sort of tunneling/proxy setup. Now comes the question: What/how should I use it? I would like to not have the additional latency for IPv6 enabled hosts, can I just setup a reverse proxy for IPv4? Would Tailscale work for my usecase, what are some resources you found useful when using it?

Currently, I'm just hosting everything IPv6-only and hoping my address never changes, but that does not work for everyone, as especially many new buildings with fiber optic connections still only have IPv4 (strangely).

top 34 comments
sorted by: hot top controversial new old
[–] hendrik@palaver.p3x.de 25 points 4 months ago (1 children)

I'd just set up the reverse proxy on the VPS and make it forward everything via IPv6. But you could also use a tunnel/VPN, everything from Tailscale to Wireguard or even an SSH tunnel would work. And there are dedicated services like Cloudflare, nohost, neutrinet, pagekite...

[–] robber@lemmy.ml 5 points 4 months ago* (last edited 4 months ago)

I'll add Pangolin to the list, it's a self-hosted Cloudflare tunnel alternative.

[–] Shimitar@downonthestreet.eu 18 points 4 months ago (2 children)

Wire guard to the vps with nftables port forwarding.

Check my wiki here https://wiki.gardiol.org/doku.php?id=networking%3Awireguard_redirects

Or setup ssh with port forwarding as well. Less reliable but nothing to install on a basic Linux.

[–] ari_verse@lemmy.ca 2 points 4 months ago (1 children)

This. Using simple ssh tunneling with port forwarding in a similar scenario. Working flawlessly with zero maintenance for 5 years and counting. Very reliable

[–] Shimitar@downonthestreet.eu 5 points 4 months ago (1 children)

Not really reliable, much less than wire guard. If your connection is unstable ssh not the best option. Autossh make it better, but still after a forced disconnection ssh will take a while to drop and reconnect. Wire guard is much better. I moved from ssh+autossh to wireguard and wished I did that sooner.

[–] ari_verse@lemmy.ca 3 points 4 months ago* (last edited 4 months ago)

Fair comment, I should qualified my answer: I use an ssh tunnel with auto-reconnect option, wrapped inside a systemd service. In all this years, I still have to run into a problem that wasn't external (server down, no internet at home etc) I agree that wireguard is the proper solution however it requires a lot of extra configuration and support in both ends, which now is prevalent but not so much 5+ years ago. Also for a single port solution, ssh is so much simpler, practical and reliable, you only need an ssh user at the other end.

ExecStart=/usr/bin/ssh -NT -o ServerAliveInterval=60 -o ServerAliveCountMax=3 -o ExitOnForwardFailure=yes -R localhost:YOUR_PORT:localhost:YOUR_PORT SOME_USER@YOUR_SERVER

[–] DevoidWisdom@sh.itjust.works 1 points 4 months ago

I do this already, but I'm going compare my nftables rules when i get home. You're ip table looks more elegant.

[–] death916@lemmy.death916.xyz 10 points 4 months ago (1 children)

Tailscale is amazing. When i first started self hosting i tried a bunch of things to avoid a companies solution but tailscale just works perfectly and form what they say in interviews they dont intend to change the free tiers. Its also open source and there's headscale so eventually you could not rely on the company at all.

[–] Jason2357@lemmy.ca 7 points 4 months ago

I switched from Tailscale to headscale, and I still would suggest Tailscale to anyone. It’s just really done well and they seem to actually love that self-hosters and hobbyists use their stuff.

[–] randombullet@programming.dev 6 points 4 months ago (1 children)

Ionos.de has a €1 a month VPS

I think 1 core, 1gb ram, and 10gb.

Use either caddy or Nginx proxy manager. Both are easy to setup. Also both are dockerized.

I use Tailscale as my tunnel.

Total latency is about 70-90ms for me.

[–] lemonuri@lemmy.ml 1 points 4 months ago* (last edited 4 months ago)

I did something very similar via netcup tiny vps, nginx and wireguard. I could post my setup notes tomorrow if someone needs them.

[–] SpacePirate@lemmy.ml 6 points 4 months ago (1 children)

Curious question, why would IPv6 introduce additional latency?

[–] cmnybo@discuss.tchncs.de 6 points 4 months ago

It doesn't, but running everything through a tunnel to get IPv4 access would. OP wants only the IPv4 traffic to go over a tunnel.

[–] 2xsaiko@discuss.tchncs.de 4 points 4 months ago* (last edited 4 months ago) (1 children)

Yes, you can just use a reverse proxy for IPv4 only and point it to the IPv6 upstream. That is what I do, with a separate DNS record which then combines the two. See the DNS records for id.knifepoint.net (CNAME), http.vineta.knifepoint.net (AAAA, A) and vineta.knifepoint.net (AAAA).

The reverse proxy config and certificate management is set up with NixOS, if it helps: https://git.dblsaiko.net/systems/tree/nixos/defaults/v4proxy.nix https://git.dblsaiko.net/systems/tree/nixos/modules/sys2x/v4proxy.nix

[–] rirus@feddit.org -5 points 4 months ago (2 children)

But having a reverse proxy would enable someone getting access to it to read traffic, while having a VPN Tunnel won't.

[–] 2xsaiko@discuss.tchncs.de 13 points 4 months ago (1 children)

If someone manages to get root (!) access on this VPS it's over either way.

[–] rirus@feddit.org 1 points 4 months ago

NO, an attacker getting control over a vps used as a tunnel could not read Data captured in the past. Also they could not do a MITM with decrypted SSL without breaking HSTS

[–] gray@pawb.social 3 points 4 months ago (1 children)

Your reverse proxy should have a cert with HTTPS.

[–] 2xsaiko@discuss.tchncs.de 2 points 4 months ago (2 children)

Tbf, technically data is still decrypted at the reverse proxy and then re-encrypted. So if someone manages to reconfigure the proxy or read its memory somehow they could read traffic in plain text.

However then since they have to control the VPS, they could also get a new cert for that domain (at least the way I’ve configured it) even if it was passed as is to the real host via a tunnel and read the plaintext data that way, so I don’t think a tunnel protects against anything.

[–] amdim@lemmy.dbzer0.com 2 points 4 months ago

I use this setup and don’t terminate SSL at the VPS and solely tunnel the encrypted traffic over a wire guard tunnel to the home lab where SSL is terminated.

The VPS solely serves to move the traffic from an external IP to an internal one.

It’s possible that someone could log into my server, change the nginx config to terminate SSL and then siphon data but it would take a few steps and can be somewhat mitigated by stapling the SSL certs that should be seen from the homelab.

[–] hank_and_deans@lemmy.ca 1 points 4 months ago (1 children)

Or just use Nginx stream proxy, and all the encryption happens on the endpoints. No need for certs on the proxy at all.

This is how I make https and mqtts available on ipv4.

[–] 2xsaiko@discuss.tchncs.de 1 points 4 months ago (1 children)

Oh interesting, I’ll have to look into that. Is this with that “proxy protocol” I’ve seen mentioned? If not, does this preserve it pass through the client socket address?

[–] hank_and_deans@lemmy.ca 1 points 4 months ago (1 children)

It's merely a tcp proxy. It doesn't even have to be http since it has no idea. The trick with tls is that it can extract the requested host name via SNI.

[–] 2xsaiko@discuss.tchncs.de 1 points 4 months ago (1 children)

Hm, okay, that does sound like the real client IP will get lost and every connection will appear to come from the proxy then. It would be good if that were passed somehow. My current setup adds the X-Forwarded-For header for example.

[–] hank_and_deans@lemmy.ca 1 points 4 months ago* (last edited 4 months ago)

That is correct. There is a trick where you can set the source ip to the ipv6 mapped ipv4 ip it originally came from. I have implemented that in a transparent tcp proxy I worked on some years ago, but I am not sure if nginx supports that.

I should look into that actually. It would be useful to me as well.

Edit: actually that only works if you are in the routing path. However a nat64 solution would work as well, where you map a /64 back to the proxy.

[–] thelittleblackbird@lemmy.world 4 points 4 months ago (1 children)

Small and stupid question.

Why don't use a ddns client to update your ipv6 evytime it changes? With a ttl of a minute your shouldn't be able to see any downtime...

I (genuinely) thinks you are trying to solve a small problem in the complicated and hard way.. M

[–] Keelhaul@sh.itjust.works 1 points 4 months ago (1 children)

Plenty of IPv4 only networks still exist from which you would not be able to access the services. I am in a similar situation as OP with my offsite address being IPv6 + CGNAT IPv4 and my own address being IPv4 only.

[–] thelittleblackbird@lemmy.world 1 points 4 months ago (1 children)

Plenty of ipv4 only in 2025?? Really?? Without a possibility to activate dual stack or just the dslite-crap?

I honestly didn't think this could be a real issue in those years.

[–] Keelhaul@sh.itjust.works 1 points 4 months ago

Yup, sorry to be the bearer of bad news🥲

[–] csm10495@sh.itjust.works 3 points 4 months ago* (last edited 4 months ago)

Another option if you need public access without something like tailscale would be to use ddns and a AAAA record. Something like https://github.com/ddclient/ddclient would help do that.

That way if the IP changes, you'd pick up on the change for your vanity url within a few minutes.. and can get https certs for that url as well.

Edit: I reread the OP. This doesn't help if clients need direct ipv4. Sorry about that.

[–] spanac@lemmy.zip 2 points 4 months ago

I have a similar situation, where I only get a public IPv6 prefix. I ended up renting small vps at netcup and installed OpenVPN and ha-proxy. My home router connects to the VPS's public IP and I do port forwarding for the services I need, or use the proxy.

Initially I setup SNAT for my web server (otherwise replies were going out the wrong interface) and that meant you don't see the public IP of the connecting client in your access logs.

Recently I switched to using ha-proxy which does tcp level proxying and works well with ports 80 and 443 and Traefik, which i use to expose my docker containers.

My connection chain looke like vps -> ha-proxy -> OpenVPN -> port forward to Traefik -> reverse proxy to the final service. It's not a fast server, and I didn't measure latency, but it's for sure not small.

As others have mentioned, ha-proxying to your IPv6 might be an interesting solution, and I think I will also try it out.

[–] tfowinder@lemmy.ml 2 points 4 months ago

I have a VPS hosted on Digital ocean with Nginx running as proxy, I use openvpn to connect to the VPS and access all my services over the VPS ip address.

I own a domain and forward all the requests from my domain to the Home server IP from my VPS, very useful because I can use different subdomains for different services all on port 80 or 443 even though the service is running on random port.

[–] yournamehere@lemm.ee 1 points 4 months ago

simplest that comes to mind is a reverse ssh tunnel and a reverse proxy on the vps maybe

[–] Brkdncr@lemmy.world 1 points 4 months ago

vpn to your vps for ipv4.

Dynamic dns to whatever your local hosted services use in case your local ipv6 changes. I’d just use the vps vpn for everything though unless the speeds are really bad.