分享
  1. 首页
  2. 文章

自已动手搭建ngrok内网穿透环境

风雨无阻 · · 1851 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

配置golang环境

下载ngrok源码


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

编译安装

  • 生成自签名证书
cd ngrok
NGROK_DOMAIN="tunnel.dw.io"
openssl genrsa -out base.key 2048
openssl req -new -x509 -nodes -key base.key -days 10000 -subj "/CN=$NGROK_DOMAIN" -out base.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 base.pem -CAkey base.key -CAcreateserial -days 10000 -out server.crt
  • 替换assets目录下的默认证书
cp base.pem assets/client/tls/ngrokroot.crt
cp server.crt assets/server/tls/snakeoil.crt
cp server.key assets/server/tls/snakeoil.key
  • 编译服务端(centos环境)
make release-server
  • 编译客户端(mac环境)
GOOS=darwin GOARCH=amd64 make release-client

并把./bin/darwin_amd64/ngrok生成的客户端拷贝到本地

配置&运行

  • 设置开机自启动ngrokd服务
    创建/etc/init.d/ngrok_start
#!/bin/bash
cd /home/dw/go/src/github.com/inconshreveable/ngrok
./bin/ngrokd -tlsKey=server.key -tlsCrt=server.crt -domain="tunnel.xiangqingou.cn" -httpAddr=":8091" -httpsAddr=":8092" > /dev/null 2>&1 &
  • 修改防火墙加入8091和8092端口的tcp放行,并reload使其生效
  • 修改nginx,使用客户端可以通过域名直接访问,不用在域名后再加:8091
upstream ngrok_pg {
 server 127.0.0.1:8091;
 keepalive 64;
}
server {
 listen 80;
 server_name *.tunnel.dw.io;
 access_log /var/log/nginx/ngrok_access.log;
 error_log /var/log/nginx/ngrok_error.log;
 location / {
 proxy_set_header X-Real-IP $remote_addr;
 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 proxy_set_header Host $http_host:8091;
 proxy_set_header X-Nginx-Proxy true;
 proxy_set_header Connection "";
 proxy_pass http://ngrok_pg;
 }
}
  • 客户端配置
    • 在ngrok同目录下创建ngrok.cfg文件
server_addr: "tunnel.dw.io:4443"
trust_host_root_certs: false
  • 启动
./ngrok -subdomain pg -config=./ngrok.cfg 8090

此时就可以看到

ngrok (Ctrl+C to quit)
Tunnel Status online
Version 1.7/1.7
Forwarding http://pg.tunnel.dw.io:8091 -> 127.0.0.1:8090
Forwarding https://pg.tunnel.dw.io:8091 -> 127.0.0.1:8090
Web Interface 127.0.0.1:4040
# Conn 0
Avg Conn Time 0.00ms

有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:风雨无阻

查看原文:自已动手搭建ngrok内网穿透环境

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
1851 次点击
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