在我们常用的Jstack, Jmap 用于分析java虚拟机的状态的工具,通过起另一个虚拟机通过运行sun.tools包下的java文件,去跟踪另一个虚拟机的状态。
如果让你设计一个跟踪另一个进程的方法,你也通常会考虑这几种常用的方式。
第一种,就是通知被跟踪的进程,让进程执行相应的消息,同时对该消息做出反应。
第二种,就是通过内核的调用,直接能够访问进程的内存,堆栈情况,通过分析被跟踪的进程的内存结构,从而知道当前被跟踪的进程的状态。
第一种方式
优势:
对调用者和被调用者只要达成简单的通讯协议,调用者无需知道被调用者的逻辑,结构,只需要简单的发送命令的方式,被调用者能够接受到命令,并且对该命令进行回应就可以。
缺点:
如果被调用者当时的状态本来就不正常,或者繁忙,没办法对该命令做出响应,那这个跟踪进程往往是在规定的等待时间里,无法返回正确的需要的信息。其次被调用者在分析的过程中,有可能需要暂停进程中的其他的线程,而对被跟踪的进程有一定的影响。
第二种方式
优势:
通过内核的支持,访问被跟踪的内存,并作出快照,后台分析,很少影响被跟踪的进程。
缺点:
这种方式需要对被跟踪程的内存分配和使用非常的了解,无法解耦,而本身系统内核调用也会出问题。
Java工具类中也是大致实现了这2中方式,工具中会先选择第一种方式,如果发现第一种方式不能成功,将会建议使用-F参数,也就是第二种方式。
我们先讲第一种方式。
既然是需要向被跟踪进程发出命令,在linux中可以选择多种方式进行进程中通讯 共享内存,文件之类,其中创建socket的文件实现通讯是比较简单的方法。
下面是整个的流程图:

分享到:
相关推荐
为了监控Java应用的性能,可以使用`jps`(Java进程状态)列出运行中的Java进程,`jstat`(JVM统计监测工具)查看JVM的统计信息,`jmap`(内存映射工具)生成堆转储,以及`jhat`(堆分析工具)分析堆转储。...
详细请看: Java 工具(jmap,jstack)在linux上的源码分析(五) -F 参数的bug的解决lib (http://blog.csdn.net/raintungli/article/details/7245709) 自己编译的,测试能够通过
OpenJDK-7与Oracle JDK在功能上基本一致,但OpenJDK是开放源代码的,对于那些希望查看源码或者对Java技术进行研究的开发者来说,OpenJDK具有一定的优势。然而,由于OpenJDK可能没有Oracle JDK那样频繁的更新,所以在...
- 使用`jinfo`, `jmap`, `jstat`, `jstack`等工具进行实时监控和诊断。 总的来说,OpenJDK 11提供了许多增强功能和性能优化,是现代Java开发的重要基础。了解并掌握其特性和使用方法,对于任何Java开发者来说都是至...
此外,`jar`命令用于打包和处理Java类库,`javadoc`生成API文档,`jps`列出运行的Java进程,`jstack`和`jmap`用于诊断和分析内存及线程问题。这些工具对于Java开发者来说是不可或缺的。 总之,"jdk-6u31-linux-x64...
Linux下的Apache Tomcat 7.0.56服务器是一个用于部署和运行Java应用程序的开源Web应用服务器,尤其适合处理Servlet和JSP。Tomcat作为轻量级应用服务器,以其高效、稳定和易于管理的特点,成为了许多开发者的首选。在...