1

我已经做了一些关于 NAT 穿越的研究,并从网上得到了一些关于 P2P 应用程序的建议。但我的情况与一个传统的 P2P 应用程序有些不同。我已经有一个公共服务器,我只需要从已知的公共服务器访问 NAT 后面的设备。

关于我的案例的详细信息如下:

1.PC-A have public IP
2.PC-B is behind NAT, does not have public IP. In my case PC-A and PC-B is under full control.
3.PC-C is also behind NAT, and could be reached from PC-B

问题是:

  1. 有什么办法可以在公共服务器 PC-A 和 PC-B 之间建立一条隧道,以便我可以使用 TCP 协议(​​甚至 UDP)从 PC-A 到达 PC-C?
  2. 值得注意的是,一切都应该以编程方式完成,尤其是在 Java 中。是否有任何库可以做到这一点?
4

1 回答 1

0

您的 PC-A 在 P2P 通话中通常被称为“中继”。

基本原则是防火墙后面的所有对等方(在您的情况下为 PC-B 和 PC-C)建立到 PC-A 的出站连接。PC-A 然后“链接/绑定”这些连接。通常这些连接是通过对防火墙友好的 HTTP 进行的。所以对于 PC-B 和 PC-C 对话,一个简化的序列是:

  • PC-B 和 PC-C 都建立到 PC-A 的 HTTP 连接
  • PC-B 向 PC-A 发出信号,表示它想向 PC-C 发送数据
  • PC-B 根据出站请求将其数据发送到 PC-A
  • PC-A 在同步响应中将数据转发给 PC-C。

当你投入时,事情变得(非常)复杂

  • 验证
  • 安全
  • 冗余继电器
  • 连接超时、可靠性、恢复等...

大多数 P2P 框架都实现了某种中继。JXTA 和 XMPP 就是这种情况(检查 ICE)。

我相信 Ian Mc Ginniss 还开发了一种称为 HTTP Tunnel 的东西,作为 Netty 项目的一部分(最初是作为 JXTA 中继的替代品,这在某种程度上是次优的)

于 2012-08-27T14:12:22.053 回答