JRockit JRCMD教程

本文将为您提供概述和教程,说明如何使用jrcmd工具对JRockit Java Heap问题进行初始分析和问题隔离。 将来的文章中将介绍使用JRockit任务控制和堆转储分析(仅限JRockit R28 +版)的更深入的分析和教程。

有关JRockit Java堆空间的快速概述,请查阅以下文章:
JRockit Java堆空间

JRCMD工具概述

jrcmd是一个免费工具,可以在JRockit二进制文件中直接使用。 它允许您从运行时JRockit VM生成和收集关键数据,例如:

  • Java进程内存空间细分(Java堆与本机内存空间)
  • Java堆诊断(直方图)– Java加载的类
  • 按需JRockit堆转储生成(仅版本R28 +)
  • 线程转储生成
  • 更多…

对于本文,我们创建了一个内部泄漏的简单Java程序。 我们将使用该程序来演示如何利用jrcmd进行初始分析。

示例Java内存泄漏程序

这个简单的Java程序只是将String数据添加到静态HashMap中,然后慢慢泄漏到JVM耗尽Java Heap内存的地步。 该程序将允许您通过JRockit jrcmd可视化一个缓慢增长的Java堆泄漏。 请注意,此示例使用了128 MB(-Xms128m –Xmx128m)的Java堆大小。

/*** JavaHeapLeakSimulator* @author Pierre-Hugues Charbonneau* http://javaeesupportpatterns.blogspot.com*/public class JavaHeapLeakSimulator {private final static int NB_ITERATIONS = 500000000;// ~1 KB data footprintprivate final static String LEAKING_DATA_PREFIX = "datadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadata
datadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadata
datadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadata
datadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadata
datadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadata
datadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadatadata";// Map used to stored our leaking String instancesprivate static Map<String, String> leakingMap;static { leakingMap = new HashMap<String, String>();}/*** @param args*/public static void main(String[] args) {System.out.println("Java Heap Leak Simulator 1.0"); System.out.println("Author: Pierre-Hugues Charbonneau");System.out.println("http://javaeesupportpatterns.blogspot.com/");try {for (int i = 0; i < NB_ITERATIONS; i++) {String data = LEAKING_DATA_PREFIX + i;// Add data to our leaking Map data structure...leakingMap.put(data, data);                             // Slowdown the Java program so we can monitor the leak before the OutOfMemoryError conditionThread.sleep(1);}} catch (Throwable any) {if (any instanceof java.lang.OutOfMemoryError) {System.out.println("OutOfMemoryError triggered! "+ any.getMessage() + " [" + any + "]");} else {System.out.println("Unexpected Exception! " + any.getMessage() + " [" + any + "]");}}System.out.println("JavaHeapLeakSimulator done!"); }
}

JRCMD –初始执行

可以从托管您要监视的JVM的本地服务器执行JRCMD,也可以通过JRockit Mission Control远程执行。 可执行文件位于您使用的JRockit JDK中:

<JRockit_JDK_HOME>/bin/jrcmd

默认的jrcmd执行将返回您可以监视的活动JRockit Java进程ID的列表:

C:\Apps\Weblogic1035\jrockit_160_24_D1.1.2-4\bin>jrcmd
5360 org.ph.javaee.tool.oom.JavaHeapLeakSimulator
5952
6852 jrockit.tools.jrcmd.JrCmd

JRCMD – Java堆监视

下一步是开始监视Java Heap内存使用情况和直方图。 Java堆直方图是Java类实例最大池的快照。 这使您可以查明泄漏的数据类型。 Ple

您可以在print_object_summary(快速摘要)或heap_diagnostics(完全分解)之间选择。

