JPDA 架构研究2 - JVMTI代理

简介:

引入:

我们先从JVMTI讲起。JVMTI的主要作用是提供一组接口来检测VM的状态和控制VM中运行的JAVA程序。JVMTI是个双向接口:

JVMTI的客户端叫Agent,它会在VM发生变化时通过事件机制被通知到变化。

JVMTI的服务端是许多函数,它们会和VM实际打交道并把结果告知Agent.


实践:

我们这里先来看下Agent. 


Agent的方法定义在哪里呢?它们定义在$JAVA_HOME/include/jvmti.h文件中。

1
2
3
4
5
JNIEXPORT jint JNICALL
Agent_OnLoad(JavaVM *vm,  char  *options,  void  *reserved);
 
JNIEXPORT  void  JNICAL。
Agent_OnUnload(JavaVM *vm);


Agent_OnLoad方法:

当代理被VM加载时,会由VM调用Agent_Onload方法。此时VM有如下能力:

(1)VM的System Property已经被设置完毕。

(2)VM的Capabilities已经被设置完毕。

(3)任何字节码都没被执行。

(4)任何类都没有被加载。

(5)任何对象都没有被创建。


Agent_OnLoad实现过程中,最重要的事情之一就是调用GetEnv方法来获取JVMTI环境的指针。

1
jint GetEnv(JavaVM *vm,  void  **env, jint version);

这样,这个代理就可以知道被代理的环境的全部信息。



Agent_OnUnload方法:

当代理被VM卸载时,会由VM调用Agent_OnUnload方法。一般发生在终止VM的时候,它一般可以用来清理在Agent_OnLoad阶段创建的资源。


因为我们在远程调试时候启动JVM时候加了代理参数:

java -agentlib:<agentLibName> ,而agentLibName我们配置的是jdwp, 所以它就对应上jdwp.dll.

也就是远程调试时候自动会在启动target VM时候启用jdwp这个代理库.


当明白了代理的作用后,我们来找其的实现。在Sun的JDK中,我们找到了jdwp.dll (Linux环境则是jdwp.so) .  它位于 $JAVA_HOME/jre/bin目录下。我们用exeScope软件打开查看内容:

wKiom1SFSz7xFsInAAJpNug-rho655.jpg

显然,它是Oracle的Sun的JDK提供的Agent ,它提供了2个方法,一个是_Agent_OnLoad(),一个是_Agent_OnUnload() 

wKiom1SFS37Ty0DhAAEzsbfIxTM606.jpg

和我们设想的一致。





总结:

从上过程我们似乎可以总结一些结论:

1. Agent 是在虚拟机启动之时加载的,这个加载处于虚拟机初始化的早期.在这个时间点上:

  所有的 Java 类都未被初始化;所有的对象实例都未被创建; 因而,没有任何 Java 代码被执行; 

(从这点上说,最明显的好处就是它能完成早期调试中用System.out.println()无法解决的问题,因为System.out.println()前提是代码行所在的类已经被初始化过了)

2.但在这个时候,我们已经可以:

操作 JVMTI 的 Capability 参数; 使用系统参数; 动态库被加载之后,虚拟机会先寻找一个 Agent 入口函数.





本文转自 charles_wang888 51CTO博客,原文链接:http://blog.51cto.com/supercharles888/1587548,如需转载请自行联系原作者
目录
相关文章
|
6月前
|
设计模式 架构师 Java
阿里P8架构师都要学习研究的java加强版23种设计模式神级PDF文档
说在前面的话 Java作为老牌纯正的编程语言,在规范性上有着天然优势。因此本版的设计模式讲解全部用Java语言来描述,并针对Java语言的特性对讲解内容做了相当大的改动。 不知道大家是否听过编程界的一段话:掌握设计模式相当于华山派的"气宗",是程序员的内功修为,虽然在同样的学习时间下,类似Python这种"剑宗"的开发模式见效更快,但是长远来看,"气宗"才是走向软件架构师以上级别的必由之路。 所以,掌握气宗就掌握了编程命脉,然而学习设计模式有四大境界: 接下来给大家分享的就是java溢彩加强版大话设计模式包含的内容知识点。 总目录 主要内容 本文是百万销量的经典畅销书《
119 0
|
8月前
|
存储 监控 关系型数据库
|
8月前
|
存储 人工智能 Cloud Native
云原生大数据架构实践与思考-DataFunTalk
导读: 作者:振策-阿里云计算平台-产品解决方案, 20230805 本文将分享当前云原生大数据架构的发展历程/架构定义/核心能力/应用场景及趋势思考。主要包括以下四个部分: - 从大数据上云看架构 - 云原生数据平台的核心能力 - Data+AI with Cloud-Native - 未来趋势与思考
1314 0
|
11月前
|
网络协议 数据可视化 NoSQL
【服务网格架构】Envoy架构概览(8):统计,运行时配置,追踪和TCP代理
【服务网格架构】Envoy架构概览(8):统计,运行时配置,追踪和TCP代理
|
11月前
|
网络协议 数据可视化 NoSQL
Envoy架构概览(8):统计,运行时配置,追踪和TCP代理
Envoy架构概览(8):统计,运行时配置,追踪和TCP代理
|
11月前
|
数据采集 机器学习/深度学习 设计模式
卷麻了! nnUNet 研究团队重磅新作 | MedNeXt: 新一代分割架构之王,刷新多项榜单记录!
卷麻了! nnUNet 研究团队重磅新作 | MedNeXt: 新一代分割架构之王,刷新多项榜单记录!
550 0
|
11月前
|
SQL 存储 缓存
图解MySQL系列(2)-SQL实战研究InnoDB架构设计
业务系统通过一个数据库连接发给MySQL,经过SQL接口、解析器、优化器、执行器,解析SQL语句,生成执行计划,接着由执行器负责执行该计划,调用InnoDB的接口去实际执行。
155 0
|
存储 缓存 NoSQL
【Laravel框架】对于Laravel框架架构的研究以及视图方法和内置会话在项目里的运用
【Laravel框架】对于Laravel框架架构的研究以及视图方法和内置会话在项目里的运用
255 0
【Laravel框架】对于Laravel框架架构的研究以及视图方法和内置会话在项目里的运用
|
存储 运维 负载均衡
基于网关服务治理的研究与实践(一)微服务架构
本篇原创系列是对基于网关服务治理的开篇介绍,作为服务治理的引子,介绍了目前主流的微服务架构技术,包括微服务架构的概念与优势、服务注册与发现、服务路由与负载均衡、服务安全等内容。
1337 0
基于网关服务治理的研究与实践(一)微服务架构
|
消息中间件 调度
架构模式-事件驱动架构-代理者拓扑
架构模式 事件驱动架构 代理者拓扑 broker topology
242 0
架构模式-事件驱动架构-代理者拓扑