微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决具有 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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?