老技术新谈,Java应用监控利器JMX(3)

【这是一猿小讲的第 46 篇原创分享】

各位坐稳扶好,我们要开车了。不过在开车之前,我们还是例行回顾一下上期分享的要点。

上期我们深入的聊了聊 JMX,把 JMX 的架构了解了七七八八,最后通过代码实战,解决系列疑问,实现远程动态修改应用参数,让线上服务升级、参数调优等系列问题不再难。

说着说着,脑子里突然闪过,过往公司的一次闲聊的场景。那是一个我认为做的非常成功的老码农,给我们分享他的过往,大概是说他们那时候会点技术都很牛掰,面试如果问知道 JSP 吗?如果说知道,那接下来就是明天来上班吧,因为懂的人特别少;然后又分享了一个临近春节,发现线上服务老停,依靠重启来临时解决,但是要过春节,然后就和另一位同事想起临时解决方案:一旦服务发现问题,会发送短信通知,接受短信指令完成服务重启。

现在想想他们为什么要靠短信指令来实现重启呢?无论他分享的这个故事,掺杂水分多少暂且不谈,就凭目前那两位老码农,一个是产品总监、一个是副总裁,而我还在苦逼哈哈的撸代码,我就不得不信服啊。

好了,其它不扯啦,撇下故事情节,get 到重点:如何实现服务的重启?现在已是 9012 年啦,同样的问题,放在当下该如何解决呢?

我们都知道从事编程,没有什么银弹,唯一的银弹就是照猫画虎的多练,其实也就是熟读唐诗三百首,不会作诗也会吟,那不妨就看看别人咋实现的。

倒腾出 Resin 的源码,虽然很多人都是第一次与 Resin 谋面,没关系你就认为是 Tomcat 就好了,只要能打通任督二脉,管它是啥呢,主要是实现思想。

面对一个开源项目或者技术轮子,我常用的大概有以下几招,接下来把招式一五一十的都献上,请各位笑纳。

招式一:用一用

先把源码跑起来,看一看,用一用,想一想。导入项目,准备工作一定要做到位,然后依据 manifest 清单文件(稍微规范点的都有这个文件),找到应用程序入口。

老技术新谈,Java应用监控利器JMX(3)_第1张图片

Resin 源码运行时需要传入参数 watchdog,其实支持 N 多命令(不深究)。

老技术新谈,Java应用监控利器JMX(3)_第2张图片

访问 http://127.0.0.1:8080/ 看看启动成功没?

老技术新谈,Java应用监控利器JMX(3)_第3张图片

点击 /resin-admin 访问 resin 监控管理平台,首次登陆需要配置用户名密码,后续直接登录即可,成功页面如下。

老技术新谈,Java应用监控利器JMX(3)_第4张图片

点点菜单玩一玩,点击 memory 菜单,效果如下,但是数据怎么来的呢?疑问先放一边,不要阻碍功能体验。

老技术新谈,Java应用监控利器JMX(3)_第5张图片

再点击 thread 菜单,效果如下,但是数据又是怎么来的呢?疑问还是先放一边,不要阻碍功能体验。

老技术新谈,Java应用监控利器JMX(3)_第6张图片

点击 webapp 菜单,效果如下,关键是对应的 Actions 操作还真能完成对应的服务的 start、stop、restart,天啦撸,惊呆了众人有没有。

老技术新谈,Java应用监控利器JMX(3)_第7张图片

其它菜单也可以肆意的点点看,可能有意想不到的惊喜。

招式二:问一问

抱着自己的疑惑,去摸索,尝试灭掉心中的疑问。请来 JConsole 来个助攻,控制台敲入 jconsole,连上 Resin 进程,打入 Resin 内部,窥探一下。

看看上面点击 memory 菜单中的数据从哪儿来的?果不其然,发现 Resin 自定义了一个 MemoryMXBean ,而且里面的属性刚好与 memory 菜单中对应上。那大概知道咋回事了,你清楚了没?没搞懂的猿粉后台直接留言啊。

老技术新谈,Java应用监控利器JMX(3)_第8张图片

再看看上面点击 thread 菜单中的数据从哪儿来的?意料之中,发现 Resin 自定义了一个 ThreadPoolMXBean ,而且里面的属性也刚好与页面上的对应上,大概也就是那么回事儿,你 get 到了没?

老技术新谈,Java应用监控利器JMX(3)_第9张图片

不妨再看看点击 webapp 菜单时,那些 start、stop、restart 如何又是让服务完成对应重启、停止、重启操作的呢?不得不说 Resin 还是按照常规的设计,自定义了一个 WebAppMXBean,而且提供了 start()/stop()/restart() 等操作方法,不得不说设计很高端。

