CentOS 7 搭建ngrok服务器(外网映射内网)

时间:2022-09-17 15:51:09
  1. 准备
    一台云服务器(本文ECS),一个域名(二级域名也可以),并且域名正确解析到云服务器

  2. 安装环境
    安装gcc和git(下载ngrok源码)

    yum install gcc -y
    yum install git -y

  3. 安装go语言环境
    去官网https://golang.org/dl/下载最新安装包
    网很慢的下载地址:https://pan.baidu.com/s/1c2i2oaG(官网1.9.2版本)
    解压缩

    tar -c /usr/local/ -zxvf go1.9.2.linux-amd64.tar.gz

    添加到环境变量

    vi /etc/profile
    export GOROOT=/usr/local/go
    export PATH= PATH: GOROOT/bin
    source /etc/profile

    查看是否安装成功(查看版本号)

    go version
    go version go1.9.2 linux/amd64

  4. 搭建Ngrok服务
    下载ngrok源码

    cd /usr/local/ngrok
    git clone https://github.com/tutumcloud/ngrok.git ngrok

    生成证书

    cd ngrok
    NGROK_DOMAIN=”你的域名”

openssl genrsa -out base.key 2048
openssl req -new -x509 -nodes -key base.key -days 10000 -subj "/CN=$NGROK_DOMAIN" -out base.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 base.pem -CAkey base.key -CAcreateserial -days 10000 -out server.crt

将新生成的证书,替换掉assets/client/tls下的证书

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

编译生成ngrokd和ngrok

make release-server release-client

正常执行后,ngrok/bin 目录下应该有 ngrok、ngrokd 两个可执行文件。

启动服务端

sudo ./bin/ngrokd -tlsKey=server.key -tlsCrt=server.crt -domain="你的域名" -httpAddr=":7009" -httpsAddr=":7008"

httpAddr、httpsAddr 分别是 ngrok 用来转发 http、https 服务的端口,可以随意指定。ngrokd 还会开一个 4443 端口用来跟客户端通讯(可通过 -tunnelAddr=”:xxx” 指定),如果你配置了 iptables 规则,需要放行这三个端口上的 TCP 协议。
现在,通过 https://你的域名:7009和 https://你的域名:7008就可以访问到 ngrok 提供的转发服务

出现下面提示则说明成功

[22:07:18 CST 2017/12/07] [INFO] (ngrok/log.(*PrefixLogger).Info:83) [registry] [tun] No affinity cache specified
[22:07:18 CST 2017/12/07] [INFO] (ngrok/log.Info:112) Listening for public http connections on [::]:7009
[22:07:18 CST 2017/12/07] [INFO] (ngrok/log.Info:112) Listening for public https connections on [::]:7008
[22:07:18 CST 2017/12/07] [INFO] (ngrok/log.Info:112) Listening for control and proxy connections on [::]:4443
[22:07:18 CST 2017/12/07] [INFO] (ngrok/log.(*PrefixLogger).Info:83) [metrics] Reporting every 30 seconds

5. 编译生成ngrok(windows客户端)

GOOS=windows GOARCH=amd64 make release-client

成功会在bin目录下看到windows_amd64文件夹,复制到windows电脑上即可启动

get /usr/local/ngrok/ngrok/bin/windows_amd64/ngrok.exe

6. windows端运行
创建一个文件,命名为ngrok.cfg,写入一下内容

server_addr: "你的域名:4443"
trust_host_root_certs: false

在创建一个启动bat文件,命名为start.bat

ngrok -config=ngrok.cfg -subdomain 映射本地的域名 本地的端口
如ngrok -config=ngrok.cfg -subdomain sb 8081

启动start.bat文件

外网域名访问
http://映射本地的域名:7009
映射到本地的地址是
127.0.0.1:本地的端口