深入浅出带你了解JVM中的OQL
OQL (Object Query Language)类似于 SQL 的查询语言,可以方便在堆中进行对象的查找和 筛选。
语法
select [from[instanceof] ][where ]
select * from com.XX.CacheManager
例子(MAT 版本)
1.查询string
SELECT * FROM java.lang.String
2.正则查询 java.lang
SELECT FROM "java.lang.."
3.查询类地址0x79571fb40
SELECT * FROM 0x79571fb40
4.属性访问器
SELECT * FROM ${snapshot}.getClasses()
5.条件查询
SELECT FROM java.lang.String s WHERE toString(s) LIKE ".day"
6.查询char数组长度大于 10 的
select * from char[] s where s.@length > 10
7.查询长度大于 15 且深堆大于 1000 字节的所有 Vector 对象
select * from java.util.Vector v where v.elementData.@length > 15 AND v.@retainedHeapSize > 1000
8.显示Vector内部数组长度
SELECT v.elementData.@length FROM java.util.Vector v
9.显示int数组索引下表为 2 的数据内容
SELECT s.getValueAt(2) FROM int[] s WHERE (s.@length > 2)
10.显示堆中所有类型
select * from ${snapshot}.getClasses()
11.显示长度为 4 且值不为空的string对象内容
SELECT toString(s) FROM java.lang.String s WHERE ((s.value.@length = 4) and (s.value != null))
12.查看保留集
SELECT AS RETAINED SET * from com.mousycoder.mycode.thinking_in_jvm.Student
13.查询 string 实例
select distinct objects classof(s) from java.lang.String s
14.查询包下的实例
select from "com.mousycoder.mycode.thinking_in_jvm.."
15.查找子类
SELECT * FROM INSTANCEOF java.util.AbstractCollection
16.查看类的属性
SELECT toString(f.path.value) FROM java.io.File f
17.查看对象地址
SELECT s.toString(), s.@objectId, s.@objectAddress FROM java.lang.String s
例子(Visual VM版本)
筛选长度大于 100 的字符串
select s from java.lang.String s where s.value.length >=100
2.查找 classloader的子类
select cl from instanceof java.lang.ClassLoader cl
3.查找父类
select heap.findClass("java.util.Vector").superclasses()
4.输出引用链
select heap.livepaths(s) from java.lang.String s where s.toString() == '56'
5.访问对象属性
select heap.findClass("com.mousycoder.mycode.thinking_in_jvm.TraceStudent").webpages
6.查看可达对象
select {r:toHtml(reachables(s)),url:s.url.toString()} from com.mousycoder.mycode.thinking_in_jvm.WebPage s
7.长度为 2 至少被 2 个对象引用的字符串
select s.toString() from java.lang.String s where (s.value != null && s.value.length == 2 && count(referrers(s)) >= 2)
8.查找直接引用对象
select referees(s) from com.mousycoder.mycode.thinking_in_jvm.Student s
9.Vector的浅堆
select {size:sizeof(o),Object:0} from java.util.Vector o
10.Vector的深堆
select {size:sizeof(o),rsize:rsizeof(o)} from java.util.Vector o
11.通过File 类打开的文件
select {size:sizeof(o),rsize:rsizeof(o)} from java.util.Vector o
12.查找长度最长的 5 个字符串并显示对象和长度
select map (top(filter(heap.objects('java.lang.String'),'it.value !=null'),'rhs.value.length -lhs.value.length',5),'{length: it.value.length,obj:it}')
13.查看string字符串一共多少个不重复的元素
select count(unique(map(heap.objects('java.lang.String'),'it.value')))
14.统计脚本
var sessions = toArray(heap.objects("http://java.lang.xxx")) var count = sessions.length; var createtimes = new Array(); for(var i=0;i

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
[Spring cloud 一步步实现广告系统] 9. 主类和配置文件
搜索系统启动主类 /** * AdSearchApplication for 广告搜索服务启动类 * * @author <a href="mailto:magicianisaac@gmail.com">Isaac.Zhang | 若初</a> */ @EnableFeignClients //启动Feign 客户端,为了访问其他微服务 @EnableDiscoveryClient // 开启服务发现组件,在这里等同于 @EnableEurekaClient @EnableHystrix // 开启hystrix 断路器 @EnableCircuitBreaker // 断路器 @EnableHystrixDashboard // 开启hystrix 监控 @SpringBootApplication public class AdSearchApplication { public static void main(String[] args) { SpringApplication.run(AdSearchApplication.class, args); ...
- 下一篇
继续南山聊代码!Apache Kafka × Apache Flink Meetup · 深圳站
8 月 31 日,Apache Flink Meetup 深圳站来啦,继续南山聊代码!本次 Meetup 由 Apache Flink(以下简称 Flink)与 Apache Kafka 联合举办,邀请到来自 Confluent 、中国农业银行 、虎牙直播、数见科技以及阿里巴巴等五位技术专家为大家呈现 Kafka 与 Flink 的技术盛宴。 ▼ 活动亮点 ▼ Flink 1.9 版本中 SQL 的新增功能有哪些,现场 Demo 演示最佳实践的姿势和调优经验; Confluent 资深系统工程师分享在现代数据驱动架构中 Kafka 扮演怎样的角色; 中国农业银行分享 Flink 在金融科技的反欺诈、系统异常检测、实时数据统计等探索与实践; 虎牙直播在混合云、边缘计算等新的基础资源框架下实时计算平台的探索与实现; 数见科技 CTO 分享批流一
相关文章
文章评论
共有0条评论来说两句吧...