首页  

jvm外挂工具揭秘     所属分类 java 浏览量 1812
Agent    c 和 Java
Attach  SA 和 VirtualMachine
JMX和PerfData

Native Agent
C/C++ 实现的 Agent,使用 JVMTI(JVM Tool Interface)接口与JVM进行通讯,
订阅感兴趣的JVM事件(比如方法出入、线程始末等),当这些事件发生时,回调Agent代码。 

相关Profile工具,如Yourkit,JProfiler,aysnc-profiler,JRebel
JRebel 动态Reload Class不重启应用


jvm启动命令里加入 -agentlib: 或 -agentpath: /path/to/agent.so
也可以使用 VituralMachine.attach() 动态加载


Java Agent 
底层也是基于 JVMTI
AOP 代码植入  在加载class文件之前做拦截并对字节码做修改。

比如 AspectJ,单元测试覆盖率 Jacoco,动态重载Class的Spring-Loaded

JMXAgent 启动一个线程 监听 响应 JMX 请求

jolokia 启动线程,监听响应 Restful JMX请求

btrace  接收client 脚本字节码,进行加载并输出结果。

两种启动方式

启动命令行加入 -javaagent:/path/to/agent.jar,
根据agent.jar中的MANIFEST.MF文件中的Premain-Class定义,JVM找到相应的MyAgent类,调用其premain函数。

使用 VM.attach() 由外部程序灵活加载,调用其agentmain函数。



Vitural Machine.attach()
通过Unix Domain Socket 与目标JVM的Attach Listener线程进行交互。 
Socket 文件为/tmp/.java_pid$PID。

com.sun.tools.attach.VirtualMachine 及其子类 sun.tools.attach.HotSpotVirtualMachine

在tools.jar中   

 jmap jcmd 默认使用该机制



SA.attach()
Serviceability Agent

分析JVM运行时 Snapshot数据 , 通过系统调用ptrace实现
ptrace会使内核暂停目标进程并将控制权交给跟踪程序,跟踪程序可以察看目标进程的内存

sun.jvm.hotspot.HotSpotAgent 负责 attach
sun.jvm.hotspot.runtime.VM 负责具体操作


VM类 提取JVM内部数据结构

内存 getObjectHeap()/getUniverse()
线程 getThreads()
永久代内容的 getSymbolTable(),getStringTable(), getSystemDictionary()

jstack,jmap 默认使用 VM.attach()模式,与目标JVM的Attach Listener 通信, 
无法响应时 可以使用 -F 参数, 使用SA.attach 模式,用 ptrace 暴力接管进程, 详细代码见 sun.tools.jmap.JMap


PerfData

JVM 统计数据 定期写入到 /tmp/hsperfdata_$username/$pid 文件中

jcmd $PID PerfCounter.print
 
jps 读取 /tmp/hsperfdata_$username/ 目录下所有的文件

jstat 也使用该文件    
JMX需要与应用交互,会干扰应用程序运行

perfdata 和 vm.attach 需要读写 /tmp 目录

JVM启动参数修改临时目录


 java agent 简单例子  
 arthas使用 
 JMX之Jolokia使用 

上一篇     下一篇
innodb mvcc

go http server

实用金融常识

git查看某个文件的变更记录

eclipse关闭验证

约瑟夫环java实现