tcp协议应用的坑
最近在做个nodejs tcp内网穿透的APP
原理图:
目的是为了让内网的redis、mysql、mongodb、ssh、远程桌面等应用 暴露一个外网端口
测试了redis和ssh 正常,但是在用mysql和mongodb和远程桌面的时候,缺一直提示无法连接。
在打印日志的时候,发现了一个有趣的现象:
服务器启动成功 socket:{"address":"::ffff:127.0.0.1","family":"IPv6","port":8888} 代理连接成功 1 收到数据 1 收到数据 1 收到数据 1 收到数据 1 收到数据 socket:{"address":"::ffff:127.0.0.1","family":"IPv6","port":8888} 代理连接成功 2 收到数据 2 收到数据 2 收到数据 2 收到数据 1 收到数据 1 收到数据
由于我们设计的代理模式,只支持1个tcp,在这些应用中 他们却使用了多个tcp连接,就造成问题了。
外网服务器和内网客户端tcp连接也得多个,然后和外网tcp连接做个映射,或者使用数据包的方式,外网tcp连接多个,内网用和服务器只用一个。用自定义协议的数据包进行转发。
项目源码地址:https://github.com/newpanjing/fastnat