内网穿透工具(替代 ngrok 和花生壳)

2019-11-08 10:25:29 +08:00
 lswang

简介

由于 IPv4 资源的有限性,目前大部分的本地电脑都是没有公网 IP。所以想要访问自己的本地服务(ssh、http、vnc、NAS、智能家居接口回调 - 比如天猫精灵自定义语义),需要有个服务来进行内网穿透。 目前有一些工具比如花生壳、ngrok 等。但是,

  1. 花生壳是收费的;
  2. ngrok 第二版也开始收费(第一版据说有一些严重 bug)。

所以,需要一款开源的方案( 当然还需要一个固定的公网 IP >_<)。

解决方案

本人用 netty 写了一个 tcp 的穿透工具叫 Tcp Through,直接下载可用。安装方式下面有介绍

该项目分 server 端和 client 端,想要看详细信息的话,可以去 github 上查看

这个工具有以下一些比较实用的功能

  1. 支持 http api 管理服务端,还支持 命令行来管理(自己写的 python 库,自己感觉还挺炫)
  2. 支持安全模式。只有在信任列表的 IP 地址才可以访问 client (防止攻击的最好方式)
  3. 支持速度限制,功能已经测试可用。只是目前在代码中没有限速,可自己修改代码,具体代码在 server 库中的 OuterServer 中,注释中有说明。
  4. client 可设定不允许 server 控制 (client 端的 isRemoteManage 参数)
  5. 支持查看实时速率(不需要用总量来计算)
  6. 管理通道进行了 SSL 加密,防止注册信息被抓包
  7. 数据平面和控制平面分离,提高性能(mac 下测速能达到 10Gb/s+)。
  8. 管理平面和控制平面都进行了安全性校验,不正确的连接会被 kill 掉,拒绝攻击。
  9. Server 可以增加密码校验,不允许其他的 client 注册。Server 启动时候加上 -s 参数。

备注: 如果是公网虚拟机(阿里云或者腾讯云),记得要开放相应的端口

Server 安装和运行

# 下载并解压
> wget https://github.com/longshengwang/tcpthrough-server/releases/download/v1.0/server-1.0.zip
> unzip server-1.0.zip
> cd server-1.0
# 启动 server 端,会占用 3 个端口,用途分别是 控制面(默认 9000)、数据面(9009)、http 服务(8080)。可以使用 --help 查看如何设定
> bin/server

注: 详细参数可以通过 bin/server --help 来查看

下面的例子是通过 服务器端的 333 端口来访问内网的 localhost22端口

Client 安装和运行

# 下载并解压
> wget https://github.com/longshengwang/tcpthrough-client/releases/download/client-1.0/client-1.0.zip
> unzip client-1.0.zip
> cd client-1.0
# 启动 client 端, 下面的字段表示:通过服务器上的 333 端口,可以访问客户端的 localhost:22 服务(这里是 ssh 服务)
> bin/client -u my_home -s <server ip>  -p 333 -l localhost:22 -p 333 -c true -a true

注: 详细参数可以通过 bin/client --help 来查看

参数说明:

name=wls_home
password=wo_shi_server_password
remote_host=192.168.122.20
remote_data_port=9009
remote_manager_port=9000
local_host=192.168.122.20
local_port=22
remote_proxy_port=2222
is_remote_manage=true

命令行

可以通过 python 的一个库(自己写的),来查看和管理 server 上的连接信息

➜ ~ pip install tcpth.cmd
➜ ~ tcpthcmd  # 如果 server 上的 http 端口不是默认的 8080,可以后面加上 -p <port>
Welcome to use the tcp through.
tcpthrough> help
tcpthrough> help
    list -- get all registration
    get <name> -- get special name information
    monitor [<name>] -- monitor the information, refresh on 2s
    register add <name> <localhost:port> <proxy port> -- add registration
    register delete <name> <proxy port> -- delete registration
    trust add <name> [<proxy port>] <trusted ip> -- add trust ip
    trust delete <name> [<proxy port>] <trusted ip> -- delete trust ip
    trust get <name> [<proxy port>] -- get trust ip
