My home network is rather unconventional. It is somewhat complicated, because I run my server as a firewall and my family has lots of devices to connect to it. I've chosen to make it much more complicated than most home networks, because I want to provide a level of security that protects my devices from rogue Apple and Google products. I also want to protect my server's management interface, and I don't want my virtual machines accessing anything but each other on the network.
Originally, this was just going to be more of an internal reference, but maybe my setup will be useful for someone else too. In this post, I'll document the way my home network is set up. I won't explain why I've done things the way I have too much, this is just to show how they are set up.
First of all, my firewall runs OpenBSD. It is an HP ProLiant DL380P, with 9 gigabit network interfaces---4 are on the motherboard, and 5 are provided via 3 PCI cards connected to the riser board. This handy diagram details how they are physically arranged, and how OpenBSD identifies them:
bge4
em0 em1
em2 em3
bge3 bge2 bge1 bge0
I figured this out by repeatedly looking at the output of ifconfig(8) while plugging a switch into one port at a time, and seeing which one got a link. Here's what the physical ports are being used for:
[bge3] The egress port; this is connected to the broadband
modem.
[bge2] The physical LAN for devices out of my control. My
family has a WiFi access point connected here.
[bge0] This HP server has a dedicated iLO port. I run a
patch cable from that port into this one, so I can access
iLO without having to physically connect to it each time.
[bge4] I run Proxmox for testing and staging. My Proxmox
machine is connected directly to this interface.
[em1] My personal computers are hooked up to a switch that
runs into this interface.
I have a 24-port switch that I used to have everything on, including iLO and Proxmox, but I wanted to provide a little more security for servers such as iLO and Proxmox that don't need to be accessed by my family. I want my OpenBSD firewall to sit between everything on my network, which is why I've added so many network interfaces to my server.
So that is the physical setup. I also have a few virtual network interfaces:
[vether0] Used to route traffic from my virtual machines
running on the server itself through vmd(8). This is connected
to a virtual switch, bridge0.
[enc0] Used to route VPN traffic. iked(8) automatically
encapsulates traffic sent to and from this interface, so
even though VPN traffic is encrypted when it arrives and
leaves the firewall, pf(4) can filter it when it is
unencrypted.
I'm giving each interface a 10.x.0.0/16 subnet, where x is just an arbitrary counter starting at 0. I previously made the mistake of using a different private network for each interface, and I'd allocate the entire range to it, which meant a lot of addresses were wasted and things were rather messy. But now, everything resides in 10.0.0.0/8, each interface just gets a different subnet. So here's how the addresses are allocated:
[10.0.0.0/16] The physical LAN that my family uses with
their WiFi access point. dhcpd(8) serves this range.
[10.1.0.0/16] Used for the VPN. iked(8) manages the address
allocation within this range.
[10.2.0.0/16] Proxmox uses this subnet. Proxmox works in
bridge mode by default, so all virtual machines are connected
as if they were physically attached to the same switch as
the Proxmox host. This allows me to use dhcpd(8) on the
firewall to issue addresses within this range.
[10.3.0.0/16] The virtual machines on the firewall use this
subnet. It is serviced by dhcpd(8).
[10.4.0.0/16] A physical LAN for my own personal devices
that are isolated from the rest of the network. This allows
me to securely use FTP to my server and other plain-text
protocols without leaking data to the rest of the network.
Only devices I trust (otherwise known as only devices that
run OpenBSD) are allowed on this network.
[10.254.254.0/30] iLO is set up to use a static IP address
and netmask. I gave it a subnet that is big enough for
exactly two hosts, and made sure it was well out of the way
of everything else. The firewall gets 10.254.254.1, and iLO
has 10.254.254.2. In the event that the firewall becomes
unavailable and I need access to iLO, I can simply unplug
the patch cable that connects the iLO port to bge0, and
plug in a laptop configured with a static IP and netmask.
Everything I need to make this network setup work is available in OpenBSD:
hostname.if(5), dhcpd(8), unbound(8), pf.conf(5)
To make things a bit nicer, I'll also be using these:
relayd(8), tftpd(8)
The virtual machines that run on the firewall utilize these:
mountd(8), nfsd(8), portmap(8), vmd(8)
So there are a lot of things to configure here. At some point, I'll write a script to automate the setup of all of this, but until then, everything is configured and managed by hand.
I'm not going to document exactly how all of this translates into OpenBSD configuration files—that job is best left to the man pages, which are very thorough and detailed. This is more of just a reference for me if I ever get confused as to what's where on my home network.