I have my services proxied through nginx and behind cloudflares free tier. That way I don't have to worry about my IP getting exposed and opening myself up to DDOS/DOS attacks, which is a genuine threat if you do things that piss people off (I'm an admin on a popular minecraft server).
Selfhosted
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:
-
Be civil: we're here to support and learn from one another. Insults won't be tolerated. Flame wars are frowned upon.
-
No spam posting.
-
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.
-
Don't duplicate the full text of your blog or github here. Just post the link for folks to click.
-
Submission headline should match the article title (don’t cherry-pick information from the title to fit your agenda).
-
No trolling.
Resources:
- selfh.st Newsletter and index of selfhosted software and apps
- awesome-selfhosted software
- awesome-sysadmin resources
- Self-Hosted Podcast from Jupiter Broadcasting
Any issues on the community? Report it using the report flag.
Questions? DM the mods!
You can use Cloudflare Tunnels too, so that you don't even need to port forward.
It’s 2023, the threat is there regardless if you piss anyone off. We’re all commodities that can/will be exploited for capitalistic gain.
I looked into nginx for minecraft, but minecraft doesn't use http headers, so I'd have to open minecraft ports on the router. Would this alleviate that? What's the difference between this setup and using something like a cloudflare tunnel? Obviously, there is still some reliance on Cloudflare.
https://tcpshield.com/ they have a very generous free tier. It requires spigot/bukkit plugins or a velocity plugin (velocity is a Minecraft proxy, think of this as NGINX for minecraft).
Thanks!
If you port forward to your Pi, only your Pi will be exposed. But, if your Pi gets pwned, it can in turn attack anything next to it. Safest is to isolate the Pi on it's own subnet or a DMZ if your router has the functionality.
Of note, many home ISPs block standard server ports like 80 and 443. You might need to use non standard ports like 8080 and 8443
I did this for some time. But now I don't want any ports open at home.
That's why I have a rented VPS that runs Traefik (a reverse proxy). This VPS has a VPN connection to my home net and is behind Cloudflare DNS. This is how I can safely expose services (even in my home net) to the Internet without forwarding any ports.
Of course those services need to have some kind of authentication.
If you've set up a VPN to your home net then why not run that VPN from the devices you use to access the reverse proxy? With wireguard at least this is quite easy.
That way you don't have to expose anything you just run a VPN with the reverse proxy in it.
My setup is
Internet <---> Reverse Proxy (on VPS) <---> OpenVPN Server (on VPS) <---> VPN Client (home router) <---> local stuff...
I don't understand what you mean? Generally I don't like to require a VPN to access stuff. My use case is, when I'm away I'd like to be able to access things from e.g. a public device, a friends laptop, etc. That's why I'm not using a VPN to access things.
The VPN site-to-site connection is mainly responsible to make network shares available on my Nextcloud instance and provide access to other (local) services via the reverse proxy
Currently I'm rethinking the VPN, but I don't think I can ditch it in favor if e.g. Cloudflare Access tunnels (too unflexible, limited compatibility, or too much hassle to keep everything configured correctly).
Also, I don't use VPN to authorize requests. I use Authelia to authorize users with Free-IPA as directory in the backend.
I know, this might be overkill for my "simple" use cases, but I like to play around with these kind of enterprise-adjacent solutions.
I suppose it depends on what you want to do. I'm currently only hosting stuff for my own purposes so it is fine if I can just access it from devices I trust.
My setup is more like
Wireguard (on Phone/Laptop/etc) <--> Wireguard (on RaspberryPi) <--> Reverse Proxy (on RaspberryPi) <--> local stuff (mostly in docker on RaspberryPi)
The advantage is that the only service accessible from outside is Wireguard, so even if some service running behind the reverse proxy is insecure I'm still the only one with access.
Obviously one of the disadvantages is that I can't access it (easily) from some random device, but I can access it from my phone and in an emergency I do have keys that I can use to install wireguard somewhere else, but I would require admin rights to some device to do so.
Ah yes. I've been there. But since I've onboarded my family onto my domain and they use a few of the services I needed a low but still secure barrier of entry. Hence the more "public" approach.
Damn thats top security right there.
If this was "top security" I'd need to change jobs, haha! I just hope it doesn't fall apart and nobody breaches it too easily.
Currently there are probably a lot of attac vectors available, that I'm not even aware of. I just have to hope, that my stuff won't become interesting for a bad actor.
Nothing to see here, move along. I have a few locks, not worth it... :D
I've been considering doing the same thing, but i'm not sure there's much actual benefit over feeling like there's more separation, because if someone accesses the vps, they get direct access into your server at home. What's your opinion?
Yes, definitely. If someone breaches the VPS, I've lost. That's why it's rather locked down using strict firewall rules, pubkey auth, fail2ban, etc.
No matter what you expose to the Internet, you're accepting a risk.
If I had to start over, I'd probably set up some form of cloud infrastructure with maybe Cloudflare for access control and security or whatever. My system started when I didn't have a lot of funds. So everything is kind of cobbled together.
The VPS is/was for hosting a few game servers and now I'm too lazy to migrate away, haha.
At least everything is based on configs that I keep in Git repositories. But I digress (again).
Yeah, same. I have a small server that runs Wireguard and I only expose services on any device on the local Wireguard interface. That way I can safely access stuff in my home net from anywhere.
You could put the pi on its own subnet. That way if it's hacked, the rest of the network is protected. Just make sure your router admin interface doesn't answer on that subnet.
You could put the pi on its own subnet.
This option is sometimes referred to as a 'DMZ' and may be supported by the router. Also look for VLAN options.
DMZ in essence means "forward ALL ports" to X. You should only DMZ a host that you know is very secure as its attack surface is significantly increased. If you need just one or two services open, best to not use DMZ
This is true for consumer routers/firewalls
The port forward only forwards to a single device so you aren't exposing your PC (directly anyway). Sounds like you have the pi good and secured but if you wanted to add another layer you could segment it out into a DMZ or its own VLAN. That way if something did happen with it an attacker couldn't move laterally inside your network.
Realistically though you're in good shape.
You’ll be ok as long as whatever software you’re running that is listening to 80 and 443 never has an exploitable vulnerability, if it does… you may be in trouble depending on the vulnerability.
Or be careful of the service on the other side of your (I assume) reverse proxy, should it have a vulnerability you may still be in trouble depending on the setup of the reverse proxy and what it’s config is.
You are probably going to be ok unless someone really wants to hack you. The LastPass hack that exposed passwords of millions of people started from an open port in the home network of one of their engineers.
If you want to be somewhat safer, you could try something like the cloudflare tunnel thing to proxy your home network through their server.
Honestly depends on what he's hosting... Services like shodan are constantly scanning the web and are trying to see what is actually running in the machine.
If he's serving something that's vulnerable and has rce it won't take too long for him to get automatically pwned.
We've seen this with the hafnium Echange vulnerability and all known vulnerable public facing web apps that used log4j.
Regarding the LastPass breach, the second part of the breach was using a very outdated version of Plex. Chances are high that his home machine was already hacked by other malicious actors.
You should be fine. If you are using port forwarding the inbound traffic on that port should be sent only to the system you have designated. The only way that changes is if the system (rpi in this case) is operating as a reverse proxy. Even then net side should only see the proxy.
The biggest vulnerability would be the system that you are forwarding to, and if that system is a reverse proxy whatever the backend systems are. Make sure everything is fully updated/patched and that you trust the services that you are running and you should be good.
My only comment on your setup would be to make sure you fully understand what you are doing and more importantly, why. Cargo Culting is a bad way to admin. Good questions like yours are a good way to start.
I have no idea but am interested in answers.
I've only exposed ports briefly for testing and got scared.
I feel a little calmer using tailscale the past few months but still feels like putting a lot of faith in someone I don't really know I can trust.
I would suggest signing up for a free Cloudflare account and setting up any DNS for your Pi through there, using the Cache feature.
Once that is done, setup an automated script that will pull down Cloudflare IPs into a file (you can use a cronjob to run this daily):
#!/bin/bash
set -e
cf_ips() {
echo "# https://www.cloudflare.com/ips"
for type in v4 v6; do
echo "# IP$type"
curl -sL "https://www.cloudflare.com/ips-$type/" | sed "s|^|allow |g" | sed "s|\$|;|g"
echo
done
echo "# Generated at $(LC_ALL=C date)"
}
cf_ips > allow-cloudflare.conf
(cf_ips && echo "deny all; # deny all remaining ips") > allow-cloudflare-only.conf
Then in your web server config to only accept connections from Cloudflare IPs:
server {
listen 80 default_server;
listen [::]:80 default_server;
server_name example.com;
root /var/www/html;
include /etc/nginx/allow-cloudflare-only.conf;
}
I prefer this method over UFW/iptables block as it allows you to control the IP block per web config, so if needed, you can make exceptions by not adding the include /etc/nginx/allow-cloudflare-only.conf;
into that specific site's conf file.
And with Cloudflare you could also only open up port 443
, because Cloudflare will do HTTP ➡ HTTPS if you enable that in their settings.
It should be safe, as it just exposes the Raspberry Pi. Make sure you've configured fail2ban to also watch the logs of all your webapps and ban people that try to brute force them (for example, if you host your own Vaultwarden instance, fail2ban should be configured to watch the Vaultwarden log for authentication failures).
For web apps that only you need to access (i.e. they do not have to be exposed publicly), consider using a VPN to access them remotely, instead of exposing the apps publicly. Wireguard and Tailscale work well for this. Tailscale is built on top of Wireguard and makes it very easy to get up and running.
No
You could accidentally expose another device if the Pi and other devices all get dynamic IPs in your local network, you might want to set a fixed IP outside of the DHCP Server's range for dynamically assigned addresses for the Pi.
Forwarding a port only forwards traffic to the device you specify. Be prepared for plenty of port scans though. If you have internal system email set up your Fail2Ban will be sending you daily messages. I get 5 or 6 a day from automated port scans triggering Fail2Ban.
One additional step that has really improved my peace of mind is setting up IP block lists on my firewall. This will depend on what your goal is in allowing HTTP access, but in my case, I block all IPs and whitelist connections from our cell provider or our places of employment. There is zero chance that a legitimate connection will come from anywhere else. It has been months since I had a connection attemp in my Nginx logs that didn't come from a member of my household.
One additional step that has really improved my peace of mind is setting up IP block lists on my firewall. This will depend on what your goal is in allowing HTTP access, but in my case, I block all IPs and whitelist connections from our cell provider or our places of employment. There is zero chance that a legitimate connection will come from anywhere else. It has been months since I had a connection attemp in my Nginx logs that didn't come from a member of my household.
Port forwarding is to a specific IP only.
There are ways that someone could access other parts of your network though, if they managed to login to the Pi somehow.
If you run your webserver in a sandbox, that adds an extra layer of security. Something like docker, or a classic setup where you have a special user account with limited access, is good. So if the server gets owned, the damage is still contained
Random webservers online are still often attacked, so disabling all password based access is helpful. You may have to occasionally look at the connections log and ip ban some attempts
If you exploit a service running on Docker you can still use that to exploit other services running on the local network that are not directly exposed to the internet. Docker offers a layer between the service and the host it's running on, not the rest of your unsecured internal network where you have samba shares with one letter passwords.