基于Ngrok搭建内网穿透服务器

内网穿透ngrok

@[TeachOfNgrok]

步骤:

1.安装Go语言环境(解压,设置环境变量在此处省略)

wget https://dl.google.com/go/go1.11.linux-amd64.tar.gz

2.安装Git并且拉取源码包

mkdir ngork 建立并进入文件夹ngork

3.生成证书


    #为base域名dagm.com生成证书
    openssl genrsa -out rootCA.key 2048
    openssl req -x509 -new -nodes -key rootCA.key -subj "/CN=gmlgtf.com" -days 5000 -out rootCA.pem
    openssl genrsa -out device.key 2048
    openssl req -new -key device.key -subj "/CN=gmlgtf.com" -out device.csr
    openssl x509 -req -in device.csr -CA rootCA.pem -CAkey rootCA.key -CAcreateserial -out device.crt -days 5000

4.替换证书文件


    cp rootCA.pem assets/client/tls/ngrokroot.crt
    cp device.crt assets/server/tls/snakeoil.crt 
    cp device.key assets/server/tls/snakeoil.key

5.开始编译ngrok

make release-server
测试并运行ngrokd(ngrokd在bin文件夹中)
./bin/ngrokd -domain="gmlgtf.com" (默认使用 http:80 https:443 tunnelAddr:4443)//该方式为当前进程运行,关闭命令行程序终止
后台运行:nohup ngrokd -domain="gmlgtf.com" -log="ngrok.log" -httpAddr=":8081" -httpsAddr=":8054" &


[15:14:59 CST 2018/09/12] [INFO] (ngrok/log.(*PrefixLogger).Info:83) [registry] [tun] No affinity cache specified
[15:14:59 CST 2018/09/12] [INFO] (ngrok/log.Info:112) Listening for public http connections on [::]:80
[15:14:59 CST 2018/09/12] [INFO] (ngrok/log.Info:112) Listening for public https connections on [::]:443
[15:14:59 CST 2018/09/12] [INFO] (ngrok/log.Info:112) Listening for control and proxy connections on [::]:4443
[15:14:59 CST 2018/09/12] [INFO] (ngrok/log.(*PrefixLogger).Info:83) [metrics] Reporting every 30 seconds

出现上图表示服务端正常启动了

6.编译客户端不同平台用不同的编译参数

  • 我在这里使用的是mac 64位编译

     GOOS=darwin GOARCH=amd64 make release-client

7.通过scp 命令下载客户端文件到本地

scp {root}@{ip}:{文件的位置} {本机存放文件的位置}
//注意不需要将整个ngork文件下载,只需要下载对应的客户端文文件即可,比如mac下就是darwin_amd64文件夹下面的ngrok

8.在刚才下载的文件目录下创建ngrok.cfg文件

cfg的文件名随意,只需要和待会的启动命令中的参数保持一致即可

9.运行客户端程序

出现
客户端连接服务端成功的界面图

表示和服务端连接上了,

log 参数可写可不写,如果写了会在当前目录下建立一个log文件
ngrok -subdomain demo -config=ngrok.cfg -log=ngrok.log 4000
demo随便取,不重复即可,4000为我本机开放的服务端口
效果图


效果图

第二个连接地址可在外网环境下访问

10.将ngrokd添加到环境变量


    vim ~/.bashrc
    export PATH=$PATH:/root/go/src/github.com/inconshreveable/ngrok/bin
    source ~/.bashrc

11. 压轴重点(遇到的坑)

本内网穿透是基于阿里云的服务器,环境为ubantu 16.04
常见的问题: 连接的时候一直出现红色的reconnectioning

  • 可能的原因:

1.服务端启动的时候对应的端口没有开放(使用telbet ip port 检查是否开放),如果没有开放,参考下面如何开放云服务器端口
2.同时保证自己的云服务器服务器解析已经开放对应的端口(以TCP协议)
3.域名DNS解析配置错误(以及域名和二级域名(或者更多级)域名均需要配置,建议使用通配符)

如何开放linux服务器端口(这种方式是临时修改,不是永久)

iptables -A INPUT -p tcp --dport 777 -j ACCEPT
iptables -A OUTPUT -p tcp --sport 777 -j ACCEPT

再查看下 iptables -L -n 是否添加上去, 看到添加了

Chain INPUT (policy DROP)
target prot opt source destination
ACCEPT tcp -- 0.0.0.0/0 0.0.0.0/0 tcp dpt:777
Chain OUTPUT (policy ACCEPT)
ACCEPT tcp -- 0.0.0.0/0 0.0.0.0/0 tcp spt:777

客户端编译参数参数


    Linux 平台 32 位系统:GOOS=linux GOARCH=386
    Linux 平台 64 位系统:GOOS=linux GOARCH=amd64
    Windows 平台 32 位系统:GOOS=windows GOARCH=386
    Windows 平台 64 位系统:GOOS=windows GOARCH=amd64
    MAC 平台 32 位系统:GOOS=darwin GOARCH=386
    MAC 平台 64 位系统:GOOS=darwin GOARCH=amd64
    
    ARM 平台:GOOS=linux GOARCH=arm
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 198,848评论 5 466
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,529评论 2 375
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 145,824评论 0 327
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,329评论 1 268
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,227评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,879评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,218评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,877评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,159评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,155评论 2 315
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,987评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,736评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,273评论 3 302
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,407评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,663评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,158评论 2 344
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,517评论 2 339

推荐阅读更多精彩内容