基于Ngrok搭建內(nèi)網(wǎng)穿透服務器

內(nèi)網(wǎng)穿透ngrok

@[TeachOfNgrok]

步驟:

1.安裝Go語言環(huán)境(解壓,設置環(huán)境變量在此處省略)

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

出現(xiàn)上圖表示服務端正常啟動了

6.編譯客戶端不同平臺用不同的編譯參數(shù)

  • 我在這里使用的是mac 64位編譯

     GOOS=darwin GOARCH=amd64 make release-client

7.通過scp 命令下載客戶端文件到本地

scp {root}@{ip}:{文件的位置} {本機存放文件的位置}
//注意不需要將整個ngork文件下載趴拧,只需要下載對應的客戶端文文件即可,比如mac下就是darwin_amd64文件夾下面的ngrok

8.在剛才下載的文件目錄下創(chuàng)建ngrok.cfg文件

cfg的文件名隨意山叮,只需要和待會的啟動命令中的參數(shù)保持一致即可

9.運行客戶端程序

出現(xiàn)
客戶端連接服務端成功的界面圖

表示和服務端連接上了著榴,

log 參數(shù)可寫可不寫,如果寫了會在當前目錄下建立一個log文件
ngrok -subdomain demo -config=ngrok.cfg -log=ngrok.log 4000
demo隨便取屁倔,不重復即可脑又,4000為我本機開放的服務端口
效果圖


效果圖

第二個連接地址可在外網(wǎng)環(huán)境下訪問

10.將ngrokd添加到環(huán)境變量


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

11. 壓軸重點(遇到的坑)

本內(nèi)網(wǎng)穿透是基于阿里云的服務器,環(huán)境為ubantu 16.04
常見的問題: 連接的時候一直出現(xiàn)紅色的reconnectioning

  • 可能的原因:

1.服務端啟動的時候對應的端口沒有開放(使用telbet ip port 檢查是否開放),如果沒有開放锐借,參考下面如何開放云服務器端口
2.同時保證自己的云服務器服務器解析已經(jīng)開放對應的端口(以TCP協(xié)議)
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

客戶端編譯參數(shù)參數(shù)


    Linux 平臺 32 位系統(tǒng):GOOS=linux GOARCH=386
    Linux 平臺 64 位系統(tǒng):GOOS=linux GOARCH=amd64
    Windows 平臺 32 位系統(tǒng):GOOS=windows GOARCH=386
    Windows 平臺 64 位系統(tǒng):GOOS=windows GOARCH=amd64
    MAC 平臺 32 位系統(tǒng):GOOS=darwin GOARCH=386
    MAC 平臺 64 位系統(tǒng):GOOS=darwin GOARCH=amd64
    
    ARM 平臺:GOOS=linux GOARCH=arm
最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末问麸,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子钞翔,更是在濱河造成了極大的恐慌严卖,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,290評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件布轿,死亡現(xiàn)場離奇詭異哮笆,居然都是意外死亡,警方通過查閱死者的電腦和手機汰扭,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評論 2 385
  • 文/潘曉璐 我一進店門疟呐,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人东且,你說我怎么就攤上這事”炯ィ” “怎么了珊泳?”我有些...
    開封第一講書人閱讀 156,872評論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長拷沸。 經(jīng)常有香客問我色查,道長,這世上最難降的妖魔是什么撞芍? 我笑而不...
    開封第一講書人閱讀 56,415評論 1 283
  • 正文 為了忘掉前任秧了,我火速辦了婚禮,結果婚禮上序无,老公的妹妹穿的比我還像新娘验毡。我一直安慰自己衡创,他們只是感情好,可當我...
    茶點故事閱讀 65,453評論 6 385
  • 文/花漫 我一把揭開白布晶通。 她就那樣靜靜地躺著璃氢,像睡著了一般。 火紅的嫁衣襯著肌膚如雪狮辽。 梳的紋絲不亂的頭發(fā)上一也,一...
    開封第一講書人閱讀 49,784評論 1 290
  • 那天,我揣著相機與錄音喉脖,去河邊找鬼椰苟。 笑死,一個胖子當著我的面吹牛树叽,可吹牛的內(nèi)容都是我干的舆蝴。 我是一名探鬼主播,決...
    沈念sama閱讀 38,927評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼菱皆,長吁一口氣:“原來是場噩夢啊……” “哼须误!你這毒婦竟也來了?” 一聲冷哼從身側響起仇轻,我...
    開封第一講書人閱讀 37,691評論 0 266
  • 序言:老撾萬榮一對情侶失蹤京痢,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后篷店,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體祭椰,經(jīng)...
    沈念sama閱讀 44,137評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,472評論 2 326
  • 正文 我和宋清朗相戀三年疲陕,在試婚紗的時候發(fā)現(xiàn)自己被綠了方淤。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,622評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡蹄殃,死狀恐怖携茂,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情诅岩,我是刑警寧澤讳苦,帶...
    沈念sama閱讀 34,289評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站吩谦,受9級特大地震影響鸳谜,放射性物質發(fā)生泄漏。R本人自食惡果不足惜式廷,卻給世界環(huán)境...
    茶點故事閱讀 39,887評論 3 312
  • 文/蒙蒙 一咐扭、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦蝗肪、人聲如沸袜爪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽饿敲。三九已至,卻和暖如春逛绵,著一層夾襖步出監(jiān)牢的瞬間怀各,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工术浪, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留瓢对,地道東北人。 一個月前我還...
    沈念sama閱讀 46,316評論 2 360
  • 正文 我出身青樓胰苏,卻偏偏與公主長得像硕蛹,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子硕并,可洞房花燭夜當晚...
    茶點故事閱讀 43,490評論 2 348

推薦閱讀更多精彩內(nèi)容