Route based IPSec to mikrotik RouterOS7 with BGP
data:image/s3,"s3://crabby-images/7a6fa/7a6fae279b2c6a21c965dd4484961c86374cc960" alt="Route based IPSec to mikrotik RouterOS7 with BGP"
There are many instructions for miktrotik, but few that work. Precisely because a lot has changed with Router OS v7, I would like to show a few variants here:
- “simple” IPsec tunnels (I show later)
- Route-based IPSec tunnels with BGP
so lets start with the tricky:
I have 2 ISPs with 2 public IP-addresses, right. So to make the connection redundant we need also a routing protocol to make the paths automatic switching over when one way fails. In Azure we have to use BGP because there is just that option.
the WAN Plan
data:image/s3,"s3://crabby-images/7a6fa/7a6fae279b2c6a21c965dd4484961c86374cc960" alt=""
the Azure side
so I have 2 vNets because of 2 Subscriptions. Subscriptions are not connected by default, so I had to connect them by usng vNet-Peering. Then my vNet apo-vnet (192.168.104.0/22) and my second vNet infra-vnet (192.168.100.0/22) is connected and the apo-vnet is using and sharing the VPN-Gateway, so there is just one VPN-Gateway needed.
data:image/s3,"s3://crabby-images/f084c/f084c5369bfc2cf7ae5915c33d27813d5a2f8d7c" alt=""
data:image/s3,"s3://crabby-images/cfb00/cfb0061aaea21840003c11e1226b63157292e4e1" alt=""
data:image/s3,"s3://crabby-images/9e5a7/9e5a71329fe7b7c4162e57a48e8fd93d81f2ba59" alt=""
data:image/s3,"s3://crabby-images/173f1/173f1394313dbd8f593a224e50abe288f482f82a" alt=""
the VPN Gateway is a “normal VpnGw1 SKU which is for most of the use-cases fully enough. The BGP Feature is built in at no additional costs.
data:image/s3,"s3://crabby-images/8c0d7/8c0d7f9a8d06b1910920855880b9a2ba3cc5b65e" alt=""
data:image/s3,"s3://crabby-images/ffc84/ffc847aadb9c0a7cb36032c5f12fd71d47d5656a" alt=""
the mikrotik Side – aka On-Prem
TL;DR: the IPSec settings in the mikrotik RouterOS v7 – I am currently using 7.3.1:
Phase1: aes-256, sha1 or sha256, modp1024, lifetime 07:30:00 7h30=27000sec, just in my case NAT-Traversal because i am behind a NAT-Router so udp 500/4500 is usedfor the connection.
dead-peer-detection is set to 30sec, so maximum recognition is 5×30 = 150sec.
Phase2: aes256 cbc (only that is in hardware!), sha256, lifetime 07:30:00 and PFS modp1024.
other combinations may also work but are not tested.
data:image/s3,"s3://crabby-images/f0398/f0398ae544d917cc20c56342cdc2b5ff15c9af27" alt=""
data:image/s3,"s3://crabby-images/9c772/9c772cdf998e90af03df2943ff2708be777e0f05" alt=""
data:image/s3,"s3://crabby-images/4a59c/4a59c3d026154d2c8c2ba6599a231dbc7bdff255" alt=""
data:image/s3,"s3://crabby-images/c15b8/c15b8a22c4e6c55ad60a07c435f288d93a04f03f" alt=""
data:image/s3,"s3://crabby-images/0ddb1/0ddb1edaeef665723b018fa96537e04bd7752fe6" alt=""
data:image/s3,"s3://crabby-images/55649/55649c7482ec4f53b438782143a29801bff996e0" alt=""
data:image/s3,"s3://crabby-images/cea6a/cea6a07173320f35abde74128afefa5eea5b3071" alt=""
the BGP Routing part – On-Prem
because we are routing between loopback-Adresses which are always online, we are creating socalled loopback-Interfaces. Giving them a fixed non-overlapping IP-Address (192.168.254.2 and 192.168.254.4) and set a static route to the other side.
the route to the Azure BGP Peer (192.168.101.126) is not needed because the default route show the direction.
data:image/s3,"s3://crabby-images/5e1ab/5e1abd2ae56119eb78fb2c71a0e08b535b970cc5" alt=""
data:image/s3,"s3://crabby-images/1ad33/1ad33f85fdb900d2437d54dba7c1e164794b25ad" alt=""
done 😉
ask my on twitter… @sdenninger