- 解析域名: 或者
- 安装 git、gcc、golang、wget:
yum -y install gcc golang wget
- 下载ngrok:
cd /usr/local/
git clone https://github.com/dollarphper/ngrok.git
cd ngrok/
- 配置环境变量:
export NGROK_DOMAIN="dollarphp.com"
- 生成证书:
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
- 生成服务器文件:
make release-server
- 生成客户端文件:
# linux:
GOOS=linux GOARCH=amd64 make release-client
# windows:
GOOS=windows GOARCH=amd64 make release-client
# mac
GOOS=darwin GOARCH=amd64 make release-client
- 生成自启动文件: a. 创建shell脚本: a-1. 创建文件夹:
mkdir -p /home/lee/ngrok
a-2. 编写shell脚本: vim /home/lee/ngrok/ngrok.sh
#!/bin/bash
/usr/local/ngrok/bin/ngrokd -log="/var/log/ngrok/ngrok.log" -domain="dollarphp.com" 1> /dev/null 2> /var/log/ngrok/ngrok.log &
echo $! > /var/run/ngrok.pid
b. 创建启动服务: vim /usr/lib/systemd/system/ngrok.service
[Unit]
Description=ngrok
After=network.target
[Service]
Type=forking
PIDFile=/var/run/ngrok.pid
ExecStart=/bin/bash /home/lee/ngrok/ngrok.sh
ExecStop=pkill ngrok
PrivateTmp=true
[Install]
WantedBy=multi-user.target
c. 创建日志文件:
mkdir -p /var/log/ngrok
touch /var/log/ngrok/ngrok.log
d. 启用服务:
systemctl enable ngrok
e. 添加开机自启动:
chkconfig ngrok on
- 启动服务:
systemctl start ngrok
- 拷贝服务端文件到客户端:
scp root@104.225.233.xxx:/usr/local/ngrok/bin/ngrok ./
- 编写配置文件: vim ngrok.conf
server_addr: "dollarphp.com:4443"
trust_host_root_certs: false
tunnels:
http:
subdomain: "test"
proto:
http: "80"
ssh:
remote_port: 8023
proto:
tcp: "22"
- 连接:
./ngrok -log=ngrok.log -config=ngrok.conf start http ssh
- 生成自启动文件: a. 创建shell脚本: vim /home/lee/ngrok/ngrok.sh
#!/bin/bash
/home/lee/ngrok/ngrok -config=/home/lee/ngrok/ngrok.conf start http ssh &
echo $! > /var/run/ngrok.pid
b. 创建启动服务: vim /usr/lib/systemd/system/ngrok.service
[Unit]
Description=ngrok
After=network.target
[Service]
Type=forking
PIDFile=/var/run/ngrok.pid
ExecStart=/bin/bash /home/lee/ngrok/ngrok.sh
ExecStop=pkill ngrok
PrivateTmp=true
[Install]
WantedBy=multi-user.target
c. 启用服务:
systemctl enable ngrok
d. 添加开机自启动:
chkconfig ngrok on