具有 Strongswan、DNS 服务器、重叠子网的站点到站点 VPN

问题描述

我需要创建一个带有远程 VPC (IKEv2 + IPSec) 的 site-to-site VPN。双方都使用对方的一些 Web 资源,这些服务主机名使用 DNS 服务器(每侧一个)映射到 IP。 A面使用Fortigate,B面使用StrongSwan

网络如下所示,其中Side B可以访问subnets A1,A2,A3,而Side A可以访问subnet B

setup 1

这是我在 B 面使用的配置

/etc/ipsec.config

conn %default
  keyexchange=ikev2
  mobike=no
  authby=psk

conn sideA
  left=%defaultroute
  leftid=GATEWAY_B_PUBLIC_IP
  leftsubnet=subnet_B
  right=GATEWAY_A_PUBLIC_IP
  rightid=GATEWAY_A_PRIVATE_IP
  rightsubnet=subnet_A1,subnet_A2,subnet_A3
  type=tunnel
  auto=start

问题是 subnet A4subnet B 重叠,因此此配置不起作用。 VPN Gateway B 是运行 Ubuntu 20 的虚拟机,因此可以进行自定义

解决方法

解决方案

我已按照以下说明更改了 ipsec.conf

conn %default
  keyexchange=ikev2
  mobike=no
  authby=psk

conn sideA
  left=%defaultroute
  leftid=GATEWAY_B_PUBLIC_IP
  leftsubnet=VIRTUAL_SUBNET_B
  right=GATEWAY_A_PUBLIC_IP
  rightid=GATEWAY_A_PRIVATE_IP
  rightsubnet=SUBNET_A1,SUBNET_A2,SUBNET_A3
  type=tunnel
  auto=start

其中 VIRTUAL_SUBNET_B 是与左侧或右侧都不重叠的虚拟子网。

并创建了以下NAT规则:

iptables -t nat -A PREROUTING -s SUBNET_Ax -d VIRTUAL_SUBNET_B -j NETMAP --to SUBNET_B
iptables -t nat -A POSTROUTING -s SUBNET_B -d SUBNET_Ax -j NETMAP --to VIRTUAL_SUBNET_B

/etc/sysctl.conf 中添加以下几行

net.ipv4.ip_forward = 1
net.ipv4.conf.all.rp_filter = 2
net.ipv4.conf.default.rp_filter = 2

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...