Home

Awesome

gnb_udp_over_tcp

GNB是一个开源的去中心化的具有极致内网穿透能力的通过P2P进行三层网络交换的VPN。

GNB节点间通过UDP协议传输数据,在一些网络环境下的路由器/防火墙会对UDP分组实施QOS策略,因此通过tcp链路转发GNB数据是不需要改动GNB通讯协议又可以提升GNB网络适应能力的一个办法。

gnb_udp_over_tcp 是一个为GNB开发的通过tcp链路中转UDP分组转发的服务。

通过 gnb_udp_over_tcp 中继 GNB 数据

演示环境

远端GNB节点 ip地址 为 192.168.1.25 GNB UDP 端口 9025 GNB TUN ip 10.1.0.25 远端 GNB 配置文件不需要调整

中继服务器 ip地址为 192.168.1.11

[gnb_1010]
    |
   udp 
    |
[udp_over_tcp udp:127.0.0.1:5001]    (./gnb_udp_over_tcp -u -l 5001 192.168.1.11 6000)
    |
   tcp
    |
[udp_over_tcp tcp:192.168.1.11:6000] (./gnb_udp_over_tcp -t -l 6000 192.168.1.25 9025)
    |
   udp 
    |
[gnb_1025  udp:192.168.1.25:9025]

在 192.168.1.11 上执行

./gnb_udp_over_tcp -t -l 6000 192.168.1.25 9025

本地ip地址为 192.168.1.10 GNB TUN ip 10.1.0.10

本地 GNB conf/1010/address.conf 内容为

n|1025|127.0.0.1|5001

address.conf中不要配置 i 类型的GNB节点

在 192.168.1.10 上执行

./gnb_udp_over_tcp -u -l 5001 192.168.1.11 6000

启动本地的GNB节点后 ping 10.1.0.25 检验是否能够ping通。

gnb_udp_over_tcp可以为其他基于UDP协议的服务中转数据

用nc作本地测试演示

[netcat]                          (nc -u 127.0.0.1 5001)
    |
   udp
    |
[udp_over_tcp udp:127.0.0.1:5001] (./gnb_udp_over_tcp -u -l 5001 127.0.0.1 6000)
    |
   tcp
    |
[udp_over_tcp tcp:127.0.0.1:6000] (./gnb_udp_over_tcp -t -l 6000 127.0.0.1 7000)
    |
   udp
    |
[netcat udp:127.0.0.1:7000]       (nc -u -l 7000)

Step1

用 nc 监听 7000 udp 端口

nc -u -l 7000

Step2

启动 gnb_udp_over_tcp 的 tcp端: 监听 tcp 6000 端口,每个接入该端口的tcp链路将建立起一个udp socket构成一个channel,tcp链路收到的报文发往 127.0.0.1 的 UDP 7000端口,从udp端收到的数据将发往tcp链路的另一端。 gnb_udp_over_tcp的tcp端可以同时接入多个tcp连接并且转发到同一个目的地址的udp端口。

./gnb_udp_over_tcp -t -l 6000 127.0.0.1 7000

Step3

启动 gnb_udp_over_tcp 的 udp端: 监听 udp 5001 端口,与 127.0.0.1 tcp 端口 6000 建立tcp链路,udp 端收到的数据发往tcp链路的另一端,从tcp链路收到的数据发往udp端。

./gnb_udp_over_tcp -u -l 5001 127.0.0.1 6000

Step4

用 nc 访问 127.0.0.1 的 5001 udp 端口,检验数据是否被成功转发。

nc -u 127.0.0.1 5001

免责声明