-
-
Notifications
You must be signed in to change notification settings - Fork 13.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
nathole: upnp support #4110
nathole: upnp support #4110
Conversation
98e4a7e
to
5d87105
Compare
Thanks for your contribution. However, for such functionality, we need to be more cautious in our design and thinking. We usually do not tend to directly submit code, but rather submit proposals and specific implementation paths in the issue, discuss and reach a consensus before attempting to code, in order to avoid wasting valuable time due to inconsistencies with project planning. There has been no progress on this issue for various reasons. One reason is that I am not clear on how useful this functionality is in the current network environment. This capability may require testing and long-term maintenance in various network environments, which would increase the project's maintenance costs. We should only consider it when the benefits are clearly greater than the added costs. Additionally, during the transition period of major version refactoring, we hope to minimize the complexity brought by new features. |
Thank you very much for your prompt and timely response. I understand and agree with your concerns. With the development of technologies such as P2P, initiating UPnP requests and asking routers to cooperate is a common technique in scenarios requiring public network mapping. Investigation and testing in this context, as outlined in #1823, demonstrate that even within ISP-level NAT networks, some providers offer support for related technologies. In IPv6 environments, even though each endpoint can acquire an IPv6 address, most routers currently block all inbound requests from the internet for security reasons. Therefore, it's still necessary to configure the opening of corresponding ports. The use of UPnP in these scenarios retains significant value. Moreover, some tools also offer similar functionalities, like ZeroTier (https://www.zerotier.com/). The current implementation is a straightforward extension of the STUN implementation for xTCP. After acquiring a public IP address, a callback is invoked. If permitted by the configuration, the UPnP feature is used to direct the router to transfer the externally exposed port to an open UDP port, thereby "creating" an EasyNAT in this environment. The subsequent process fully reuses the STUN procedure. I haven't closely examined the current implementation, but my assumption is that either the visitor or the proxy needs to be reachable by the other party for a direct connection to be established without the need for server relay. Therefore, I have implemented related configuration code on both the visitor and the proxy sides. If there's any misunderstanding on my part, please kindly correct me. Below is a log output from a proxy with this feature enabled, for your reference.
|
I suggest creating a new issue to track this proposal, and it may be necessary to pay attention to the following points:
|
PRs go stale after 21d of inactivity. Stale PRs rot after an additional 7d of inactivity and eventually close. |
我非常需要这个,有环境可以测试下这个,请问要如何使用这个代码,进行编译测试。 |
代码在这里:https://github.com/slayercat/frp/tree/dev-nathole-upnp-helpers git clone [email protected]:slayercat/frp.git cd frp git checkout origin/dev-nathole-upnp-helpers 剩下的流程与正常构建一致。 |
测试后,frpc to xtcp 代理端日志: 2024-06-17 16:42:36.368 [I] [proxy/xtcp.go:90] [efbb49835709a4d9] [ikuai.ssh] nathole prepare success, nat type: EasyNAT, behavior: BehaviorNoChange, addresses: [x.x.x.x:8224 x.x.x.x:8224], assistedAddresses: [192.168.253.5:41411]
2024-06-17 16:42:37.378 [I] [proxy/xtcp.go:111] [efbb49835709a4d9] [ikuai.ssh] get natHoleRespMsg, sid [1718613755e740b3bdc4976603], protocol [quic], candidate address [y.y.y.y:24478 y.y.y.y:24478], assisted address [192.168.6.180:56382 192.168.64.1:56382], detectBehavior: {Role:sender Mode:2 TTL:0 SendDelayMs:3000 ReadTimeoutMs:35000 CandidatePorts:[] SendRandomPorts:1000 ListenRandomPorts:0}
2024-06-17 16:43:15.380 [W] [proxy/xtcp.go:119] [efbb49835709a4d9] [ikuai.ssh] make hole error: wait detect message error: read udp4 0.0.0.0:41411: i/o timeout
2024-06-17 16:44:44.147 [I] [proxy/xtcp.go:90] [efbb49835709a4d9] [ikuai.ssh] nathole prepare success, nat type: EasyNAT, behavior: BehaviorNoChange, addresses: [x.x.x.x:8384 x.x.x.x:8384], assistedAddresses: [192.168.253.5:40358]
2024-06-17 16:44:45.156 [I] [proxy/xtcp.go:111] [efbb49835709a4d9] [ikuai.ssh] get natHoleRespMsg, sid [1718613883e34c169b73460e78], protocol [quic], candidate address [y.y.y.y:3977 y.y.y.y:3977], assisted address [192.168.6.180:51182 192.168.64.1:51182], detectBehavior: {Role:sender Mode:2 TTL:0 SendDelayMs:3000 ReadTimeoutMs:35000 CandidatePorts:[] SendRandomPorts:1000 ListenRandomPorts:0}
2024-06-17 16:45:23.158 [W] [proxy/xtcp.go:119] [efbb49835709a4d9] [ikuai.ssh] make hole error: wait detect message error: read udp4 0.0.0.0:40358: i/o timeout 没有发起 测试镜像使用上述代码编译后运行: docker pull qq851161583/frpc:upnp |
看日志是 NAT 类型检测成功了,然后打洞后,未成功将端口上报给 路由器 的 upnp,导致连接失败。 |
最新进展,根据 2024-06-17 17:08:30.749 [I] [upnp/upnp.go:152] [2af55021c903f4e5] [ikuai.ssh] UPNP_ForwardPort: remoteAddrPort=x.x.x.x:8329, localAddrPort=0.0.0.0:48424, targetForwardToLocal=192.168.253.5
2024-06-17 17:08:32.750 [W] [upnp/upnp.go:166] [2af55021c903f4e5] [ikuai.ssh] UPNP_ForwardPort error: multiple or no services found.
2024-06-17 17:08:32.750 [I] [proxy/xtcp.go:90] [2af55021c903f4e5] [ikuai.ssh] nathole prepare success, nat type: EasyNAT, behavior: BehaviorNoChange, addresses: [x.x.x.x:8329 x.x.x.x:8329], assistedAddresses: [192.168.253.5:48424]
2024-06-17 17:08:32.757 [I] [proxy/xtcp.go:111] [2af55021c903f4e5] [ikuai.ssh] get natHoleRespMsg, sid [1718615309c7d30d6f39fc7910], protocol [quic], candidate address [y.y.y.y:30657 y.y.y.y:30657], assisted address [192.168.6.180:65366 192.168.64.1:65366], detectBehavior: {Role:receiver Mode:1 TTL:4 SendDelayMs:0 ReadTimeoutMs:5000 CandidatePorts:[{From:30652 To:30662}] SendRandomPorts:0 ListenRandomPorts:0}
2024-06-17 17:08:37.810 [W] [proxy/xtcp.go:119] [2af55021c903f4e5] [ikuai.ssh] make hole error: wait detect message error: read udp4 0.0.0.0:48424: i/o timeout 看起来应该没什么问题了,这个获取不到 |
感谢测试。upnp服务器这个,建议检查一下网段问题或相关路由器是否开启 |
嗯,这个我的网络环境比较复杂,目前网络被旁路由接管了,出口路由docker部署了直接dmz的。upnp跨网段了,我后面再简化下了测试下。感谢对这个功能的付出。希望 upnp 能早日转正。 |
我又测试了下,网络环境里是有 upnp 服务器的,就是我的 路由器。 启动后,还是显示 找不到 UPNP_ForwardPort error: multiple or no services found. |
WHY
When a router supports UPnP,
frpc
can be configured to utilize the UPnP protocol to assist with tunnel traversal.This method can circumvent issues associated with the lack of support for STUN, enhancing the possibility of establishing direct connections.
It is important to note that UPnP operates as a plaintext protocol. Therefore, it should be disabled in scenarios where secure, concealed communication is required.
By default, this configuration is disabled, and it requires the specification of the program name to be exposed to UPnP devices.
see also:
#1823
#3703