我有一个连接到 1 个接口的服务器tap0
。还有一个具有 2 个接口的客户端,这些接口具有公共 Internet 连接(eth1
和eth2
)以及接口 2 的隧道,因此我可以通过 发送流量,tap0
并且实际上将通过 发送数据eth2
。
如果我做
curl ifconfig.co
我得到了eth1
. 如果我做
curl ifconfig.co --interface eth2
我得到了 的公共 IP eth2
,如果我得到了
curl ifconfig.co --interface tap0
我得到了服务器的公共 IP(它通过了隧道,所以一切都很好)。
tap0
在192.168.0.0/24
子网中(其他的是192.168.1.0/24
and 192.168.3.0/24
,所以这里没有冲突),我可以正确连接到192.168.0.1
, 192.168.0.22
(这是服务器本地 IP)等。
我已经在服务器路由器 ( 192.168.0.1
) 中为我需要的机器端口192.168.0.22
(iperf3、80、OpenVPN 等)设置了重定向。
简而言之,我认为到目前为止我的一切工作正常。
当我想连接到服务器公共 IP 时,问题就来了。假设公共 IP1.2.3.4
通过 VPN。如果我做
curl 1.2.3.4
当连接通过服务器路由器时,我得到了我需要的所有信息,eth1
服务器路由器将其重定向到服务器所在的本地计算机。但如果我这样做
curl 1.2.3.4 --interface tap0
什么都没发生!
使用 tcpdump检查客户端tap0
我可以看到创建了一个请求
但是该请求永远不会到达服务器上(检查了服务器上的 eth0 是否有传入的 OpenVPN UDP 数据包,并且在客户端中创建此数据包时没有新数据包到达)。当从客户端连接到其他任何东西时,这在服务器上:
这变成了一个解密的数据包,不用说当那里没有出现 UDP 数据包时,没有解密的数据包出现。tap0
tap0
eth0
tap0
tap0
我不知道这里发生了什么。我以为tap0
在客户端通过的所有数据包都会毫无限制地发送到服务器,但事实并非如此。
另外,如果我去服务器机器192.168.0.22
对公共 IP 进行 curl,我会连接回 Web 服务器并且 curl 接收结果,因此服务器连接到自身不会有问题。
我该怎么做才能使与我的服务器公共 IP 的连接在发送时有效tap0
?