ngrok 是用go语言实现的,编译过程碰到不少坑
主要碰到的坑就是依赖错误,以及依赖的包被伟大的GFW给挡住了。 最好是用天朝外的VPS make release-server release-client
修改日志src/ngrok/log/logger.go中的import部分改成
import (
log "github.com/alecthomas/log4go"
"fmt"
)
其他的跟网上的差不多了。 下面就把依赖好的包打包发上来,以及编译的方法给大家说下: 这个包是已经包含好了依赖,拿到包后,确认你的环境,如果你要编译客户端需要go 1.6 否则编译会通不过
- 安装依赖
sudo apt-get install build-essential golang mercurial git
- 解压
tar -zxv -f ngrok.pkg.tar.gz
- 生成证书
openssl genrsa -out base.key 2048
openssl req -new -x509 -nodes -key base.key -days 10000 -subj "/CN=ngrok.youkele.com" -out base.pem
openssl genrsa -out server.key 2048
openssl req -new -key server.key -subj "/CN=ngrok.youkele.com" -out server.csr
openssl x509 -req -in server.csr -CA base.pem -CAkey base.key -CAcreateserial -days 10000 -out server.crt
cp base.pem assets/client/tls/ngrokroot.crt
- 编译服务器
make release-server
- 编译客户端 (go >= 1.6)
#linux
make release-client
#windows
GOOS=windows GOARCH=amd64 make release-client
#mac
GOOS=darwin GOARCH=amd64 make release-client
编译前如果make clean了,那记得把证书再copy一份cp base.pem assets/client/tls/ngrokroot.crt
运行
- 服务器
/usr/local/src/ngrok/bin/ngrokd -tlsKey=/usr/local/src/ngrok/server.key -tlsCrt=/usr/local/src/ngrok/server.crt -domain="ngrok.youkele.com" -httpAddr=":8090" -httpsAddr=":4433"
- 客户端
ngrok.cfg
server_addr: "ngrok.youkele.com:4443"
trust_host_root_certs: false
- 客户端 启动
./ngrok -config=./ngrok.cfg -subdomain=test 8080
./ngrok -h 可以看帮助
- 配置nginx
server {
listen 80;
server_name *.ngrok.xxx.xxx;
access_log /var/log/nginx/xxx.xxx.log;
location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header Host $http_host:8090;
proxy_set_header X-Nginx-Proxy true;
proxy_set_header Connection "";
proxy_pass http://127.0.0.1:8090;
}
}