搭建内网穿透的ngrok服务器

要求:要有备案的域名,和可测试的服务器。

1.给域名添加两条a记录,

ngrok.heyintec.com 和 *.ngrok.heyintec.com 分别都指向42.192.120.161(我自己的服务器)

2.在服务器上安装go环境和ngrok

a.先安装go

wget https://storage.googleapis.com/golang/go1.8.linux-amd64.tar.gz

#解压缩到/usr/local目录

tar -C /usr/local -xzf go1.8.linux-amd64.tar.gz

#修改环境变量

vi /etc/profile

export PATH=$PATH:/usr/local/go/bin

source /etc/profile

#查看go是否安装成功

go version

b.再来安装ngrok

#下载到源码到/usr/local目录

cd /usr/local/

git clone https://github.com/inconshreveable/ngrok.git

cd ngrok

#生成ssl证书

export NGROK_DOMAIN="ngrok.heyintec.com"

#指定go执行路径

export GOPATH=/usr/local/ngrok/

openssl genrsa -out rootCA.key 2048

openssl req -x509 -new -nodes -key rootCA.key -subj "/CN=$NGROK_DOMAIN" -days 5000 -out rootCA.pem

openssl genrsa -out server.key 2048

openssl req -new -key server.key -subj "/CN=$NGROK_DOMAIN" -out server.csr

openssl x509 -req -in server.csr -CA rootCA.pem -CAkey rootCA.key -CAcreateserial -out server.crt -days 5000

#移动证书,记住要覆盖 输入y

cp rootCA.pem assets/client/tls/ngrokroot.crt

cp server.crt assets/server/tls/snakeoil.crt

cp server.key assets/server/tls/snakeoil.key

3.编译生成服务端和客户端

#服务端,linux系统GOOS=linux,64位系统GOARCH=amd64,32位系统GOARCH=386

GOOS=linux GOARCH=amd64 make release-server

#客户端,我这里是mac

GOOS=darwin GOARCH=amd64 make release-client

#客户端linux

GOOS=linux GOARCH=amd64 make release-client

#客户端windows

GOOS=windows GOARCH=amd64 make release-client

然后在ngrok的bin目录将会生成不同的可执行文件。

4.启动服务端

#在ngrok的bin目录,以守护进程启动ngrokd服务

nohup ./ngrokd -domain="ngrok.heyintec.com" -httpAddr=":8090" -httpsAddr=":8091" -tunnelAddr=":8092" &

5.启动客户端

我们把客户端文件下载到对应的机器上,比如我给拉到自己的mac电脑

在mac上新建一个针对ngrok客户端的配置文件 ngrok.cfg

bash 复制代码
server_addr: "ngrok.heyintec.com:8092"

trust_host_root_certs: false

#命令行启动客户端

#映射子域名wx,也就是wx.ngrok.heyintec.com:8092 到内网本地的127.0.0.1:8083 端口

./ngrok -config ngrok.cfg -subdomain wx 127.0.0.1:8083

相关推荐
lizhihai_991 小时前
股市学习心得-AI 产业链核心标的梳理清单
大数据·服务器·人工智能·科技·学习
黄同学real2 小时前
解决 Visual Studio Web Deploy 远程发布报 401 未授权 (ERROR\_USER\_UNAUTHORIZED)
服务器
天天进步20152 小时前
Tunnelto 源码解析 #9:控制服务器设计:Warp、WebSocket、Ping/Pong 与连接保活
运维·服务器·websocket
Java面试题总结3 小时前
Linux-Ubantu-贴士-apt的地盘
linux·运维·服务器
●VON3 小时前
AtomGit Flutter鸿蒙客户端:数据模型
android·服务器·安全·flutter·harmonyos·鸿蒙
酉鬼女又兒3 小时前
零基础入门计算机网络:网络层核心任务、三大关键问题、两种服务类型与 TCP/IP 网际层协议体系全解析
服务器·网络·网络协议·tcp/ip·计算机网络·php·求职招聘
Gauss松鼠会4 小时前
【GaussDB】GaussDB重要通信参数汇总
服务器·网络·数据库·sql·性能优化·gaussdb·经验总结
凡人叶枫5 小时前
Effective C++ 条款10:令 operator= 返回一个 reference to *this
java·linux·服务器·开发语言·c++·effective c++
某林2125 小时前
Isaac Sim 5.1.0 无头服务器部署与 RTX 显存段错误排障全记录
运维·服务器·docker·容器·isaac
m0_738120725 小时前
Docker 环境下 Vulfocus 靶场搭建全流程(附镜像源问题解决方案)
运维·服务器·网络·安全·docker·容器