老技术新谈,Java应用监控利器JMX(3)_第10张图片

老技术新谈,Java应用监控利器JMX(3)_第11张图片

说到这,那不妨演示一下服务的停止、重启功能,不然难以服众,再次点击 resin-admin 的 webapp 菜单,效果如下。

老技术新谈,Java应用监控利器JMX(3)_第12张图片

回到 JConsole 页面,我们点击 stop() ,停止 resin-admin 服务,直接看图就行。

老技术新谈,Java应用监控利器JMX(3)_第13张图片

此时我们再访问管理控制台页面,果不其然,服务不可用。

老技术新谈,Java应用监控利器JMX(3)_第14张图片

不妨在 JConsole 中点击 start() 启动一下服务,看图就行。

老技术新谈,Java应用监控利器JMX(3)_第15张图片

此时我们再访问 resin-admin 管理控制台页面,居然又可以正常访问,真是逆天的节奏。

老技术新谈,Java应用监控利器JMX(3)_第16张图片

备注:借助 JConsole 是为了看清楚定义了很多 MXBean,其实页面上的 start、stop、restart 按钮完成的功能 与 JConsole 的操作是一样的。

招式三:记一记

深入任何框架源码,打日志是必不可少的环节,为了便于把源码流程给串起来,关键位置一定要打印属于自己风格日志,最好是狂打属于自己的日志,然后跑起来用日志串一串流程。

老技术新谈,Java应用监控利器JMX(3)_第17张图片

招式四:画一画

是否可以画画类图梳理梳理关系,在全局上看一看。如果用的是 IDEA,那么生成类图,超级之简单。选择接口或者类,然后右键选择菜单 Diagrams --> Show Diagram... (请记住该操作,平时工作中真会帮助你省很多事情)

老技术新谈,Java应用监控利器JMX(3)_第18张图片

老技术新谈,Java应用监控利器JMX(3)_第19张图片

效果如下,清晰明了,系列 MXBean 映入眼帘,并且继承关系与咱们的日志的打印差不多(看不清的放大了看啊,哈哈)。

老技术新谈,Java应用监控利器JMX(3)_第20张图片

难道一个 Resin 应用服务器就这么点玩意,其实真实是下面这样的,真的好庞大(图片看不清,其实这个真看不清就对了,需要用高倍望眼镜,复杂的有点辣眼睛),但是实现套路都是一样的,都是一系列的 MXBean 定义。

640?wx_fmt=png

是否也可以画画时序图答案是必须的,前提是 IDEA 装了 SequenceDiagram 插件,举个栗子(只是举栗,重在告诉你方式方法)。

老技术新谈,Java应用监控利器JMX(3)_第21张图片

招式五:猜一猜

访问 http://127.0.0.1:8080/resin-admin/?q=index&s=0 前端页面咋运转的?

潜心去看,会发现 resin-admin 的页面是 PHP 语言实现的,其实很简单,就是获取请求 URL 中的 q 参数,然后直接把对应的 page 页面展示出来,如果传入的 q 参数是空,则默认展示 summary 页面。

老技术新谈,Java应用监控利器JMX(3)_第22张图片

例如http://127.0.0.1:8080/resin-admin/?q=memory&s=0  则会把 memory.page 展示出来,可以看到里面是通过访问MBeanServer 找到对应的 MemoryMXBean 并获取对应的值。

老技术新谈,Java应用监控利器JMX(3)_第23张图片

招式六:仿一仿

思考我们是否可以借鉴思想去实现呢?照猫画虎,答案是肯定的,今天就先不深入去开展了。

好了,今天主要借助对 Resin 源码的简单剖析,让我们更深入理解 JMX 的应用;同时想传达面对框架源码或者技术轮子时,平时我常用的一些方式方法,简单划分为六大招式:用一用、问一问、记一记、画一画、猜一猜、仿一仿,希望对你能有点帮助。

好了,今天的车要到站了,还有很多应用场景没有说,咱们还是且听下回分解吧,真心希望一猿小讲的每篇分享都能帮到你一点点。

最后如果感觉有点帮助,不妨锻炼一下手指点个在看,或者再来个疯狂分享转发,因为你的每一次分享,我都认真当成了鼓励与喜欢。

老技术新谈,Java应用监控利器JMX(3)_第24张图片

推荐阅读:

老技术新谈,Java应用监控利器JMX(1)

老技术新谈,Java应用监控利器JMX(2)

人生靠反省,Java靠泛型

爱情36技之暗送秋波的技术

你可能感兴趣的:(老技术新谈,Java应用监控利器JMX(3))