1. 程式人生 > >分享一下在centos上搭建ngrok伺服器的過程吧!

分享一下在centos上搭建ngrok伺服器的過程吧!

最近開發自己的微信公眾號時,發現在本地寫程式碼,然後要傳到伺服器上面去,非常的不方便,通過百度,知道了一款開源軟體ngrok,在它的伺服器在國外,灰常的慢,訪問的速度簡直不能直視,於是百度解決辦法,沒想到ngrok伺服器可以自己搭建,跟著教程一步步搭建ngrok,在這裡做一下筆記。

準備工作:

1、一臺公網可以訪問到得linux伺服器(centos)

2、把需要做的域名解析到伺服器上面

軟體:

一、安裝git

1、安裝git所用到依賴包

yum -y install zlib-devel openssl-devel perl hg cpio expat-devel gettext-devel curl curl-devel perl-ExtUtils-MakeMaker hg wget gcc gcc-c++

2、下載git

3、解壓git

tar zxvf git-2.6.0.tar.gz

4、編譯git

cd git-2.6.0

./configure –prefix=/usr/local/git

make

make install

5、建立git的軟連線

ln -s /usr/local/git/bin/* /usr/bin/

二、安裝go環境

因為我是64位的centos,所以下載64位的包,還有一定要下載1.4版本的go環境,好像1.4以後的版本就不是用C語言編寫的,會編譯錯誤。

1、下載go環境

2、解壓

tar zxvf go1.4.2.linux-amd64.tar.gz

mv go /usr/local

3、建立軟連線

ln -s /usr/local/go/bin/* /usr/bin

4、編譯ngrok

cd /usr/local/

export GOPATH=/usr/local/ngrok/

export NGROK_DOMAIN=”你得域名”

cd 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

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

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

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

如果是在天朝的伺服器需要改,香港或者國外的伺服器不需要

vim /usr/local/ngrok/src/ngrok/log/logger.go
log “github.com/keepeye/log4go”

四、編譯服務端和客戶端

指定編譯環境變數,如何確認GOOS和GOARCH,可以通過go env來檢視

1、編譯服務端

cd /usr/local/go/src

GOOS=linux GOARCH=amd64 ./make.bash

cd /usr/local/ngrok/

GOOS=linux GOARCH=amd64 make release-server

2、由於我是mac os x作業系統,所以我使用下面的編譯客戶端

cd /usr/local/go/src

GOOS=darwin GOARCH=amd64 ./make.bash

cd /usr/local/ngrok/

GOOS=darwin GOARCH=amd64 make release-client

Windows的客戶端編譯(64位,32位的把GOARCH的值改為386)

cd /usr/local/go/src

GOOS=windows GOARCH=amd64 ./make.bash

cd /usr/local/ngrok/

GOOS=windows GOARCH=amd64 make release-client

3、啟動服務端

/usr/local/ngrok/bin/ngrokd -domain=”$NGROK_DOMAIN” -httpAddr=”:80”

五、客戶端的使用及其配製檔案

客戶端配置檔案(ngrok.cfg)

server_addr: “你得域名:4443”

trust_host_root_certs: false

(<a href="http://www.dztcsd.com/">資質代辦</a>)

客戶端使用

./ngrok -config=./ngrok.cfg -subdomain=blog 80

setsid ./ngrok -config=./ngrok.cfg -subdomain=test 80 #在linux下如果想後臺執行


作者: racall 

來源:慕課網