I need to enable communication between the VXLANs and the Internet, so the first machine I will create is a pfsense firewall in Proxmox. I will connect the WAN interface to the external network and 2 other interfaces to the VXLANs. This will grant Internet access to the VXLANs, but force the traffic to flow through the firewall.
Creating the Virtual Machine
Prerequisite: Configure Software Defined Networking
The creation of a virtual machine in Proxmox is pretty straightforward. Since this is the first machine in the lab and the first one in this guide I will go into more detail in this post. The first step is to create the machine itself and name it. I configured it to start when the host boots so the VXLNAS have immediate Internet access.
data:image/s3,"s3://crabby-images/ef2ff/ef2ff49ecce98d96e1868765923065f0f4b8dddd" alt="View of create virtual machine showing pfsense name. First step in creating a firewall using pfsense in Proxmox."
Next I selected the pfsense ISO image and added it to the CD/DVD drive. I left the system settings default and gave the machine a 40 GB disk.
data:image/s3,"s3://crabby-images/b19a2/b19a2cb8374a49956b8d03b6133cbc34fc21bcff" alt="Selecting pfsense ISO as the operating system installer image."
data:image/s3,"s3://crabby-images/4dafd/4dafd0b8190f4b2034853877853c798a8e98e59b" alt="Leaving the system settings with default settings."
data:image/s3,"s3://crabby-images/3cb61/3cb610b0949603be7944d19dc7c05dadd562d86d" alt="Setting the disk size to 40GB for the pfsense firewall in Proxmox"
After configuring the disk size, I had to set the CPU and memory settings. I chose to use 1 socket with 2 cores for CPU, and gave the firewall 2048MB or 2GB of RAM.
data:image/s3,"s3://crabby-images/5d18f/5d18f076962e11a16b1cbc5ef1634d8c15dae9fc" alt="Configure the CPU to 1 socket with 2 cores in Proxmox"
data:image/s3,"s3://crabby-images/219d4/219d41639b451c6d765670b6ff7573e0ffe10042" alt="Setting RAM to 2048MB or 2GB in Proxmox"
Next I set the WAN interface to vmbr0 which is the external facing bridge on my host. Then I confirmed the settings to finish the initial configuration. Before booting I have to add the other 2 interfaces.
data:image/s3,"s3://crabby-images/09e0f/09e0f17aef19fb24853746f832b5f75cab87d57e" alt="Setting the WAN interface to vmbr0 in Proxmox"
data:image/s3,"s3://crabby-images/67bbd/67bbdcc1c779633a7a4eda4485494b44e1a4f227" alt="Screen to confirm settings prior to VM launch. "Start after created" is unchecked."
Before booting the machine I added the DMZ and LAN interfaces, selecting the appropriate Vnet for each bridge. I did not make the change here but recommend configuring the MTU to 1450 now in your setup. You can change it in the pfsense web console if you forget like I did.
data:image/s3,"s3://crabby-images/f076d/f076d975d7a85e417ca92dd9ee6bf86ab186d141" alt="LANnet and DMZnet interfaces added to pfsense."
Next, I boot up the machine and am greeted with the pfsense installer.
data:image/s3,"s3://crabby-images/efce8/efce807e31de5f2fa444cac3de8e5a401bd1189d" alt="pfsense installer screen after configuring the virtual machine"
Installing pfsense firewall in Proxmox
Installing pfsense on a virtual machine is also a straight forward process so I will skip the first few installer screens and list the options I selected below.
- Select Install
- Select the keyboard layout
- Select preferred partition method: I went with default
- Remaining disk options: again I stuck with default
- When you see a “Last Change!” ZFS configuration select yes to install
- Once the install is complete select “No” for manual configuration and reboot
After the installation is complete and pfsense reboots you should see a screen stating all links are up. Select no to set up VLANs now.
data:image/s3,"s3://crabby-images/c416f/c416fd80047da207e2c9e680fb26367289c4b86e" alt="Installer screen showing all interfaces up and asking to configure VLANs."
Configure the Interfaces
I set my pfsense interfaces to the appropriate Vnets:
- WAN = vtnet0
- LAN = vtnet1
- OPT1 = vtnet2
data:image/s3,"s3://crabby-images/2f837/2f837d8221e1591dbd18f6f5e3101ac8776b09c7" alt="Example interface configuration assigning the WAN, LAN, and OPT1 to the right virtual interfaces."
Next I had to configure the right IP addresses on the interfaces. I left WAN as DHCP, but used option 2 on the main screen to set the LAN and DMZ IPs to the right networks.
data:image/s3,"s3://crabby-images/3ddc8/3ddc88a3301de144cdf962f0a8ed3f6e3999722d" alt="Main screen after interface assignment showing WAN and LAN IPs. This requires a change."
After changing the LAN interface you will receive an IP address for the webConfigurator, in my case the is http://10.0.1.1. Before I switched to the web interface, I had to set the MTU to 1450 on my interfaces using the shell (option 8 from this screen) using the command below.
root: ifconfig vtnet1 inet 10.0.1.1 netmask 255.255.255.0 mtu 1450
root: ifconfig vtnet2 inet 10.10.1.1 netmask 255.255.255.0 mtu 1450
data:image/s3,"s3://crabby-images/3b474/3b474d3aa65c7399e6913063c5acb234dd2aafb7" alt="Set the interfaces for internal networks to mtu of 1450 using command ifconfig vtnet1 inet 10.0.1.1 netmask 255.255.255.0 mtu 1450"
With that my firewall install is complete and I can switch to the webConfigurator to configure the DMZ network. First, I need a machine to connect to the webConfigurator, which is the subject of the next post.
0 Comments
1 Pingback