1. 程式人生 > >ngrok 伺服器 客戶端的安裝,使用(包含二級域名的配置)

ngrok 伺服器 客戶端的安裝,使用(包含二級域名的配置)

服務端的安裝

條件: 需要一臺公網伺服器

1.在伺服器上安裝go的環境變數

wget https://storage.googleapis.com/golang/go1.8.3.linux-amd64.tar.gz --no-check-certificate
tar zxvf go1.8.3.linux-amd64.tar.gz
mv go /usr/local/
2、新增環境變數
vim /etc/profile
新增如下內容:
export PATH=$PATH:/usr/local/go/bin
export GOROOT=/usr/local/go
使配置生效
 source /etc/profile

 go version 檢視go是否安裝成功

2.安裝git

yum –y install git

3.配置二級域名

在伺服器中dns解析中配置二級域名的解析,需要在域名管理裡面設定二級域名的解析二級域名配置

4.配置nginx

4.1 需要在nginx中配置二級域名的訪問,在nginx.conf中配置一個server:
    server {
        listen       80;
        server_name  ngrok.abc.cn;
        access_log logs/ngrok.log;
        error_log logs/ngrok.error;
        #charset
koi8-r; #access_log logs/host.access.log main; location / { proxy_set_header Host $host; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http://127.0.0.1:8001; }

配置好nginx以後,重新nginx

./nginx -s reload

5.安裝ngrok

https://github.com/Yaoshicn/make-ngrok
先看下make-ngrok.sh指令碼內容如下:

#!/bin/bash
domain=$1
root="`pwd`/ngrok"
certificate_dir="$root/certificate"
release_dir="$root/../release"

RED='\033[0;31m'
NC='\033[0m'

if ["$1" = ""]; then 
    printf "Usage: ./make-ngrok.sh [YOUR DOMAIN]\n" 
    exit
fi

printf "Domain:$domain\n"

printf "${RED}Git clone...${NC}\n"
git clone https://github.com/inconshreveable/ngrok && cd $root
printf "${RED}Done${NC}\n"

printf "${RED}Install go-bindata...${NC}\n"
go get github.com/jteeuwen/go-bindata
[ -d $root/bin ] || mkdir $root/bin && cp $GOPATH/bin/go-bindata $root/bin
printf "${RED}Done${NC}\n"

[ -d $certificate_dir ] || mkdir $certificate_dir && cd $certificate_dir

printf "${RED}Generate self-sign certificate...${NC}\n"
openssl genrsa -out rootCA.key 2048
openssl req -x509 -new -nodes -key rootCA.key -subj "/CN=$domain" -days 5000 -out rootCA.pem
openssl genrsa -out device.key 2048
openssl req -new -key device.key -subj "/CN=$domain" -out device.csr
openssl x509 -req -in device.csr -CA rootCA.pem -CAkey rootCA.key -CAcreateserial -out device.crt -days 5000
printf "${RED}Done${NC}\n"

printf "${RED}Copy certificates and key to target folders...${NC}\n"
cd $certificate_dir
cp rootCA.pem ../assets/client/tls/ngrokroot.crt
cp device.crt ../assets/server/tls/snakeoil.crt
cp device.key ../assets/server/tls/snakeoil.key
printf "${RED}Done${NC}\n"

# make
printf "${RED}Make release server and client...${NC}\n"
cd $root
make release-server release-client
printf "${RED}Done${NC}\n"

printf "${RED}Make client for other platforms...${NC}\n"
# Linux 32
unset GOBIN && GOOS="linux" GOARCH="386" make release-client
# Linux 64
unset GOBIN && GOOS="linux" GOARCH="amd64" make release-client
# ARM
unset GOBIN && GOOS="linux" GOARCH="arm" make release-client
# Windows 32
unset GOBIN && GOOS="windows" GOARCH="386" make release-client
# Windows 64
unset GOBIN && GOOS="windows" GOARCH="amd64" make release-client
# Mac 32
unset GOBIN && GOOS="darwin" GOARCH="386" make release-client
# Mac 64
unset GOBIN && GOOS="darwin" GOARCH="amd64" make release-client
printf "${RED}Done${NC}\n"
rm -rf $release_dir
[ -d $release_dir ] || mkdir $release_dir
cp -r $root/bin/* $release_dir

瞭解下別人寫好的指令碼,開始安裝ngrok

cd /usr/local
mkdir ngrok
cd mgrok
git clone https://github.com/Yaoshicn/make-ngrok.git
cp /usr/local/ngrok/make-ngrok/make-ngrok.sh make-ngrok.sh
pwd
/usr/local/ngrok/
ll
make-ngrok.sh

然後執行:

./make-ngrok.sh [YOUR DOMAIN] 比如:ngrok.abc.com

等待安裝,安裝完成後,在ngrok目錄下會多出兩個資料夾: release跟ngrok資料夾
點開release

cd release
ll

可以看到已經編譯好的ngrokd
此時,已經成功,剩下就是啟動ngrok,
編寫一個啟動指令碼:

vi startNgrok.sh
#!/bin/bash
nohup /usr/local/ngrok/release/ngrokd -domain="ngrok.abc.cn" -log="/usr/local/ngrok/release/ngrok.log" -httpAddr=":8001"  &
tail -f /usr/local/ngrok/release/ngrok.log

儲存startNgrok.sh檔案

chmod +x  startNgrok.sh
./startNgrok.sh

此時能看到啟動日誌檔案,表示已經安裝成功了


客戶端的使用(只說使用自有域名的情況)

條件:你需要一個自有域名,假如說是: www.xxx.com

1.域名解析

你需要把域名解析到剛才的www.abc.com對應的伺服器的ip地址上,新增一條
類似這個,需要在域名管理裡面設定二級域名的解析二級域名配置
,
主機記錄為你本地需要被別人訪問的域名字首,比如:www

記錄值是上面ngrok服務端的ip地址

,然後本地啟動客戶端,客戶端為伺服器/usr/local/ngrok/release目錄下對應的各種作業系統對應的版本,如果為windows x64位的作業系統就下載 windows_amd64目錄下的ngrok.exe可執行程式,儲存到本地的一個資料夾中,建立ngrok.cfg檔案,複製下面兩行配置

server_addr: ngrok.abc.cn:4443
trust_host_root_certs: false

ngrok.abc.cn 為你ngrok服務端分配的二級域名,儲存
編寫啟動檔案 start.bat

@echo OFF
color 0a
Title ngrok啟動工具 
Mode con cols=109 lines=30
:START
echo
:TUNNEL
ngrok -config=ngrok.cfg -hostname www.abc.com 80
PAUSE
goto TUNNEL

www.abc.com 為ngrok客戶端配置的域名,
儲存以後,啟動就可以看到啟動畫面了.
顯示online表示成功了.


     最後一點,服務端的域名註冊商要跟客戶端的域名註冊商是同一個服務商,比如阿里註冊的域名,客戶端的域名也要是阿里雲,如果不為阿里雲的話,就會讓接入備案,建議可以用cc域名,現在不用備案,阿里雲跟騰訊雲通用.
    教程到此結束.