tcpthrough>
tcpthrough> list   # 在命令行下,列是对齐的,拷贝过来之后就不对齐了
 Name | Local Service | Proxy Port | Out Conn Count | Remote Managed | Security | Write Speed | Read Speed
--------------------------------------------------------------------------------------------------------------
 my_home | localhost:22 | 333 | 0 | true | true | 0KB/s | 0KB/s
tcpthrough>

说明:

16216 次点击
所在节点    程序员
104 条回复
lswang
2019-11-08 11:59:35 +08:00
@easing 是的,现在 NAT 打洞已经非常难了
lswang
2019-11-08 12:04:08 +08:00
@jaybing926 ssh 转发是简单,不过少了 限速、管理一些其他的功能
fanyingmao
2019-11-08 12:12:13 +08:00
还是直接用 ssh 转发,比较简单。
fclql
2019-11-08 12:53:15 +08:00
都什么年代了还需要穿透?
wpblank
2019-11-08 12:57:22 +08:00
正好我顺路问个问题,本来准备电脑弄个内网穿透,回家了也能连上。结果我们公司网络好像屏蔽了 frp 和 v2ray,想问下怎么实现的
sagaxu
2019-11-08 13:03:19 +08:00
家里宽带公网 IP,配了 dmz,域名解析到家里 IP,每隔半个小时向 dnspod 上报一次 IP。

公司 ssh 连接到家里做隧道,systemd 管理,转发失败会自动重连。

第三方工具,好像并不需要。
encro
2019-11-08 13:10:23 +08:00
frp,nps,goproxy 都很不错
wangyongbo
2019-11-08 13:10:41 +08:00
@jaybing926 教一下我吧, 这一条命令是啥? 谢谢
shenqi
2019-11-08 13:33:23 +08:00
临时使用,推荐 pierced。不要滥用了,不然封了就惨了。
sagaxu
2019-11-08 13:36:05 +08:00
@tigerstudent systemd 或者 supervisord 都很成熟
lswang
2019-11-08 13:43:11 +08:00
@wpblank 怎么屏蔽 frp 和 v2ray 的就不知道了。 文章里的安装步骤照着做就行,如果是 windows 的,把文章里对应的命令换成你手动操作。不过你需要有一个固定的公网 IP
jaybing926
2019-11-08 14:18:59 +08:00
@wangyongbo ssh -R 20001:localhost:80 root@a.a.a.a 或者 autossh -p22 -M 5000 -NR 20001:0.0.0.0:80 root@a.a.a.a,autossh 会一直尝试重新连接 可以消除网络故障隐患,ssh 透传的缺陷是透传到外网的端口只能监听 127
samondlee
2019-11-08 14:29:25 +08:00
点个 star2333
感觉和 sakura frp 魔改的 有点儿像
zlylong
2019-11-08 14:34:02 +08:00
@wpblank 屏蔽 V2ray 是如何做到的???比 GFW 还强!?
lswang
2019-11-08 14:43:02 +08:00
@samondlee 谢谢支持
SenLief
2019-11-08 15:29:27 +08:00
有公网 IP 的还是直接用 DDNS,没有的我觉得不如买一个设备了。省心
daimiaopeng
2019-11-08 15:31:34 +08:00
frp 不香吗?
lswang
2019-11-08 15:39:10 +08:00
@daimiaopeng 自己写的最香
ungrown
2019-11-08 15:52:12 +08:00
@xxsww211 你们为什么造轮子之前就不能先查一下,你说的这个也有了,而且早就有了,“远古”项目 n2n 就是(虽然已经凉凉),现在有个更大的项目 zerotier
ungrown
2019-11-08 15:53:08 +08:00
@lswang 有本事加密算法也自己写
重复造轮子就是浪费生产力

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/617484

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX