AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1061246
Accepted
Martin Melka
Martin Melka
Asked: 2021-04-23 11:16:39 +0800 CST2021-04-23 11:16:39 +0800 CST 2021-04-23 11:16:39 +0800 CST

使用 OpenVPN 通过 VPN 网关路由子网

  • 772

我工作的一家小公司很快就要摆脱办公室了,我不得不将当前本地托管的 VPN(只是一个 Zyxel Zywall 110 设备)迁移到基于云的 VM 中。我在网络(后端开发转向操作)方面没有那么丰富的经验,所以我想验证以下方法是否可行。


我有一个专用的虚拟机,我在其中设置了 OpenVPN 访问服务器,基础运行良好,人们可以连接,一切都很好。

但是有一个问题,当前的 VPN 通过“隧道”将某个 IP 范围转发到合作伙伴公司的内部网络。它看起来像这样:

if dest_addr in '172.30.239.0/25':
    route through gw 194.xxx.xxx.xxx
else:
    route through gw 0.0.0.0

例如,当连接到 VPN 时,我的流量将按如下方式路由:

dest 1.2.3.4       => me -> VPN server -> its internet gateway -*-> 1.2.3.4
dest 172.30.239.10 => me -> VPN server -> partner network gateway (194.xxx.xxx.xxx) -(internal network routing)-> 172.30.239.10

从我们的路由器到合作伙伴公司的 VPN GW 的连接是通过带有预共享密钥的 IKEv1 完成的(从路由器的 Web UI 判断,因为这就是我拥有的所有“文档”)。

一些描述以下设置的 ascii 艺术作品。我正在用Router虚拟机替换。

            +-----------------+           [     Partner infra, this has to stay the same     ]
            | Router          |           194.xxx.xxx.xxx            e.g. 172.30.239.75
            | --------------- |   IKEv1   +-------------+       +-------------------------+
User -----> | 172.30.239.0/25-| --------> | VPN gateway |-----> | Internal network server |
            |     default     |           +-------------+       +-------------------------+
            |        |        |
            +--------+--------+
                     |
                     |
                 internet

OpenVPN 访问服务器本身不支持这样的东西(或者我无法找到该配置),所以我认为我可以在 VM 级别上做到这一点。如果我使用 Strongswan 之类的东西将操作系统连接到 VPN 网关并配置适当的路由iptables,这可以工作吗?连接到 OpenVPN 服务器并进入该172.30.239.0/25范围的用户的流量会被路由到 Strongswan 的连接,还是这种方法根本上是错误的?我有哪些选择?

谢谢!

vpn routing openvpn
  • 2 2 个回答
  • 3963 Views

2 个回答

  • Voted
  1. Best Answer
    Martin
    2021-04-27T05:15:38+08:002021-04-27T05:15:38+08:00

    现在事情有点清楚了。当然,OpenVPN 有一个选项可以解决您的问题:如果您希望 VPN 客户端通过您的 VPN 隧道路由网络 1.2.3.0/25 的流量,请使用选项push(源):

    --push option
        Push a config file option back to the client for remote execution. Note that
     option must be enclosed in double quotes (""). The client must specify --pull in
     its config file. The set of options which can be pushed is limited by both
     feasibility and security. Some options such as those which would execute scripts
     are banned, since they would effectively allow a compromised server to execute
     arbitrary code on the client. Other options such as TLS or MTU parameters cannot
     be pushed because the client needs to know them before the connection to the
     server can be initiated. 
    

    因此,您必须添加您的 openvpn 服务器配置

    push "route 1.2.3.0 255.255.255.128"
    

    这告诉 openvpn 客户端,它应该通过 vpn 隧道将所有流量路由到该子网。而且,当然,在服务器本身上,正确的路由也必须到位 - 但我想这条路由可能已经到位。

    [更新]
    我的回答缺少一些关于路由的基本信息。任何网络设备都可以充当网关——这就是家庭路由器的作用。路由不做用iptables——那是修改linux内置内核防火墙的工具。路由决策是在路由表的帮助下完成的(为了简单起见,我在这里只讨论 IPv4)。对于正在发送的每个 IP 数据包,都会考虑路由表,从仅主机路由(/32 子网)开始,采用它可以找到的最“精确”的路由。因此,仅在没有找到具有更“精确”子网的匹配路由时才采用默认路由( /0 子网)。

    通过 VPN 隧道路由所有流量很容易。OpenVPN 使用该redirect-gateway指令。因此,要么将该指令放入所有客户端配置中,要么放入一个

    push "redirect-gateway def1"
    

    进入您的服务器配置。使用选项 def1,将使用两个具有 128.0.0.0 子网的路由,而不是一个 0.0.0.0 子网路由 - 这样做是为了避免新的默认路由被 DHCP 客户端覆盖。

    来到你的服务器上的路线。由于服务器是 IPSec 隧道的端点(连接到您的合作伙伴),因此软件(strongswan?)已经在该服务器上安装了必要的路由,以便远程网络的流量通过 IPSec 隧道进行路由。

    让我用示例网络和路线画一张图,以便更好地理解。考虑以下网络:

    A ---------- B -------- C --------- D
    
    • A 是一个 IP 为 10.8.0.2 的 OpenVPN 客户端
    • B 是 IP 为 10.8.0.1 和 172.16.0.1 的 OpenVPN 服务器
    • C 是您合作伙伴网络内的远程 IPSec 端点,IP 为 172.16.0.2 和 192.168.0.1
    • D 是合作伙伴网络内的网络设备,IP 为 192.168.0.10

    在此示例设置中,您有三个网络:

    • OpenVPN 网络
    • IPSec 网络
    • 合作伙伴网络

    设备A有路由:0.0.0.0/0 gw 10.8.0.1
    服务器B有两条路由:一条默认网关到ISP,192.168.0.0/24 gw 172.16.0.2
    服务器C有两条路由:一条默认网关到伙伴的ISP,和:10.8.0.0/24 gw 172.16.0.1
    对于设备D,只0.0.0.0/0 gw 192.168.0.1需要默认路由。

    • 1
  2. NerdUno
    2022-06-26T05:36:01+08:002022-06-26T05:36:01+08:00

    以下是我们仅通过 OpenVPN 隧道路由 OpenVPN 子网的方法:

    pull-filter ignore redirect-gateway
    route-nopull
    route 10.8.0.0 255.255.255.0
    
    • 0

相关问题

  • 无法通过 Ubuntu VPN 访问外部网络

  • 用 D-LINK DFL-CPG310 防火墙替换 Cisco Pix 防火墙

  • 最好的点对点 VPN?

  • WAN 上的 VLAN

  • 通过 VPN 连接什么是远程服务器 IP?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve