Bobcares

How to Configure BGP over IPsec from pfSense to AWS

by | Sep 1, 2024

Learn how to configure BGP over IPsec from pfSense to AWS. Our pfSense Support team is here to help you with your questions and concerns.

How to Configure BGP over IPsec from pfSense to AWS

Did you know that configuring Border Gateway Protocol over IPsec from a pfSense firewall to AWS involves several steps to set up a secure and efficient connection between the local network and AWS?

An Overview:

Step 1: Configure BGP on pfSense

  1. If we already have a BGP setup, we can view the current BGP status by going to Services > FRR BGP > Status.
  2. Also, in the BGP routing table, we will see the LAN route and routes learned from ASN 64515.
  3. So, make sure that the desired LAN networks are being advertised through BGP.
  4. Then, add two BGP peers for the AWS tunnels. So, go to Services > FRR BGP > Neighbors, then click Add.
  5. Next, it is time to configure BGP peering for the First Tunnel. So, enter the details from the AWS configuration file:
    • Customer Gateway ASN: `65000`
    • Virtual Private Gateway ASN: `62351`
    • Neighbor IP Address: `158.254.202.87`
    • Neighbor Hold Time: `30`
  6. Also, enter the neighbor IP address, add a description, set the Remote AS to AWS’s ASN (`62351`), and set the Update Source to `Ipv4`.
  7. Then, apply the route map for inbound and outbound traffic and click Save.
  8. Now, it is time to configure BGP peering for the Second Tunnel. So, we can follow the same steps as the first tunnel, but use the details for the second AWS tunnel:
    • Customer Gateway ASN: `65000`
    • Virtual Private Gateway ASN: `62351`
    • Neighbor IP Address: `158.254.202 25`
    • Neighbor Hold Time: `30`

    Repeat the configuration steps and make sure the route map allows the routes from the second neighbor.

  9. Then, click Save.

Step 2: Validate BGP and IPsec Configuration

  1. Now, check the BGP Status on pfSense. So, go to Status > FRR > BGP.
  2. Then, verify that new routes toward the AWS subnet are being learned. The route with the lowest metric will be chosen, indicated by the “>” symbol.
  3. Now, log in to the AWS console and go to “Site-to-Site VPN Connections”. Select the VPN connection and check that the status is Up.
  4. Next, verify the number of routes learned under the tunnel details.
  5. Then, go to VPC > Routing Table > Routes and ensure all the routes propagated from the VPN gateway are visible and marked as propagated.
  6. Next, test connectivity from an EC2 instance in AWS. For example:

    [ec2-user@ip-172-31-15-103 ~]$ ping 1.1.1.1 -c 2
    [ec2-user@ip-172-31-15-103 ~]$ traceroute 1.1.1.1

  7. Finally, confirm the traffic is taking the expected path.

Step 3: Simulate Failover and Validate Redundancy

  1. Block access to the public IP of the active AWS tunnel to simulate an outage. The tunnel should go down within a few seconds.
  2. Also, check the routing table to ensure it has been updated to use the secondary tunnel for traffic to AWS.
  3. Then, run a traceroute again to confirm the traffic is now using the standby path:

    [ec2-user@ip-172-31-15-103 ~]$ traceroute 1.1.1.1

Step 4: Configure HA IPsec VPN with BGP Dynamic Routing

  1. On both pfSense firewalls, create two IPsec Site-to-Site VPNs with Routed IPsec (VTI). Configure Phase 1 for both VPNs on each site.
  2. Now, use Mode Routed (VTI) and create a transit network with a `/30` subnet mask.
  3. Then, go to Interfaces > Assignments and assign and enable the new IPsec interfaces. The IP should be automatically assigned.
  4. Also, ensure firewall rules are in place to allow traffic between remote and local sites through the IPsec tunnel.

Step 5: Install and Configure FRR Package

  1. Go to System > Package Manager > Available Packages and search for `bgp` or `frr`. Install the package on both the master and slave servers.
  2. Then, go to Services > FRR Global/Zebra Configuration and add a route map to allow exchanging all routes with the peer.
  3. Next, go to Services > FRR BGP and configure the BGP protocol for each site. Set the internal IP from the LAN interface as the router IP.

Step 6: Configure BGP Neighbors

  1. First, go to Neighbors and create a neighbor called BGP. Set both inbound and outbound route map filters to ALLOW-ALL.
  2. Then, add the neighbors and use the peer group BGP configuration.
  3. Next, go to Services > FRR > Status > BGP and validate the settings in the BGP table.
  4. Finally, verify the advertised routes from the other peer under Diagnostics > Routes.

[Need assistance with a different issue? Our team is available 24/7.]

Conclusion

With the above steps, we will have a robust BGP configuration over IPsec between the pfSense firewall and AWS, ensuring secure and efficient routing with redundancy and failover capabilities.

In brief, our Support Experts demonstrated how to configure BGP over IPsec from pfSense to AWS.

0 Comments

Submit a Comment

Your email address will not be published. Required fields are marked *

Never again lose customers to poor
server speed! Let us help you.