C:\Apps\Weblogic1035\jrockit_160_24_D1.1.2-4\bin>jrcmd 5360 heap_diagnosticsInvoked from diagnosticcommand======== BEGIN OF HEAPDIAGNOSTIC =========================Total memory in system: 8465022976 bytes
Available physical memory in system: 5279170560 bytes
-Xmx (maximal heap size) is 134217728 bytes
Heapsize: 134217728 bytes
Free heap-memory: 123592704 bytes--------- Detailed Heap Statistics: ---------90.9% 3948k     5468  +3948k [C 3.0% 128k     5490   +128k java/lang/String2.1% 92k     3941    +92k java/util/HashMap$Entry1.2% 50k      461    +50k java/lang/Class0.8% 35k       21    +35k [Ljava/util/HashMap$Entry;0.6% 24k        7    +24k [B0.3% 15k      305    +15k [Ljava/lang/Object;0.3% 14k      260    +14k java/net/URL0.2% 6k      213     +6k java/util/LinkedHashMap$Entry0.1% 4k      211     +4k java/io/ExpiringCache$Entry0.1% 2k        4     +2k [Ljrockit/vm/FCECache$FCE;0.0% 1k       50     +1k [Ljava/lang/String;0.0% 1k       10     +1k java/lang/Thread0.0% 1k       61     +1k java/util/Hashtable$Entry0.0% 1k        7     +1k [I0.0% 0k       19     +0k java/util/HashMap0.0% 0k       19     +0k java/lang/ref/WeakReference0.0% 0k        7     +0k [Ljava/util/Hashtable$Entry;0.0% 0k       19     +0k java/util/Locale0.0% 0k       11     +0k java/lang/ref/SoftReference0.0% 0k        1     +0k [S
…………………………………………………

–第一列对应于Class对象类型对Java Heap占用量的贡献,以%为单位
–第二列对应于以K为单位的Class对象类型的内存占用量
–第三列对应于特定类型的Class实例的# –第四列对应于特定类型的增量-/ +内存占用量

从上面的快照中可以看到,最大的数据类型是[C(在我们的例子中为char)和java.lang.String。 为了查看泄漏的数据类型,您将需要生成几个快照。 频率将取决于泄漏率。 在我们的示例中,在下面找到5分钟后拍摄的另一个快照:

# After 5 minutes--------- Detailed Heap Statistics: ---------93.9% 26169k    28746 +12032k [C2.4% 674k    28768   +295k java/lang/String2.3% 637k    27219   +295k java/util/HashMap$Entry0.9% 259k       21   +128k [Ljava/util/HashMap$Entry;0.2% 50k      462     +0k java/lang/Class0.1% 24k        7     +0k [B
# After 5 more minutes--------- Detailed Heap Statistics: ---------94.5% 46978k    50534 +20809k [C 2.4% 1184k    50556   +510k java/lang/String2.3% 1148k    49007   +510k java/util/HashMap$Entry0.5% 259k       21     +0k [Ljava/util/HashMap$Entry;0.1% 50k      462     +0k java/lang/Class

第三和第四列显示不断增加。 如您所见,在我们的案例中,泄漏数据为[C,java.lang.String和java.util.HashMap $ Entry,它们都从〜4 MB增加到28 MB,50 MB,并且还在不断增长……

通过这种方法很容易查明泄漏的数据类型,但是泄漏数据类型的来源(根本原因)呢? 这是jrcmd不再有用的地方。 更深入的内存泄漏分析将要求您使用JRockit Mission Control或堆转储分析(仅JRockit R28 +)。

最后一点,在确定真正的Java Heap泄漏之前,请确保在两次捕获之间至少有一个Full GC之后拍摄了jrcmd快照(您感兴趣的是OldGen泄漏,例如,在主要GC集合中幸存的Java对象)。

JRCMD线程转储生成

线程转储分析对于与卡死的线程相关的问题至关重要,但对于解决某些类型的Java Heap问题也很有用。 例如,它可以通过暴露在短时间内在Java Heap上分配大量内存的罪魁祸首来查明Java Heap突然增加的原因。 可以使用jrcmd print_threads选项生成线程转储。

**在删除Thread.sleep()并增加Java堆容量之后,从我们的示例Java程序捕获了线程转储**

C:\Apps\Weblogic1035\jrockit_160_24_D1.1.2-4\bin>jrcmd 5808 print_threads5808:===== FULL THREAD DUMP ===============Mon Apr 09 09:08:08 2012Oracle JRockit(R) R28.1.3-11-141760-1.6.0_24-20110301-1429-windows-ia32
"Main Thread" id=1 idx=0x4 tid=6076 prio=5 alive, native_blockedat jrockit/vm/Allocator.getNewTla(II)V(Native Method)at jrockit/vm/Allocator.allocObjectOrArray(Allocator.java:354)[optimized]at java/util/Arrays.copyOfRange(Arrays.java:3209)[inlined]at java/lang/String.<init>(String.java:215)[inlined]at java/lang/StringBuilder.toString(StringBuilder.java:430)[optimized]at org/ph/javaee/tool/oom/JavaHeapLeakSimulator.main(JavaHeapLeakSimulator.java:38)at jrockit/vm/RNI.c2java(IIIII)V(Native Method)-- end of trace
……………………………………….

我们可以看到示例Java程序正在从执行JavaHeapLeakSimulator程序的“主线程”创建许多java.lang.String对象。

结论

我希望本文能帮助您理解可以利用JRockit jrcmd工具进行快速Java堆分析。 期待您的意见和问题。

未来的文章将包括更深入的JRockit Java堆和堆转储分析教程。

参考: Java EE支持模式和Java教程博客上的JCG合作伙伴 Pierre-Hugues Charbonneau的JRockit jrcmd教程 。


翻译自: https://www.javacodegeeks.com/2012/04/jrockit-jrcmd-tutorial.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/372716.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

sts java配置tomcat_STS配置Tomcat.9.0

今天&#xff0c;心血来潮&#xff0c;弄了一下STS,按着建立WEB项目的方式建立工程。一、新建工程(FILE --NEW--Dynamic Web project)二、输入项目名称&#xff0c;TestWeb&#xff0c;然后下一步&#xff0c;点击FInish.三、新建index.jsp并打开index.jsp,书写测试成功&#x…

javaweb国际化

根据数据的类型不同&#xff0c;国际化分为2类&#xff1a;静态数据国际化和动态数据的国际化。 静态数据&#xff0c;包括 “标题”、“用户名”、“密码”这样的文字数据。 动态数据&#xff0c;包括日期、货币等可以动态生成的数据。 国际化涉及到java.util.Locale和java.ut…

20145335郝昊《网络攻防》Bof逆向基础——ShellCode注入与执行

20145335郝昊《网络攻防》Bof逆向基础——ShellCode注入与执行 实验原理 关于ShellCode&#xff1a;ShellCode是一段代码&#xff0c;作为数据发送给受攻击服务器&#xff0c;是溢出程序和蠕虫病毒的核心&#xff0c;一般可以获取权限。我们将代码存储到对方的堆栈中&#xff0…

Java枚举益智游戏

假设我们有以下代码&#xff1a; enum Case {CASE_ONE,CASE_TWO,CASE_THREE;private static final int counter;private int valueDependsOnCounter;static {int sum 0;for(int i 0; i<10; i) {sum i;}counter sum;} Case() {this.valueDependsOnCounter counter*counte…

jp在java中无法编译_JPanal上加图片的问题!

JPanal上加图片的问题&#xff01;import java.awt.BorderLayout;import java.awt.Dimension;import javax.swing.JFrame;import javax.swing.JPanel;import javax.swing.*;import java.awt.*;public class Frame1 extends JFrame {JPanel contentPane;JLabel jLabel1 new JLa…

玩转Android之加速度传感器的使用,模仿微信摇一摇

Android系统带的传感器有很多种&#xff0c;最常见的莫过于微信的摇一摇了&#xff0c;那么今天我们就来看看Anroid中传感器的使用&#xff0c;做一个类似于微信摇一摇的效果。 OK ,废话不多说&#xff0c;我们就先来看看效果图吧&#xff1a; 当我摇动手机的时候这里的动画效果…

图像

背景图案的设置 将图片插入到网页中去 用图像作为超链接 使用工具建立地图索引 切片索引 为网站添加图标 5.1 背景图案的设置&#xff08;背景不占位置&#xff0c;不影响文本的输入&#xff09; 格式&#xff1a;<body background"URL"> 5.2 将图片插入…

Maven构建依赖项

熟悉发行版和快照依赖项的Maven和Gradle用户可能不了解TeamCity快照依赖项&#xff0c;或者认为他们与Maven相关&#xff08;这是不正确的&#xff09;。 熟悉工件和快照依赖关系的TeamCity用户可能不知道&#xff0c;除了TeamCity提供的插件之外&#xff0c;添加Artifactory插…

Java两种设计模式_23种设计模式(11)java策略模式

23种设计模式第四篇&#xff1a;java策略模式定义&#xff1a;定义一组算法&#xff0c;将每个算法都封装起来&#xff0c;并且使他们之间可以互换。类型&#xff1a;行为类模式类图&#xff1a;策略模式是对算法的封装&#xff0c;把一系列的算法分别封装到对应的类中&#xf…

Problem E: 平面上的点——Point类 (II)

Description 在数学上&#xff0c;平面直角坐标系上的点用X轴和Y轴上的两个坐标值唯一确定。现在我们封装一个“Point类”来实现平面上的点的操作。 根据“append.cc”&#xff0c;完成Point类的构造方法和show()方法&#xff0c;输出各Point对象的构造和析构次序。 接口描述&a…

MFC 控件RadioButton和CheckBox区别

1. 单个RadioButton在选中后&#xff0c;通过点击无法变为未选中 单个CheckBox在选中后&#xff0c;通过点击可以变为未选中 2. 一组RadioButton&#xff0c;只能同时选中一个 一组CheckBox&#xff0c;能同时选中多个 3. RadioButton在大部分UI框架中默认都以圆形表示 CheckBo…

什么是ActiveMQ?

尽管Active MQ网站已经对ActiveMQ进行了详尽的介绍&#xff0c;但我想在其定义中添加更多上下文。 从ActiveMQ项目的网站上&#xff1a; “ ActiveMQ是JMS 1.1的开源实现&#xff0c;是J2EE 1.4规范的一部分。” 这是我的看法&#xff1a;ActiveMQ是一种开源消息传递软件&…

字符串倒着输出java_Java 输出反转字符串

Java 输出反转字符串public class Test {public static void main(String args[]){try{// 获取键盘输入的字符串BufferReader f new BufferReader(new inputStreamReader(System.in));String str f.readline();for (int i str.length() -1 ; i >0 ; i--) {System.out.p…

webpack基础入门

我相信&#xff0c;有不少的朋友对webpack都有或多或少的了解。网上也有了各种各样的文章&#xff0c;文章内作者也写出了不少自己对于webpack这个工具的理解。在我刚刚接触webpack的时候&#xff0c;老实说&#xff0c;网上大部分的文章我是看不懂的。。webpack里面有很多名词…

位运算基础

异或运算的基础有点忘记了 先介绍一下。。2个数异或 就是对于每一个二进制位进行位运算 具有2个特殊的性质 1、一个数异或本身恒等于0&#xff0c;如5^5恒等于0&#xff1b; 2、一个数异或0恒等于本身&#xff0c;如5^0恒等于5。 3 满足交换律 1.交换数字这个性质能利用与交换数…

JAXB自定义绑定– Java.util.Date / Spring 3序列化

JaxB可以处理Java.util.Date序列化&#xff0c;但是需要以下格式&#xff1a; “ yyyy-MM-ddTHH&#xff1a;mm&#xff1a;ss ”。 如果需要将日期对象格式化为另一种格式怎么办&#xff1f; 我有同样的问题时&#xff0c;我正在同春MVC 3和Jackson JSON处理器 &#xff0c;最…

双足机器人简单步态生成

让机器人行走最简单的方法是先得到一组步态曲线&#xff0c;即腿部每个关节随时间运动的角度值。可以在ADAMS或3D Max、Blender等软件中建立好机构/骨骼模型&#xff0c;设计出脚踝和髋关节的运动曲线&#xff0c;然后进行逆运动学解算&#xff0c;测量每个关节在运动过程中的转…

重新访问了访客模式

访客模式是面向对象设计中最被高估但又被低估的模式之一。 高估了它&#xff0c;因为它常常被选择得太快&#xff08; 可能是由建筑宇航员选择的 &#xff09;&#xff0c;然后以错误的方式添加时会膨胀本来非常简单的设计。 如果您不遵循教科书示例&#xff0c;那么它可能会非…

java web开发技术大_2021年六大javaweb开发主流技术

作为历史最为悠久的编程语言——java&#xff0c;历经数十年依然盘踞在编程榜最前面的位置&#xff0c;这与它的技术和应用范围是分不开的&#xff0c;同时呢&#xff0c;javaweb开发主流技术更是java开发者时时刻刻关注的问题&#xff0c;接下来我们一起分析一下2020年互联网行…

ASP.NET—013:实现带控件的弹出层(弹出框)

http://blog.csdn.net/yysyangyangyangshan/article/details/38458169 在页面中用到弹出新页面的情况比较多的&#xff0c;一般来说都是使用JS方法showModalDialog("新页面相对路径?参数1&参数2",window,"新页面样式");然后会新弹出一个模态的page页。…