弄了一个小东西,轻量级的 NodeJS 内存监控工具
发布于 2 年前 作者 JerryC8080 3509 次浏览 来自 分享

Memeye

Memeye 是一个轻量级的 NodeJS 进程监控工具,它提供 进程内存、V8 堆空间内存、操作系统内存 三大维度的数据可视化展示。 前端部分,借助 Vue2ChartJS 提供了一个不错的动态展示面板。
Memeye 在宿主进程中,只植入了一个简单的数据收集器,其他工作则启动一个子进程,交由子进程来进行。
这样做能把 Memeye 的代码对宿主进程的影响降到最低,以确保数据的真实性。

特点

  • 轻量级
  • 简单
  • 面向开发环境
  • 可视化

Note: Memeye 暂时只支持单进程,NodeJS 分布式进程还不适用,所以不建议在产品环境使用。

动机

总所周知,NodeJS 对内存是很敏感的。在去年 4 月我用 NodeJS 做的一个营销性的项目,在上线当天 PV 突破了 100W。
其中内存就呈现出持续上涨趋势,在排查问题的过程中,想寻找一个轻量级的,只要可视化的呈现内存使用情况的工具,无果。
然后就有了这个项目的想法,但当时由于繁忙只做出了一个 Demo 级别的,简单能用就发布了。
最近有时间,再次翻出来,重构改版,增加更多维度的数据展示。

Demo

See preview demo (也许需要翻墙)

兼容性

  • Node v7.x
  • Node v6.x

安装 & 使用

运行下面命令安装 :

npm install memeye --save-dev

然后在你的代码中引入

const memeye = require('memeye');
memeye();

最后打开你的浏览器,输入下面地址:

http://localhost:23333  //23333 port by defaul.

就这么简单!

Memeye 是如何工作的

Memeye 有三个核心概念:Collector, Indicators, Dashboard。
Collector 运行在宿主进程中(你的NodeJS进程),Indicator 和 Dashboard 运行在子进程中,这样可以尽量减少 Memeye 代码对你的宿主进程的影响。

Collector

Collector 会监听宿主进程,并且收集数据,然后通过 IPC 通信管道发送数据给子进程,交由子进程处理。

Indicator

Indicator 像一个状态机。当它的属性变化的时候,会触发相应事件。所以我们可以用它来处理收集回来的数据。

Dashboard

Dashboard 会以子进程的形式唤起。他会创建一个 Indicator 实例,以及启动一个集成 socket.io 的 Http 服务器。
然后绑定 Indicator 和进程通信管道,以接收父进程发过来的数据。
最后再绑定 Indicator 和 socket.io,这样可以在 Indicator 属性变化的时候发送数据给前端。

##Collector, Indicator, Dashboard 之间的通信

commication.jpeg

预览

预览

12 回复

真不错,数据核心应该是调用 v8模块process.memoryUsage() 暴露的数据做了收集和处理吧。其实线上一般来说只会关注 堆内内存 大小,如果更深入做一下堆内内存的结构解析就更好了,毕竟可以定位到疑似泄漏点

先star了,有空再看

棒棒哒,可以加精华了

非常不错!

@hyj1991 感谢支持,你说的没错,主要用了 v8process.memoryUsage()os 模块。关于更加深入的分析和研究,可以放到后面的版本加上。😁

@i5ting 😏 说的好像狼叔有权限加精似的。

jerry,我把你的代码看了一遍,写的很直观,也学到不少。 英文注释我很喜欢,哈哈

已加星~😁

@slashhuang 哈哈,没想到还有人看源码了,羞涩🙈

@tonny0812 谢谢,么么哒。

真不错 好厉害

回到顶部