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

我们经常需要由外网访问内网的机器,什么时候会用到外网访问内网?我们就假设这么一种情景,有 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

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,497评论 19 139
  • 第一章 Nginx简介 Nginx是什么 没有听过Nginx?那么一定听过它的“同行”Apache吧!Ngi...
    JokerW阅读 32,884评论 24 1,002
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,692评论 25 709
  • 2017年7月13号 朱博康 河南博物院创建于1927年,是中国建立较早的博物馆之一,当时馆址定在开封,1961年...
    岳小白他爸爸阅读 1,079评论 0 0
  • 一花一世界一叶一菩提
    彭城浪子阅读 1,488评论 0 0