Ngrok经过代理的方式实现两个不一样的网络之间的通讯。一般用于实现内网与外网之间某些服务的穿透,若是要使用ngrok服务实现内外网穿透,可使用其余人提供的ngrok服务,下载对应的客户端进行配置便可。也能够根据本身的须要使用本身的服务器实现ngrok公网服务,下面介绍如何本身搭建ngrok服务器。node
注意ngrok服务端程序与客户端程序因为会在编译时将对应的证书编译进去,因此一般须要成套使用,除非服务端特殊说明并提供了自身的证书文件,不然非配套的客户端可能没法链接非配套的服务端 mysql
ngrok也能够在编译完成后使用其余的证书文件启动,一样客户端也可使用其余的证书而非内置的证书来连接服务端,有须要的同窗能够自行查找资料或者看看官方文档,这里不进行说明 git
接下来进行服务端程序与客户端程序的编译与配置说明github
部署ngrok服务须要有如下条件:golang
ngrok.你的域名 *.ngrok.你的域名
(ps:这里的ngrok前缀能够随意更换,只要下边使用到域名的位置与这里保持一致便可)编译ngrok的可执行文件以前咱们须要先给ngrok生成一套证书,以供ngrok的服务端和客户端进行认证,该证书能够从证书颁发机构获取,也能够自行生成,在shell中执行如下命令web
export NGROK_DOMAIN=ngrok.你的域名 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
其中的“ngrok.你的域名”替换为你本身设置的域名地址,这里咱们生成好的证书在下边会被用到。ngrok是用go语言写的一个开源项目,因此在编译时须要有go语言的环境,使用以下方式安装sql
# CentOS/ReadHat yum install golang # unbuntu/debian apt install golang
以后将ngrok源码克隆到本地,而后进入到ngrok的项目目录,在进行编译以前,咱们须要先用上边生成的证书文件替换掉ngrok自身的默认证书文件shell
git clone https://github.com/inconshreveable/ngrok cd ngrok cp /上边证书的目录/server.key ./assets/server/tls/snakeoil.key cp /上边证书的目录/server.crt ./assets/server/tls/snakeoil.crt cp /上边证书的目录/rootCA.pem ./assets/client/tls/ngrokroot.crt
接下来执行make release-server
命令进行服务端程序的编译工做,若是成功编译就会在./bin目录下会生成一个可执行文件ngrokd服务端程序vim
ps:若是未能成功编译,能够在./docs/SELFHOSTING.md文件中找到编译说明
ps:编译时须要clone其余几个github项目,若是没法自动clone也能够按照编译时的信息手动进行克隆,克隆完成后再进行make release-server便可api
执行make release-client
来编译ngrok的客户端程序,若是成功编译就会在./bin目录下生成一个可执行文件ngrok(注意是否是ngrokd,有d的是服务端程序名称)
接下来咱们就可使用该套服务端与客户端进行内网穿透了,首先启动服务端程序,推荐写成系统服务的配置文件,这样能够经过systemtl来进行管理
将./bin/ngrokd文件拷贝到/usr/local/bin目录下cp ./bin/ngrokd /usr/local/bin
,而后建立vim /etc/systemd/system/ngrokd.service
文件,将以下内容写入其中
[Unit] Description=ngrok service After=network.target After=syslog.target [Service] Type=simple ExecStart=/usr/local/bin/ngrokd -domain=ngrok.你的域名 -log=/var/log/ngrokd.log -log-level=WARNING ExecStop=/bin/kill $MAINPID ExecReload=/bin/kill -USR1 $MAINPID Restart=always [Install] WantedBy=multi-user.target
ps:这里的“ngrok.你的域名”替换为你上边为证书设置的那个域名,域名左右必定不能带有引号,不然没法正确解析域名地址
ps:在启动服务端以前必须先将日志文件建立出来,ngrok不会自动建立该文件,若是不预先建立将没法启动服务 touch /var/log/ngrokd.log
而后经过systemctl start ngrokd
来启动你的服务端进程,若是须要开机启动能够执行systemctl enable ngrokd
来加入开机启动的服务列表
将咱们以前生成的./bin/ngrok客户端下载到须要穿透内网的机器上而且拷贝到/usr/local/bin目录下,在该机器上建立一个yaml配置文件:vim ~/.ngrok.yml
并写入以下内容
server_addr: ngrok.你的域名.com:4443 # 这里指定客户端要链接的服务端的域名和端口号,4443是默认的监听的端口,能够在服务端进行更改 trust_host_root_certs: false # 这里指定是否验证服务端的证书,若是是从证书机构获取的证书则能够写为true,若是是本身生成的证书这里写为false tunnels: # 这个配置项是你要开启的通道的配置 ssh: # ssh是这个通道的名称,能够随意命名 remote_port: 5022 # 该配置项能够申请远程服务器的固定端口,若是不设置该参数,每次在启动客户端的时候服务端都会随机分配一个端口号 proto: # 该配置项指明该通道使用哪些协议 tcp: 22 # 该配置项指明该通道开启本地tcp协议的22(sshd服务)端口,即将远程的5022端口转发到本地22端口 mysql: remote_port: 53306 proto: tcp: 3306 next: subdomain: web # 若是是启动http的通道则能够指定该配置项来声明该通道监听的子域名是什么,在访问时应该访问web.ngrok.域名 proto: http: 80 api: subdomain: api proto: http: 80
最后启动咱们的ngrok客户端程序便可,/usr/local/bin/ngrok -log=/var/log/ngrok.log -log-level=WARNING -config=/你上边的yml配置文件的路径,这里要写绝对路径/.ngrok.yml start-all
ps:在启动客户端以前必须先将日志文件建立出来,ngrok不会自动建立该文件,若是不预先建立将没法启动 touch /var/log/ngrok.log
若是启动后显示的界面中Tunnel Status一项显示为online则表示链接成功,经过ctrl + c来关闭客户端程序,这里也能够参照上边服务端的系统配置文件将客户端的启动也加入系统服务
若是没成功链接请检查你的服务器防火墙是否开放了相关端口,以及你的域名是否正确添加了解析记录