题目:构建自己的监测工具
作者:
Andrew Wilcox, 高级架构师, MentorGen LLC
这篇文章的目标是要自己实现一个Profiler,在实现的时候,他用到了很多5.0的agent api实在是让我打开眼界。先来一个最简单的就是通过Runtime的addShutdownHook()方法可以注册一个虚拟机结束时的钩子。
然后开始的就是怎么用java.lang.instrument当中的新类来监视jvm了,以前想到过hack jvm的方法只是自己定义一个classloader来控制类加载的流程,但是这个通过agent的方式更是走前了一步,他只需要在启动jvm时增加一个参数,让vm加载你的类,那么就可以完全的监视整个程序的执行流程。实在好玩。
PS:原文当中的Profiler可能是有问题的,因为他用asm weav为其他类添加那些profile方法时,没考虑到profile的start()和end()方法也会被weav掉,所以start()和end()可能会陷入无限递归。