美文网首页
让 Ngrok 变得更好,Ngrok 重构小记

让 Ngrok 变得更好,Ngrok 重构小记

作者: 程序员麦叔叔 | 来源:发表于2018-03-05 15:25 被阅读0次

我们经常需要由外网访问内网的机器,什么时候会用到外网访问内网?我们就假设这么一种情景,有 1000 台设备安装我们家的软件。这 1000 台设备不一定是 PC 机,有可能是无人售货机,有可能是手持的 POS 机,也有可能是一体化的点餐系统,那么如何去管理这些设备,或者说升级安装在这些设备上的软件?

很多人可能会说,让软件具有自动升级功能不就可以了吗?但是有由于设备的多样性,环境的多样性,往往使得升级不一定成功。在这种情况下,如果要跑到客户那里去维护,成本太高了。如果能通过外网连接这些设备,通过终端去管理它们,无疑要高效很多。

在网上搜了一下,发现 ngrok 是个不错的选择。亲自试用了一下,的确好用。但是,同时也发现了不少问题

  1. 不够稳定,无论服务端还是客户端,在使用一段时间后,就会挂掉。据说开源的 1.7 版本有严重的内存泄漏,估计是这个问题引起的。
  2. 我希望通过 Nginx 把请求转发到 Ngrokd 去,但是支持的不是很好。
  3. 服务端不能集群,通过集群,可以提高系统的可用性,并发性。
  4. 安装部署不方便,需要编译源码才能安装。

基于以上种种问题,我希望能对它进行改进。我希望的架构是

 -----------------------------------
 | ---------- ---------- ---------- |
 | | Ngrokd | | Ngrokd | | Ngrokd | |
 | ---------- ---------- ---------- |
 -----------------------------------
     |                      |
     |TCP                   | HTTP 请求
     |                      |
     |         ----------------------
     |         |     HTTP PROXY     |
     |         ----------------------
     |                       |
     |                       |
----------------------------------
|           NGINX                |
----------------------------------
                       |
                       |
| --------- -------- --------- ------ |
| Ngrok | | Ngrok | | Ngrok | | Ngrok | 
| --------- -------- ---------- ----- |

有了这个想法后,首先就下载源码,打开一看,还是有点复杂。代码各个模块的耦合度很高,各种功能都塞到一块去了。并且是自己不熟悉的 GO 语言,有点想放弃,但苦于没有更好的方案,只好硬着头皮上了。

如何去重构呢?首先要做的,就是根据目标架构,剥离各种不必要的功能,减少类,减少接口,减少方法。根据我们的架构,有这些功能可以剥离的

  1. 服务端 HTTPS 请求的支持,由于使用了 NGINX 作为代理,服务端只需要支持 HTTP 请求就可以了。
  2. 服务端与客户的安全连接,同样由于使用了 NGINX ,可以不要。
  3. 服务端的对访问设备的安全认证,剥离集成到 NGINX
  4. 客户端的 HTTP 请求的监控,也是可以不要的。
  5. 客户端 UI 部分,也是可以精简的

经过这么一系列的精简后,代码量大概只有原来的 30%, 大大提高了可维护性。

代码托管在 https://github.com/ansiboy/mgrok

感兴趣的朋友可以关注一下

相关文章

  • 让 Ngrok 变得更好,Ngrok 重构小记

    我们经常需要由外网访问内网的机器,什么时候会用到外网访问内网?我们就假设这么一种情景,有 1000 台设备安装我们...

  • myshop readme

    shop 配置 ngrok ngrok下载和基本使用从https://ngrok.com/ 下载ngrok 下面...

  • SSH 内网穿透术

    让 ngrok, localtunnel 等见鬼去吧!(ngrok 不用的理由,localtunnel-serve...

  • 使用Ngrok实现内网穿透服务

    # 使用Ngrok实现内网穿透服务 tags: 网络 Linux ngrok ngrok是什么? ngrok是一个...

  • ngrok使用

    ngrok的使用步骤如下: 1. 进入ngrok官网(https://ngrok.com/),注册ngrok账号并...

  • 微信

    http://ngrok.ciqiuwl.cn/ ngrok -config=ngrok.cfg -subdoma...

  • Linux 14.04配置ngrok

    ngrok 国内一个免费的ngrok 由于ngrok编译时候制定了域名以及证书,所以不同的ngrok-client...

  • Mac端口映射

    1.下载ngrok 地址:https://ngrok.com/download 2../ngrok http 80...

  • 内网穿透(mac)

    我使用的是:ngrok1.下载ngrok:https://ngrok.com/download[https://n...

  • Mac上如何使用ngrok映射外网

    如何在Mac上使用ngrok? 1. 下载Mac版ngrok:https://ngrok.com/download...

网友评论

      本文标题:让 Ngrok 变得更好,Ngrok 重构小记

      本文链接:https://www.haomeiwen.com/subject/tceaaxtx.html