`
younglibin
  • 浏览: 1207685 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

outOfMemeoryError处理

 
阅读更多

outOfMemeoryError处理(使用hprof)

1. 程序出现 

 

Exception in thread "pool-1-thread-2" java.lang.OutOfMemoryError: Java heap space

 

2. 找到是哪些 代码 导致出现了 这样的问题

 

3. 使用 

 

-Xrunhprof:heap=sites,depth=12 再次启动程序 

 

  <jvmarg  value="-Xrunhprof:heap=sites,depth=12"/>

  <xmlfileset refid="testng.conf"/>

</testng>

 

 

 

4.看生成的文件   java.hprof.txt  查看调用栈  TOP 10 的调用栈

 

 

 

298625           percent          live          alloc'ed  stack class

298626  rank   self  accum     bytes objs     bytes  objs trace name

298627     1 15.60% 15.60%   8400672 25002   8400672 25002 322798 char[]

298628     2  6.69% 22.29%   3600288 25002   3600288 25002 322771 org.testng.internal.TestNGMethod

298629     3  6.69% 28.98%   3600288 25002   3600288 25002 322805 org.testng.internal.ConfigurationMethod

298630     4  6.69% 35.67%   3600144 25001   3600144 25001 322882 org.testng.internal.ConfigurationMethod

298631     5  6.32% 41.98%   3400272 25002   3400272 25002 322822 char[]

298632     6  5.94% 47.92%   3200128 25001   3200128 25001 322896 char[]

298633     7  3.72% 51.64%   2000160 25002   2000160 25002 322799 org.testng.internal.NoOpTestClass

298634     8  2.60% 54.24%   1400112 25002   1400112 25002 322782 java.lang.Object[]

298635     9  2.60% 56.84%   1400112 25002   1400112 25002 322814 java.lang.Object[]

298636    10  2.60% 59.44%   1400112 25002   1400112 25002 322816 java.lang.Object[]

298637    11  2.60% 62.04%   1400056 25001   1400056 25001 322890 java.lang.Object[]

298638    12  2.60% 64.64%   1400056 25001   1400056 25001 322891 java.lang.Object[]

298639    13  2.60% 67.24%   1400056 25001   1400056 25001 323002 java.lang.Object[]

298640    14  2.23% 69.47%   1200072 50003   1200072 50003 322813 java.util.ArrayList

298641    15  2.23% 71.70%   1200072 50003   1200072 50003 322815 java.util.ArrayList

298642    16  2.23% 73.93%   1200048 25001   1200048 25001 323000 org.testng.internal.SingleTestMethodWorker

 

 

 

292945 TRACE 322771:

292946   org.testng.internal.BaseTestMethod.<init>(BaseTestMethod.java:89)

292947   org.testng.internal.BaseTestMethod.<init>(BaseTestMethod.java:85)

292948   org.testng.internal.TestNGMethod.<init>(TestNGMethod.java:46)

292949   org.testng.internal.TestNGMethod.clone(TestNGMethod.java:167)

292950   org.testng.internal.TestNGMethod.clone(TestNGMethod.java:25)

292951   org.testng.internal.Invoker.invokePooledTestMethods(Invoker.java:1430)

292952   org.testng.internal.Invoker.invokeTestMethods(Invoker.java:1167)

292953   org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:127)

292954   org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:111)

292955   java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)

292956   java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)

292957   java.lang.Thread.run(Thread.java:662)

 

 

 

在 : invokeTestMethods  方法中有如下  代码  : 

由于本次代码的invocationCount  只是 1000000  太大 ,循环内部 每次都在创建 ITestResult testResult  这个对象导致内存溢出

 

while(invocationCount-- > 0) {

      boolean okToProceed = checkDependencies(testMethod, allTestMethods);

 

      if (!okToProceed) {

        //

        // Not okToProceed. Test is being skipped

        //

        ITestResult testResult = new TestResult(testClass, null /* instance */,

                                               testMethod,

                                               null /* cause */,

                                               start,

                                               System.currentTimeMillis(),

                                               m_testContext);

        String missingGroup = testMethod.getMissingGroup();

        if (missingGroup != null) {

          testResult.setThrowable(new Throwable("Method " + testMethod

              + " depends on nonexistent group \"" + missingGroup + "\""));

        }

 

        testResult.setStatus(ITestResult.SKIP);

        result.add(testResult);

        m_notifier.addSkippedTest(testMethod, testResult);

        runTestListeners(testResult);

        return result;

      }

 

 

解决办法 ,可以自己实现他的 线程调用,这样testng 中每次代码调用完成,就会 进行 GC 回收

 

 

 

 

 

hprof出处来源网址: http://www.cnblogs.com/linhaohong/archive/2012/07/12/2588657.html

J2SE中提供了一个简单的命令行工具来对java程序的cpu和heap进行 profiling,叫做HPROF。HPROF实际上是JVM中的一个native的库,它会在JVM启动的时候通过命令行参数来动态加载,并成为 JVM进程的一部分。若要在java进程启动的时候使用HPROF,用户可以通过各种命令行参数类型来使用HPROF对java进程的heap或者 (和)cpu进行profiling的功能。HPROF产生的profiling数据可以是二进制的,也可以是文本格式的。这些日志可以用来跟踪和分析 java进程的性能问题和瓶颈,解决内存使用上不优的地方或者程序实现上的不优之处。二进制格式的日志还可以被JVM中的HAT工具来进行浏览和分析,用 以观察java进程的heap中各种类型和数据的情况。

在J2SE 5.0以后的版本中,HPROF已经被并入到一个叫做Java Virtual Machine Tool Interface(JVM TI)中。

 

hprof使用来源网址: http://www.ms-accp.com/New-1346.html

 

java -Xrunhprof:heap=sites  -Xms4100m -Xmx4100m  -Djava.library.path=$LD_LIBRARY_PATH -classpath ./build/classes:./build/*:./conf:./lib/* com.yoyosys.yihualu.ehual    uImpl.StartYhl parser.properties

 

 

在执行命令的根目录 会生成  java.hprof.txt  这个文件 

当命令行 出现   一下字段 ,表示  该文件已经生成

 Dumping allocation sites ... done.

如果程序处于 停滞状态 ,使用 Ctrl+c  直接终止 ,运行 这一个文件也能够生成!

 

 

这部分的一个实例展示了我们怎样才能够运行装载在JDK 中的剖析器。尽管从剖析器而来

的消息是以略显粗糙的文本文件形式表示的,而不是像一般的商业剖析器那样产生图形化的

表示,但是在判定我们程序的特性方面,它仍然能够提供很有价值的帮助。

当我们调用程序时,通过向Java 虚拟机传送一个额外参数来运行剖析器。这个参数必须是

一个单一字符串,逗号后面没有任何空格,像这样(尽管它应该在一个单一的行中,但是在

书中被缠绕表示了,因为书页面不够宽):

 

 

java

–Xrunhprof:heap=sites,cpu=samples,depth=10,monitor=y,thread=y,

doe=y ListPerformance

?? heap=sites 告知剖析器编写在堆上的内存使用信息,指示被分配在什么地方。

?? cpu=samples 告知剖析器进行统计抽样来确定CPU 的使用情况。

?? depth=10 指示线程追踪的深度(默认是4)。

?? thread=y 告诉剖析器去标识在堆栈序列中的线程。

?? doe=y 告知剖析器在退出时清空剖析数据。

下面的列表仅包含 HPROF 所产生的文件的一部分。输出文件被创建在当前目录下并且被命

名为java.hprof.txt。

java.hprof.txt 开始部分描述了文件中其余部分的细节。由剖析器产生的数据处于不同

部分;例如,TRACE 表示文件中的追踪部分。我们将会看到许多TRACE 部分,每个都编了

号,以便可以在后面进行引用。

SITES 部分展示了内存分配的位置。这部分有几行,它们按照被分配和被引用的字节(活

动着的字节)数排序。内存以字节列出。Self 列代表该位置占据内存的百分比,下一列

accum,代表累积的内存百分比。live bytes 和live objects 列代表在该位置上的活

动的字节数和所创建的、占用这些字节的对象个数。allocated bytes 和 objects 代

表实例的对象总数和字节总数,包括那些正在被使用的和没有被使用的。在allocated 和

live 中列出的字节数之差代表可以被垃圾收集的字节数。Trace 列实际上引用了文件中的

一个TRACE。第一行引用了下面显示的668 追踪。name 代表被创建实例所属的类。

SITES BEGIN (ordered by live bytes) Thu Jul 18 11:23:06 2002

percent live alloc'ed stack class

rank self accum bytes objs bytes objs trace name

1 59.10% 59.10% 573488 3 573488 3 668 java.lang.Object

2 7.41% 66.50% 71880 543 72624 559 1 [C

3 7.39% 73.89% 71728 3 82000 10 649 java.lang.Object

4 5.14% 79.03% 49896 232 49896 232 1 [B

5 2.53% 81.57% 24592 310 24592 310 1 [S

TRACE 668: (thread=1)

java.util.Vector.ensureCapacityHelper(Vector.java:222)

java.util.Vector.insertElementAt(Vector.java:564)

java.util.Vector.add(Vector.java:779)

java.util.AbstractList$ListItr.add(AbstractList.java:495)

ListPerformance$3.test(ListPerformance.java:40)

ListPerformance.test(ListPerformance.java:63)

ListPerformance.main(ListPerformance.java:93)

这个追踪展示了分配内存的方法调用序列。如果我们进入由行号所指示的追踪,我们将发现

有一个对象分配动作发生在 Vector.java 的222 行:

elementData = new Object[newCapacity];

这有助于我们发现程序中使用掉相当大的内存数量(在这种情形下是 59.10 %)的部分。

注意在位置 1 的[C 表示基本数据类型char。这是Java 虚拟机中对基本数据类型的内部

表示。

 

hprof来源网址: http://www.cnblogs.com/linhaohong/archive/2012/07/12/2588657.html

1.查看内存CPU使用情况

2.查看java内存分配信息   

 

1.java -agentlib:hprof=help  使用该命令可以得到 帮组说明和默认配置值

 

java -Xrunhprof:heap=sites  -Xms4100m -Xmx4100m  -Djava.library.path=$LD_LIBRARY_PATH -classpath ./build/classes:./build/*:./conf:./lib/* com.yoyosys.yihualu.ehual    uImpl.StartYhl parser.properties

 

 

 

将  java进程profiling的信息(sites和dump)都会被写入到一个叫做java.hprof.txt的文件中。大多数情况下,该文件中都会对每个trace,threads,objects包含一个ID,每一个ID代表一个不同的观察对象。通常,traces会从300000开始。

 

 

默认,force=y,会将所有的信息全部输出到output文件中,所以如果含有多个JVMs都采用的HRPOF enable的方式运行,最好将force=n,这样能够将单独的JVM的profiling信息输出到不同的指定文件。

 

interval选项只在 cpu=samples的情况下生效,表示每隔多少毫秒对java进程的cpu使用情况进行一次采集。

 

msa选项仅仅在Solaris系统下才有效,表示会使用Solaris下的Micro State Accounting功能

 

 

 

live

     存活的 被引用的对象

 

alloced

     已分配的 被引用的对象 

 

分享到:
评论

相关推荐

    2019年计算机组装与维护实训实习报告.pdf

    计算机试题试卷课件

    2019年计算机维护实训总结.pdf

    计算机试题试卷课件

    【路径规划】基于matlab固定次序法移植路径规划(目标函数:最短距离)【含Matlab源码 8800期】.mp4

    Matlab领域上传的视频均有对应的完整代码,皆可运行,亲测可用,适合小白; 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主或扫描视频QQ名片; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作

    高压无桥PFC原理图PCB源代码资料

    高压无桥PFC原理图PCB源代码资料

    2020年计算机基础考试题ID[含答案].pdf

    计算机试题试卷课件

    MySQL基础语法-空间数据类型.pdf

    MySQL基础语法——空间数据类型

    2020年计算机操作规程.pdf

    计算机试题试卷课件

    多目标蜣螂优化算法NSDBO求解微电网多目标优化调度 Matlab语言 1.单目标优化调度模型已不能满足专家的偏好,多目标优化可

    多目标蜣螂优化算法NSDBO求解微电网多目标优化调度 Matlab语言 1.单目标优化调度模型已不能满足专家的偏好,多目标优化可满足不同帕累托前沿的选择。 输出包括帕累托曲线图、方案调度图等等,如图1所示,方便您撰写,可完全满足您的需求 2.该多目标蜣螂算法将传统单目标蜣螂算法与非支配排序策略相结合,用于求解多目标问题,多目标蜣螂算法也可以成多目标水母算法、多目标灰狼算法等等 3.文件夹内也赠送多目标微电网优化调度模型PDF介绍,如图2所示,图2下方也展示了主程序页面与文件夹内容,使用方便快捷~ 4.注释清晰,适合新手小白,直接运行main即可一键出图

    2020年度计算机笔试模拟题全含答案.pdf

    计算机试题试卷课件

    transitions-Python轻量级、面向对象的有限状态机实现

    transitions-Python轻量级、面向对象的有限状态机实现

    oracle和mysql的区别.docx

    oracle和mysql区别

    各类好玩的Windows控制台小游戏

    斗地主、斗破苍穹、俄罗斯方块、飞机大战2、飞机大作战、汉诺塔、火柴人跑酷、狼人杀、迷宫、扫雷、贪吃蛇、推箱子、五子棋、小游戏合集。 以下是这些游戏的简要介绍: 1. **斗地主**:这是一款非常流行的纸牌游戏,在游戏中三名玩家使用一副扑克牌进行对抗,其中一名玩家作为地主,另外两名玩家作为农民,目标是尽快出完手中的牌。 2. **斗破苍穹**:这是一款根据同名小说改编的角色扮演游戏(RPG),玩家在游戏中扮演一个角色,通过完成任务和挑战来提升自己的实力。 3. **俄罗斯方块**:这是一个经典的益智游戏,玩家需要操控不同形状的方块下落并拼接成完整的行,每一行都会消失得分。 4. **飞机大战2/飞机大作战**:这是两款飞行射击类游戏,玩家操纵一架飞机在空中与敌机战斗,通过射击击败敌人并避开敌人的攻击。 5. **汉诺塔**:这是一个经典的数学益智游戏,目标是将所有盘子从一个柱子移动到另一个柱子上,但每次只能移动一个盘子,并且大盘子不能放在小盘子之上。 6. **火柴人跑酷**:这是一款动作冒险游戏,玩家控制一个火柴人角色进行跑酷,躲避障碍物并收集金币。

    人工智能在高中信息技术教学中的应用与实践.pdf

    毕业设计选题/开题答辩/项目源码/论文等资源 硕博论文、期刊资源、有需要可详细咨询 毕业设计选题/开题答辩/项目源码/论文等资源 硕博论文、期刊资源、有需要可详细咨询毕业设计选题/开题答辩/项目源码/论文等资源 硕博论文、期刊资源、有需要可详细咨询毕业设计选题/开题答辩/项目源码/论文等资源 硕博论文、期刊资源、有需要可详细咨询毕业设计选题/开题答辩/项目源码/论文等资源 硕博论文、期刊资源、有需要可详细咨询毕业设计选题/开题答辩/项目源码/论文等资源 硕博论文、期刊资源、有需要可详细咨询毕业设计选题/开题答辩/项目源码/论文等资源 硕博论文、期刊资源、有需要可详细咨询毕业设计选题/开题答辩/项目源码/论文等资源 硕博论文、期刊资源、有需要可详细咨询毕业设计选题/开题答辩/项目源码/论文等资源 硕博论文、期刊资源、有需要可详细咨询毕业设计选题/开题答辩/项目源码/论文等资源 硕博论文、期刊资源、有需要可详细咨询毕业设计选题/开题答辩/项目源码/论文等资源 硕博论文、期刊资源、有需要可详细咨询毕业设计选题/开题答辩/项目源码/论文等资源 硕博论文、期刊资源、有需要可详细咨询

    jquery.min.js

    jquery.min.js

    MATLAB 中实现 LSTM(长短期记忆)神经网络进行多变量时间序列预测(包含详细的完整的程序和数据)

    内容概要:该项目提供了一份详细的指南,介绍了如何在 MATLAB 中应用 LSTM (长短期记忆) 神经网络进行多变量时间序列预测。包括了从多变量时间序列的数据生成、特征工程到 LSTM 模型的设计,模型训练及预测、性能评估等多个方面。具体步骤有生成两组相关特征的时间序列,构造相应的 LSTM 网络结构,并对其进行训练与测试,最终展示了实际操作中的结果对比并给出评价。还提供了多样的评估指标如 MSE、MAE 和 RMSE,使模型的准确性更加可视化。 适合人群:机器学习开发者和研究人员。 使用场景及目标:针对含有长期依赖关系的时间序列数据分析、建立预测模型,特别适用于金融投资、气象研究等领域内的数据建模。 注意事项:尽管项目示例提供的代码已包含了所有必要的组成部分和参数设定技巧,但针对特定应用场景可能仍需进一步调整优化模型。

    大学生租房系统-论文.zip

    伴随着全球信息化发展,行行业业都与计算机技术相衔接,计算机技术普遍运用于各大行业,大学生租房系统便是其中一种。实施计算机系统来管理可以降低大学生租房管理的成本,使整个大学生租房的发展和服务水平有显著提升。 本论文主要面向大学生租房管理中出现的一些常见问题,将其与计算机管理系统结合起来。通过这个系统,用户登录大学生租房系统可以实现首页,房屋信息,房屋评价,公告资讯,个人中心,后台管理,意见反馈等进行相应操作,管理员可以更加方便的管理首页,个人中心,房主管理,用户管理,房屋类型管理,房屋信息管理,预约看房管理,定金留房管理,租赁订单管理,房屋评价管理等内容。计算机管理系统在大学生租房设计中的应用,可以很大程度上提高管理水平,使大学生租房管理获得更好的效果。 但是,这套系统实现的功能只是整个大学生租房管理中的一部分,系统中还存在一些不及之处,需要继续的创新,使其完美。 关键词:Java;大学生租房系统;mysql

    语音 241006_201537.m4a

    语音 241006_201537.m4a

    oracle和mysql区别.docx

    Oracle和MySQL都是基于关系模型的数据库管理系统,但它们在多个方面存在显著差异。以下是对Oracle和MySQL区别的详细分析: 一、开发背景与许可费用 Oracle:由甲骨文公司开发,是一个商业数据库管理系统,用户需要购买许可证才能使用。 MySQL:最初由瑞典MySQL AB公司开发,现属于Oracle旗下产品,但MySQL本身是一个开源数据库,提供免费的社区版和商业版。 二、适用场景与用户群体 Oracle:因其强大的功能、高性能和高安全性,主要被大型企业和机构使用,适用于需要处理大量数据、复杂查询和高并发访问的企业级应用程序。 MySQL:由于其开源性、易用性和较低的成本,在互联网行业中广泛使用,尤其是在小型和中型企业中,适用于对成本和简单性有更多考虑的应用场景。 三、功能与性能 Oracle:提供广泛的数据类型(包括对象关系、空间和XML等)、高级安全功能(如审计、访问控制和加密)、强大的性能优化器以及丰富的索引类型。此外,Oracle还支持复杂的事务处理和数据完整性约束,以及OLTP(联机事务处理)和OLAP(联机分析处理)工作负载。 MySQL:虽然也支持关系数

    基于PHP的博客Blog源码-现代化个人博客系统ModStartBlog最新版源码,Laravel和ThinkPHP版

    基于PHP的博客Blog源码--现代化个人博客系统ModStartBlog最新版源码,Laravel和ThinkPHP版 基于PHP的博客Blog源码--现代化个人博客系统ModStartBlog最新版源码,Laravel和ThinkPHP版 --- > ModStartBlog 是一个基于 Laravel > 现代化个人博客系统。模块市场拥有丰富的功能应用,支持后台一键快速安装,让开发者能快的实现业务功能开发。系统完全开源,基于 Apache > 2.0 开源协议,免费且不限制商业使用。 功能特点: ---- > 极速开发 > > 支持模块任意搭配的方式进行极速开发,让系统能以最快的速度上线。 > > 开放源码 > > ModStart是开源框架,无需授权即可商业使用,代码全部开源免费且无任何加密。 > > 资源丰富 > > 拥有丰富的开发文档和教程,支持定制开发,所有模块均支持二次开发。

    黄河交通学院教学质量评价系统的设计与实现.doc

    黄河交通学院教学质量评价系统的设计与实现

Global site tag (gtag.js) - Google Analytics