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 / 问题 / 888097
Accepted
RogerFC
RogerFC
Asked: 2017-12-15 02:33:30 +0800 CST2017-12-15 02:33:30 +0800 CST 2017-12-15 02:33:30 +0800 CST

AWS OpenVPN 多 VPC + ClassicLink 上的路由

  • 772

我在 AWS 中设置的多区域网络中的服务器之间连接时遇到问题,因为并非所有服务器都可以从网络中的任何点访问。

我通过 openvpn 隧道将 eu-central-1 中的 VPC (A) 连接到 eu-southeast-1 中的另一个 (B),第二个 VPC 通过 ClassicLink 连接到 EC2-Classic (EC2) 节点。此连接是通过几个对等服务器建立的,VPC A 中的对等服务器 A 和 VPC B 中的对等服务器 b。用户通过 openvpn 连接到 VPC A,并通过 openvpn 服务器 vpnserver-a。

网络图是这样的:

+---------+   +---------+   +---------+   +----+
|user     |   |VPC A    |   |VPC B    |   |EC2 |
|172.20/16+---+172.29/16+---+172.31/16+---+10/8|
+---------+   +---------+   +---------+   +----+
           VPN           VPN       ClassicLink

问题是我无法建立任何这样的联系:

  • 用户到 EC2 中的任何节点
  • VPC A 中的任何节点到 EC2 中的任何节点
  • EC2 中的任何节点到 VPC A 中的任何节点

从用户到 VPC A 和 B 以及 VPC A 和 B 之间的连接工作正常。

我怀疑路由有问题,但我一直无法解决。

路由设置如下:

  • vpnserver-a 向用户发布路由 172.29/16、172.31/16 和 10/8(openvpn 配置文件)
  • peering-a 将路由 172.31/16 和 10/8 发布到 VPC A(openvpn 配置文件)
  • peering-b 将路由 172.29/16 和 172.20/16 发布到 VPC B(openvpn 配置文件)
  • VPC A 中的路由表将 172.31/16 和 10/8 路由到对等互连-a(AWS VPC 子网路由表)
  • VPC B 中的路由表将 172.29/16 和 172.20/16 路由到 peering-b(AWS VPC 子网路由表)

网络 ACL 对这些子网之间的所有流量开放。安全组也设置为接受连接。

我使用 tcpdump 进行了一些(基本)数据包检查,以尝试了解路由是否适用于以下结果: - 尝试从 VPC A 中的 node-a 连接到 EC2 中的 node-ec2,我可以看到数据包通过 peering-a和 peering-b,但没有到达 node-ec2 - 尝试从 node-ec2 连接到 node-a,我什至看不到到达 peering-b 的数据包

所以我怀疑 ClassicLink 中的路由涉及我不知道的其他配置。

如何设置丢失的路线?这甚至可能吗?

谢谢!

amazon-web-services
  • 1 1 个回答
  • 530 Views

1 个回答

  • Voted
  1. Best Answer
    Michael - sqlbot
    2017-12-15T07:45:23+08:002017-12-15T07:45:23+08:00

    ClassicLink 不支持访问 VPC 之外的任何内容。

    您注意到没有适用于来自ClassicLink 的流量的路由表——从那里返回到此 VPC 中您的实例的路由是隐式的,因此无法将外部流量传送回您的“对等-b”实例。

    严格来说,下面并没有具体说它不行,因为他们所指的VPN连接是VPC的Hardware VPN服务提供的VPN连接,而不是你用自己的实例设计的连接......

    ClassicLink 不支持 VPC 外的传递关系。您的链接 EC2-Classic 实例将无法访问与 VPC 关联的任何 VPN 连接、VPC 终端节点或 Internet 网关。同样,VPN 连接另一端的资源或 Internet 网关将无法访问链接的 EC2-Classic 实例。

    http://docs.aws.amazon.com/AWSEC2/latest/UserGuide/vpc-classiclink.html#classiclink-limitations

    ...但是,影响是存在的,而且 ClassicLink 机器没有可配置的 VPC 路由表来处理其流向 VPC 的流量这一事实意味着您在技术上甚至没有办法尝试配置您的 VPC 工作这种情况需要的方式。

    • 1

相关问题

  • 与 AWS 中的其他系统相比,CentOS 报告的总内存较低

  • 如何在 Amazon Linux 服务器上升级到 Java 1.8?

  • 了解 Amazon AWS 使用数据

  • 亚马逊提供的负载均衡服务体验如何?

  • ELB 中现有节点的 AWS 自动缩放问题

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