准备公网域名 创建两个A记录ngrok
和*.ngrok
到云主机的IP
在系统上安装Go,最好不要安装在/usr/local/下,会有很多权限问题,直接安装在home目录下即可
注意对应下载相应系统的版本
参考的配置,其中GOPATH不用管:
GOPATH="/home/ubuntu/go"
GORACE=""
GOROOT="/home/ubuntu/dev/go"
GOTOOLDIR="/home/ubuntu/dev/go/pkg/tool/linux_386"
配置好环境变量之后就可以使用go version
或者go env
来查看相应的环境变量
下载ngrok,注意对应的环境变量目录,最好也下载在home目录下面
git clone https://github.com/inconshreveable/ngrok.git
cd ngrok
生成相应的证书,中间最好不要使用环境变量$NGROK_DOMAIN
,可能出错
openssl genrsa -out rootCA.key 2048
openssl req -x509 -new -nodes -key rootCA.key -subj "/CN=ngrok.example.cn" -days 5000 -out rootCA.pem
openssl genrsa -out server.key 2048
openssl req -new -key server.key -subj "/CN=ngrok.example.cn" -out server.csr
openssl x509 -req -in server.csr -CA rootCA.pem -CAkey rootCA.key -CAcreateserial -out server.crt -days 5000
拷贝证书文件到ngrok响应目录
cp rootCA.pem assets/client/tls/ngrokroot.crt
cp server.crt assets/server/tls/snakeoil.crt
cp server.key assets/server/tls/snakeoil.key
切换到相应的目录下,先编译go,再编译ngrok。如果要编译32位平台的需要使用GOARCH=386
cd /usr/local/go/src
GOOS=linux GOARCH=amd64 ./make.bash
cd /usr/local/ngrok/
GOOS=linux GOARCH=amd64 make release-server release-client
其中,会有个问题$GOROOT_BOOTSTRAP must not be set to $GOROOT
配置的 $GOROOT_BOOTSTRAP 和 $GOROOT 一致导致。可以复制一份go的源码到另外的路径,如/usr/local/go-copy
,同时export GOROOT_BOOTSTRAP=/usr/local/go-copy
备注编译MAC和WIN客户端,分别对应GOOS=darwin
和GOOS=windows
编译完成之后在服务器上打开服务端ngrokd,切换到ngrok/bin
目录下
sudo ./ngrokd -domain="ngrok.example.cn" -httpAddr=":8081" -tunnelAddr=":8082"
将服务器8081端口给http请求,将8082端口给tunnel请求(如ssh)
再把编译好的客户端ngrok
下载到本机
在相同目录创建一个ngrok.cfg
的文件,修改内容
server_addr: ngrok.example.cn:8082
trust_host_root_certs: false
tunnels:
http:
proto:
http: 80
subdomain: pi
ssh:
remote_port: 8084
proto:
tcp: 22
其中8082要对应服务器端的tunnel地址,否则无法连接。
在本地运行./ngrok -config=ngrok.cfg start http ssh
就可以打开http和ssh的tunnel了
看到Tunnel Status online
以及下面的地址就表面隧道建立好了
这时候就可以通过ssh [email protected] -p 8084
来ssh登录本地账户了,其中user为本地用户名,8084为配置文件中的端口
参考:
http://linfuyan.com/ubuntu-ngrok/
https://zhuanlan.zhihu.com/p/29019562
https://zhuanlan.zhihu.com/p/25768758