ngrok搭建教程,亲自测试没问题

 

需要内网域名一个,服务器一台,我的服务器是阿里云国内的,域名也是在阿里云买的,在测试后需要备案,后面我换了一个备案域名就可以访问了。

安装git, golang和openssl

yum install -y git golang openssl

使用git下载项目

git clone https://github.com/inconshreveable/ngrok.git /usr/local/ngrok

 

#进入到ngrok目录生成证书

域名解析

ngrok搭建教程,亲自测试没问题_第1张图片

需要解析域名到服务器,测试域名能访问服务器后进行下面操作。

#准备一个独立域名,备好案的,替换下面的axiba.xyz域名
cd /usr/local/ngrok

# 下面的命令用于生成证书
openssl genrsa -out rootCA.key 2048
openssl req -x509 -new -nodes -key rootCA.key -subj "/CN=axiba.xyz" -days 5000 -out rootCA.pem
openssl genrsa -out device.key 2048
openssl req -new -key device.key -subj "/CN=axiba.xyz" -out device.csr
openssl x509 -req -in device.csr -CA rootCA.pem -CAkey rootCA.key -CAcreateserial -out device.crt -days 5000

# 将我们生成的证书替换ngrok默认的证书,会提示覆盖,输入y
cp rootCA.pem assets/client/tls/ngrokroot.crt
cp device.crt assets/server/tls/snakeoil.crt
cp device.key assets/server/tls/snakeoil.key

编译服务端与客户端

#64位的linux服务端
GOOS=linux GOARCH=amd64 make release-server
#64位的windos客户端
GOOS=windows GOARCH=amd64 make release-client

编译后的服务端与客户端在ngrok/bin目录下

第一个目录下面的ngrokd是服务端,第二个目录下的需要拷贝ngrok.exe到windos平台,可以使用winScp和Xftp等工具。

启动服务端

./bin/ngrokd -domain="axiba.xyz"

如下图就启动成功

然后我们需要在防火墙中运行这几个端口通过,或者关闭防火墙,然后还需要在服务器对应的云平台设置安全组,允许这几个端口通过

然后在需要代理的windos平台吧刚才那个exe文件下载下来,然后在同级目录下新建ngrok.cfg与start.bat

ngrok的内容

server_addr: "axiba.xyz:4443"
trust_host_root_certs: false

 

start.bat的内容

ngrok.exe -subdomain=wx -config=ngrok.cfg 80

wx 是本地自定义下级域名,80是代理的端口

编辑好后点击start.bat

ngrok搭建教程,亲自测试没问题_第2张图片

显示成功,第一访问的时候可能比较慢,请耐心。

设置开机自动启动

进入指定目录下

cd /etc/systemd/system/

新建文件

touch ngrok.service

编辑文件

vim ngrok.service
cription=ngrok
After=network.target

[Service]
ExecStart=/usr/local/ngrok/bin/ngrokd -domain=axiba.com

[Install]
WantedBy=multi-user.target

加入开机启动

systemctl enable ngrok.service //加入开机启动
systemctl daemon-reload  //重新载入 systemd,扫描新的或有变动的单元
reboot //重启系统

其他代码

    systemctl 是管制服务的主要工具, 它整合了chkconfig 与 service功能于一体。
     
    systemctl is-enabled iptables.service
    systemctl is-enabled servicename.service #查询服务是否开机启动
    systemctl enable *.service #开机运行服务
    systemctl disable *.service #取消开机运行
    systemctl start *.service #启动服务
    systemctl stop *.service #停止服务
    systemctl restart *.service #重启服务
    systemctl reload *.service #重新加载服务配置文件
    systemctl status *.service #查询服务运行状态
    systemctl --failed #显示启动失败的服务
     
    注:*代表某个服务的名字,如http的服务名为httpd

 

你可能感兴趣的:(后端技术)