Visual VM对OQL的支持

上面我们学会了如何查看堆内存快照,但是,堆内存快照十分庞大,快照中的类数量也很多。Visual VM提供了对OQL(对象查询语言)的支持,以便于开发人员在庞大的堆内存数据中,快速定位所需的资源。

2.1 Visual VM的OQL基本语法

OQL 语言是一种类似SQL的查询语言。基本语法如下:

  1. select <JavaScript expression to select>

  2. [ from [instanceof] <class name> <identifier>

  3. [ where <JavaScript boolean expression to filter> ] ]

OQL由3个部分组成:select 子句、from 子句和where 子句。select 子句指定查询结果要显示的内容;from 子句指定查询范围,可指定类名,如java.lang.String、char[]、[Ljava.io.File(File数组);where 子句用于指定查询条件。

select 子句和where 子句支持使用Javascript 语法处理较为复杂的查询逻辑;select 子句可以使用类似json的语法输出多个列;from子句中可以使用instanceof关键字,将给定类的子类也包括到输出列表中。

在Visual VM的OQL中,可以直接访问对象的属性和部分方法。如下例中,直接使用了String对象的count属性,筛选出长度大于等于100的字符串:

select s from java.lang.String s where s.count >= 100

选取长度大于等于256的 int 数组:

select a from int[] a where a.length >= 256

筛选出表示两位数整数的字符串:

select {instance: s, content: s.toString()} from java.lang.String s where /^\d{2}$/(s.toString())

上例中,select 子句使用了json语法,指定输出两列为String对象以及String.toString() 的输出。where 子句使用正则表达式,指定了符合/^\d{2}$/条件的字符串。

下例使用 instance 关键字选取所有的ClassLoader,包括子类:

select cl from instanceof java.lang.ClassLoader cl;

由于在Java程序中,一个类可能会被多个ClassLoader同时载入,因此,这种情况下,可能需要使用Class的ID来指定Class。如下例,选出了所有ID为0x37A014D8的Class对象实例。

select s from 0x37A014D8 s;

解决内存泄露的一个方法是分许heap dump文件,可以参考 http://visualvm.java.net/oqlhelp.html

我自己总结了一下以后可能用到的一些OQL,如下:

查找所有包含指定类的list

heap.objects(heap.findClass("java.util.ArrayList"),true, function(it){
if(it.size<=0){
return false ;
}
var i=0;
var data = it.elementData[0];
var className = classof(data).name;
if(isClass(className)){
return true
}else{
return false;
}

} )

function isClass(name){
var pattern = /com.netease/ ;
var result = pattern.exec(name);
return result!=null;
}

查找业务类直接或者间接引用的list

select filter(heap.livepaths(s),function(it){

var array = it ;
var i= 0;
var size = array.length;
for(;i<size;i++){
var className = classof(array[i]).name;
if(isClass(className)){
return true
}else{
return false;
}
}
return true ;

}) 
from java.util.ArrayList s

查找包含内容最多的List,这个应该是查找内存泄露的好语句
map(top(heap.objects('java.util.ArrayList'), 'rhs.size - lhs.size', 5),"toHtml(it)+'='+it.size")

查找当前系统属性
map(heap.objects(heap.findClass("com.netease.Main")),"it.size")

查找同样内容最多的string
var counts={};
var alreadyReturned={};

filter(
sort(
map(heap.objects("java.lang.String"),
function(heapString){
if( ! counts[heapString.toString()]){
counts[heapString.toString()] = 1;
} else {
counts[heapString.toString()] = counts[heapString.toString()] + 1;
}
return { string:heapString.toString(), count:counts[heapString.toString()]};
}), 
'lhs.count < rhs.count'),
function(countObject) {
if( ! alreadyReturned[countObject.string]){
alreadyReturned[countObject.string] = true;
return true;
} else {
return false;
}
}
);

以后可能用到的一些OQL相关推荐

  1. ORM查询语言(OQL)简介--概念篇

    相关文章内容索引: ORM查询语言(OQL)简介--概念篇 ORM查询语言(OQL)简介--实例篇 ORM查询语言(OQL)简介--高级篇:脱胎换骨 ORM查询语言(OQL)简介--高级篇(续):庐山 ...

  2. ORM(一)OQL结构图

    代码是基于:1.1   从上图我们可以看出接口IExpression是比较重要的接口,所有与SQL语句相关的接口都继承了此接口. 在这里我称IExpression接口为表达式接口.我理解SQL里所有的 ...

  3. JVM OQL查询语言

    OQL查询语言 SELECT Clause The SELECT clause determines what to extract from the heap dump. To display ob ...

  4. java oql_深入理解java虚拟机(八):java内存分析工具-MAT和OQL

    以下内容翻译自MAT帮助文档. 一.Class Histogram Class Histogram shows the classes found in the snapshot, the numbe ...

  5. java query object_Object Query Language (OQL) query 基本使用

    OQL是对java堆内存进行查询分析 使用方法: 1.查看java线程id jps -lvm 上图红框中的为pid: 2.运行命令-导出堆内存信息-会生成一份文件在你本地 jmap -dump:liv ...

  6. Java虚拟机性能监测工具Visual VM与OQL对象查询语言

    1.Visual VM多合一工具 Visual VM是一个功能强大的多合一故障诊断和性能监控的可视化工具,它集成了多种性能统计工具的功能,使用 Visual VM 可以代替jstat.jmap.jha ...

  7. jhat中的OQL(对象查询语言)

    jhat中的OQL(对象查询语言) 如果需要根据某些条件来过滤或查询堆的对象,这是可能的,可以在jhat的html页面中执行OQL,来查询符合条件的对象 基本语法: select <javasc ...

  8. Mendix中OQL

    文章目录 1.概念 2.OQL表达式 2.1 OQL聚合 2.2 OQL函数 2.21 OQL CASL 2.24 OQL COLALESCE 2.23 OQL DATEDIFF 2.24 OQL D ...

  9. Android性能优化—MAT之OQL详解(三)

    OQL是Object Query Language的简写,即对象查询语言,OQL语法和关系型标准查询语言SQL的语法相似,只是增加了比如对象标识.复杂对象.操作.继承.多态性以及联系. SELECT ...

最新文章

  1. 自动驾驶公司Momenta完成超2亿美元融资,估值超10亿美元
  2. 11月份西部数码.wang域名注册量及市场份额统计报告
  3. 《LeetCode力扣练习》第53题 最大子数组和 Java
  4. ajax如何知道超时请求,如何发送ajax请求来检查会话超时并在grails中呈现relogin消息?...
  5. 信息系统项目管理师需要准备多久?备考技巧分享
  6. 一个java文件中多个类
  7. linux字符驱动向vxworks移植,VxWorks驱动移植至SylixOS总结
  8. Spring配置中的classpath:与classpath*:的区别研究
  9. sdk是什么_海外APP和游戏中最常用SDK排名(截止5月17, 2020)
  10. python入门——P43魔法方法:算数运算2
  11. Linux web服务与HTTP协议基础概念
  12. android开发分页查询,Android开发中实现分页效果的简单步骤
  13. 安装双系统后无法进入第二系统
  14. 新起点、新目标--获得MVP后的感悟
  15. 阿里云与腾讯云的区别对比
  16. 电子密码锁程序C语言,基于C语言STC89C52单片机电子密码锁的系统设计与仿真
  17. 炫云渲染农场next客户端22546更新内容一览
  18. 寒假怎么过?经典计算机教材助你弯道超车
  19. 拉线传感器的数显仪表在测量中起到多大的作用
  20. 幽默的最高境界——这才叫幽默

热门文章

  1. 逻辑运算 或,与,非
  2. vscode 配置 pcl头文件库
  3. 计算器软件设计和计算机软件设计区别,求一个模拟计算器程序
  4. 160 - 51 DueList.6
  5. php 邮件验证_PHP程序来验证电子邮件地址
  6. ffplay分析 (视频从Frame(解码后)队列取数据到SDL输出)
  7. 汇编语言-008(条件跳转应用 、loopnz 条件循环指令使用 、loopz 条件循环指令使用 、 if语句编写汇编时 、while语句编写汇编时 、循环内的if语句嵌套)
  8. 2016_icpc_dalian_onsite
  9. verilator编译 更新文件的规则
  10. 【蓝桥杯】BASIC-8 回文数(2020-06-08)