I’ve setup up the new LAB, but now I need to create an environment for my testing otherwise I could have saved me the money and spent it on a subscription for Netflix/Disney+/Apple+/Amazon Prime (pick your favourite).
My environment will be using an on-prem Active Directory, consisting of
- Domain Controller (NLSOMDC01)
- an Azure AD Connect Server (NLSOMCC01) to ensure the environment is extended to Azure
- a 2-tier PKI infrastructure
- a Root CA (NLSOMCRT), that’s brought offline after the initial setup/configuration
- a Subordinate CA (NLSOMCA01) that will be issuing CA’s
- a Management Server with Windows Admin Center (NLSOMMG01)
To ensure this AD can communicate with Azure, I need to create a site-to-site IPSEC VPN Tunnel. For this I will install a pfSense Firewall (Community Edition) NLSOMFW01 .
Setting up the pfSense Firewall (Community Edition)
I defined a new VM (1 vCPU, 1GB RAM, 8GB HDD & 2 NICs) which is very limited, but as this is only used for the IPSec tunnel, The installer has been mounted so I start installing:
I read the copyright and distribution notice and click Accept
data:image/s3,"s3://crabby-images/9f73e/9f73e24f562851b49af47ba376196e25d7c4a8eb" alt=""
Out of the 3 options, the default one “Install” is the one I need, so I click OK.
data:image/s3,"s3://crabby-images/97bf1/97bf1d8b129a55c1708fddf5e655b3bdc72c21b2" alt=""
Again not much to do for me, US is a good-enough keyboard layout for me, so I click Select
data:image/s3,"s3://crabby-images/67fe3/67fe3a407363014505e7a0a6a7c37ef64c07f878" alt=""
I will use the guided disk setup “Auto (UFS)” and click OK after which the installation starts.
data:image/s3,"s3://crabby-images/95743/957433f00a7d3549f5e316c1dcbcc06cb0aadf5f" alt=""
The installation finishes quickly and I don’t need to make any manual modifications, so I click No
data:image/s3,"s3://crabby-images/650df/650df180f40b77f44bcc87814ff757a96615894b" alt=""
Now the VM needs a reboot
data:image/s3,"s3://crabby-images/9de94/9de946edb1302ddedc428fed07d2bf0b3e45557e" alt=""
After the reboot, the first thing I need to do is define the VLANs. For my Lab environment this is not needed, so I type n. Next action is to assign the network interfaces correctly to WAN/LAN. After that’s done, I’m sure to proceed, so I type y
data:image/s3,"s3://crabby-images/fe06a/fe06a6a265a5a51d03d1775b8034b3290aaed990" alt=""
Ok, next up assigning fixed IP addresses to my NICs. type 2.
data:image/s3,"s3://crabby-images/2a665/2a6656ce5c7e9fdd5dc10925ba1006f5bc1c972b" alt=""
First I will start with the WAN interface.
IPv4 | 192.168.2.17 |
Subnet mask (CIBR notation) | 24 |
IPv4 upstream gateway | 192.168.2.254 |
IPv6 via DHCP | y |
data:image/s3,"s3://crabby-images/d3890/d38900920c74caa07b16548828819b2752fd45a2" alt=""
Now up for the LAN Interface
IPv4 | 10.57.11.1 |
Subnet mask (CIBR notation) | 24 |
IPv4 upstream gateway | <ENTER> |
IPv6 via DHCP | y |
Now I can finish the configuration using the GUI. I logon using the default credentials (admin | pfsense)
data:image/s3,"s3://crabby-images/749a8/749a8ebf8b7b556382be23328eaa5686089f15be" alt=""
I immediately get a warning that the ‘admin’ password is using the default credentials, but first I will go through the initial configuration, so I click Next
data:image/s3,"s3://crabby-images/69d76/69d766c413a631cd1dbdcbb33248fcb614c8483e" alt=""
The pfSense setup wizard starts (9 steps). Step 1 of 9, click Next
data:image/s3,"s3://crabby-images/56a7e/56a7e8d5d95dd63300705099491ea885c993beeb" alt=""
Step 2 of 9, provided the following information and clicked Next
Hostname | NLSOMFW01 |
Domain | lab.damen-online.nl |
Primary DNS Server | 192.168.2.254 |
Secondary DNS Server | 1.1.1.1 |
data:image/s3,"s3://crabby-images/fb163/fb163bb0ee63522a57302afaa45b9dbc909b0068" alt=""
I use the same timeserver (0.nl.pool.ntp.org)as I did before and set the correct timezone (Europe/Amsterdam), again Next
data:image/s3,"s3://crabby-images/22d5f/22d5f73fc7a3dd9175cb9548112596d964b1411d" alt=""
The next step is actually already correct, so I click Next
data:image/s3,"s3://crabby-images/5c30d/5c30d341154bdb64ebbca2540380f8965cc62b6d" alt=""
Same goes for the LAN interface, so again Next
data:image/s3,"s3://crabby-images/60fe1/60fe16adfce41e09ce721eeaaba93dd709d36ec0" alt=""
Now I can set the new admin password, which I do and click Next
data:image/s3,"s3://crabby-images/65fa4/65fa4335fa71400861fb56ffb8356437860b961b" alt=""
Now I need to reload the configuration
data:image/s3,"s3://crabby-images/2a25e/2a25e4274a8a351d0aeab65dd35693c723079088" alt=""
and after that the initial configuration has been finished, click Finish, and I can start configuring the Site-to-site connection
data:image/s3,"s3://crabby-images/ffb7c/ffb7cbd9f304176f3cfa9ccdb7d88b7194c9ff2b" alt=""
Site-to-site connection
One of the IP of the pfSense firewall assigned is in my isolated subnet, but I ensured there is a Subnet IP (192.168.2.17) in my private network. As I have the router from my ISP provider in front I needed to ensure that UDP 500 / 4500 is also being forwarded to this IP.
data:image/s3,"s3://crabby-images/54d80/54d80be0b25e7f53f6ad03a0f95d72f732c09e03" alt=""
Virtual Network
Now I need to setup the Azure side of the Site-to-site VPN Gateway connection. For this I logon to the Azure portal and select Create a resource in the menu
data:image/s3,"s3://crabby-images/8aec3/8aec3d7d1296dc5978d21d10899259561a8da2ad" alt=""
I search for Virtual Network and click Create
data:image/s3,"s3://crabby-images/9d13f/9d13ff8a620cab82b763db06346ec6c7ccf73c4f" alt=""
I provide the following information to define my “personal” network in Azure and click Create
Name | vLAB |
Address Space | 10.10.12.0/23 |
Subscription | Microsoft Partner Network |
Resource Group | (New) LABRG |
Location | (Europe) West Europe |
Subnet Name | AzureLAB |
Subnet Address Range | 10.10.13.0/24 |
data:image/s3,"s3://crabby-images/35856/35856b89038bb6aab9ab4e8fdd96ef4578bf00a0" alt=""
VPN Gateway
Now I need to create the VPN Gateway so I select Create a resource in the menu again and search for Virtual Network Gateway and click Create
data:image/s3,"s3://crabby-images/76d0f/76d0f4c07510416105e735a38b120fb7a619c0d6" alt=""
Again a lot of information needs to be provided to the VPN Gateway can be defined and click Review + Create. This can take some time (up to 45 minutes).
Subscription | Microsoft Partner Network |
Resource Group | LABRG |
Instance Name | vLABGW |
Region | (Europe) West Europe |
Gateway type | VPN |
VPN type | Route-Based |
SKU | VpnGw1 |
Generation | Generation1 |
Virtual Network | vLAB |
Gateway subnet address range | 10.10.12.0/24 |
Public IP address | Create new |
Public IP address name | vLABGWPublicIP |
data:image/s3,"s3://crabby-images/49cd1/49cd1577b0926ed5a5a396ef5a51979e51816bca" alt=""
Local Network Gateway
Now I can create the local network gateway, which defines my on-premises network. So again back to the menu, search for Local Network Gateway and select Create
data:image/s3,"s3://crabby-images/8e03b/8e03b2deb6244412db2f5ce051910ac3dc19f7ec" alt=""
Here we need to provide a descriptive name,the public IP address of my internet connection and the address space that are part of the local network.
Name | NLSOM |
IP address | Public IP of my internet connection |
Address Space | 10.57.11.0/24 (internal subnet) |
data:image/s3,"s3://crabby-images/3df8f/3df8fc5b5f70f94be936a0f570b79a5ddbc17daa" alt=""
Now I create the VPN connection. For this I open the Virtual Network Gateway I’ve created earlier and addd a new connection.
data:image/s3,"s3://crabby-images/8a971/8a971d4919946edb45cd454231cf10c38fab994e" alt=""
Again I need to provide a couple of variables to setup the VPN connection
Name | Azure-NLSOM |
Connection type | Site-to-site (IPSec) |
Virtual network gateway | vLABGW |
Local network gateway | NLSOM |
Shared key (PSK) | <private shared key> |
IKE Protocol | IKEv2 |
data:image/s3,"s3://crabby-images/ebd6c/ebd6cd5da691469a0d3aa9879d14033eddadbe21" alt=""
pfSense
Back to the pfSense firewall, where I select VPN, IPsec
data:image/s3,"s3://crabby-images/c3af4/c3af40ff5672059566a830b73d970f6cd3994977" alt=""
As I need to create a Site-to-Site VPN Tunnel, I will click +Add P1
data:image/s3,"s3://crabby-images/bb029/bb02902a1f07424485c40caaac24fed85a77b2c0" alt=""
Now I can configure the first phase (P1) of the tunnel. I provide the following information and hit Save
Key Exchange version | Auto |
Interface | WAN |
Remote Gateway | <vLABGWPublicIP> |
Description | Site-to-Site VPN NLSOM – Azure |
Authentication Method | Mutual PSK |
My identifier | Public IP address of my internet connection, as the pfSense VM is behind my router |
Peer identifier | Peer IP address |
Pre-Shared Key | <private shared key> |
Encrytpion Algorithm | AES – 256 bits – SHA256 – 2 (1024 bit) |
data:image/s3,"s3://crabby-images/eb59e/eb59e011e9ebc5c0a710d39ba610636da33687d3" alt=""
Now I can configure phase 2 (P2) of the tunnel, by clicking + Add P2
data:image/s3,"s3://crabby-images/9dbda/9dbdaaf76ddda46b69c8a2c0580d961ef3e7ceb2" alt=""
Adding the last piece of information for my tunnel to work.
Remote Network | 10.10.12.0/24 |
Description | Phase 2 NLSOM – Azure |
Protocol | ESP |
Encryption Algorithm | AES – 256 bits |
Hash Algorithm | SHA1 |
data:image/s3,"s3://crabby-images/ab802/ab802b25d73bfcb7dc435a208924415562cea6e3" alt=""
After clicking Save I’m redirected back to the Tunnels page. Click Apply Changes
data:image/s3,"s3://crabby-images/f940a/f940a3be19247be3d759efa179eea17fdde1e1a1" alt=""
Now I switch to the Status page of IPsec to check the status of the tunnel
data:image/s3,"s3://crabby-images/07d3c/07d3c135c580ab4d061a288e479bba4f8582eb74" alt=""
And my tunnel is up-and running
data:image/s3,"s3://crabby-images/1e388/1e388e6578b5bdc69af9cee564c989d80dd9ac04" alt=""
This finishes up the Site-to-Site VPN connection, so now I can sync my on-premises Active Directory to Azure AD.