Ngrok安装配置

  • Ngrok安装配置已关闭评论
  • 114 views
  • A+
所属分类:编程开发 运维实战

前言

实际开发测试环境中,我们一般都是在内网开发,所以说对于移动端测试是一件比较麻烦的事情,尤其是adsl还没有共有ip。

内网穿透

这时候,我们就需要内网穿透服务来解决第三方服务无法回调的问题了,下面我们来稍微盘点那些流行的内网穿透技术。

Ngrok

ngrok 是一个反向代理,通过在公共的端点和本地运行的 Web 服务器之间建立一个安全的通道。ngrok 可捕获和分析所有通道上的流量,便于后期分析和重放(百度百科)。

  • 优点:使用方便,Docker容器化,配置简单,各平台支持,也可以自己搭建服务器
  • 缺点:ngrok 是一个开源程序,官网服务在国外,国内访问国外速度慢。1.7+以后不再开源,收费才是持续发展的动力

国内也有相应的ngrok服务 natapp、frp、nat123端口映射、内网通、花生壳等等,这里就不一个个介绍了,有兴趣的可以自行谷歌,毕竟今天的主角是Ngrok。

下面一张图我们来了解一下Ngrok的穿透流程:

Ngrok安装配置

环境说明

云服务器Linux(centos7.4)、Nginx、Docker、hteen/ngrok Docker镜像,备案域名一枚

申请key

如果你没有带公网的服务器搭建ngrok服务器端也没有域名的话,那么你可以通过从https://ngrok.com/ 注册一个账号 获取官方分配一个密钥,使用免费的服务器端,只对于只是使用的adsl的人来说,比较方便。

服务器端搭建

获取ngrok镜像:

docker pull hteen/ngrok

启动

  • 我们需要挂载宿机目录(E.g /data/ngrok)到容器的/xubo/ngrok目录
  • 第一次运行,它将会在/data/ngrok目录下生成二进制文件和CA证书
docker run --rm -it -e DOMAIN="ngrok.baiked.com" -v /data/ngrok:/ngrok hteen/ngrok /bin/sh  /build.sh

安装成功会出现以下提示(省略中间过程):

Generating RSA private key, 2048 bit long modulus
.............................+++
.............................+++
e is 65537 (0x10001)
Generating RSA private key, 2048 bit long modulus
...............................+++
...............................+++
go get -tags 'release' -d -v ngrok/...
go install -tags 'release' ngrok/main/ngrok
build ok !

客户端和服务端生成在/data/ngrok/bin目录下:

bin/ngrokd                  服务端
bin/ngrok                   linux客户端
bin/darwin_amd64/ngrok      osx客户端
bin/windows_amd64/ngrok.exe windows客户端

启动Ngrok server

由于ngrok默认使用80和443端口,这里我们使用Nginx服务做转发,通过端口映射的方式访问Docker容器(参考docker-compose.yml配置)。

docker run -idt --name ngrok-server \
-v /data/ngrok:/xubo/ngrok \
-p 8082:80 \
-p 4432:443 \
-p 4444:4443 \
-e DOMAIN='ngrok.baiked.com' hteen/ngrok /bin/sh /server.sh

启动之后需要在nginx.conf 添加两条反向代理配置(HTTPS请求自行配置):

server {
     listen       80;
     server_name  ngrok.baiked.com *.ngrok.baiked.com;
     location / {
             proxy_redirect off;
             proxy_set_header Host $host;
             proxy_set_header X-Real-IP $remote_addr;
             proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
             proxy_pass http://127.0.0.1:8082;
     }
 }

配置DNS解析

服务启动后,要想正常运行,我们还需要添加两条A记录到云服务器(替换成自己的IP地址):

这里需要把ngrok.baiked.com和*.ngrok.baiked.com的a记录指向服务端带公网的ip

 

客户端搭建

没有公网ip,也没有备案域名,情况下:

Ngrok安装配置

如上图,申请完auth后,直接下载客户端,直接启动就行,如下:

./ngrok authtoken 3dyiFw7exxxxxxWgWsk_4c1M9dokdJHgvmRAnoTq2

有自己的服务端的情况下:

启动Ngrok client

首先从data/ngrok/bin目录下载各个环境下的客户端。

windows 环境

首先创建一个ngrok.cfg配置文件:

server_addr: "ngrok.baiked.com:4444"
trust_host_root_certs: false

使用cmd命令切换到对应的目录下,然后执行以下命令:

ngrok.exe  -config  ngrok.cfg -subdomain   doc 192.168.1.125:4999

如果出现以下文字,说明安装成功:

Versionerface 2.3.27
Web Interface 192.168.1.125:4999
Forwarding http://22047e4b.ngrok.io -> http://192.168.1.125:4999
Linux 环境
[root@k3s ~]# ./ngrok -config ngrok.cfg -subdomain doc 192.168.1.125:4999

Session Status connecting  Session Status online
Versionerface 2.3.27
Web Interface 192.168.1.125:4999
Forwarding http://22047e4b.ngrok.io -> http://192.168.1.125:4999

 

 

 

 

 

 

 

 

  • 安卓客户端下载
  • 微信扫一扫
  • weinxin
  • 微信公众号
  • 微信公众号扫一扫
  • weinxin
avatar