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
已分配的 被引用的对象
相关推荐
内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。
深圳建设施工项目安全生产奖惩管理制度
离散数学课后题答案+sdut往年试卷+复习提纲资料
04741计算机网络原理 2018(尚德).pdf 13年试题(2套).pdf 2015年10月自考计算机网络原理04741试题及答案解析.docx 2021年4月自考04741计算机网络原理真题及答案.docx 2021年4月自考04741计算机网络原理试卷.bak.docx 计算机网络原理 课后题答案 全 李全龙版 自考04741.zip.zip 计算机网络原理课件 计算机网络原理课件.rar
C++实现rpc,全程手写
前端拿到的列表数据里id都一样的处理办法.txt
最新仿720云全景制作源码|krpano仿720云全景网站源码(新增微信支付+打赏+场景红包等)是一款基于php+mysql开发制作的全景在线制作网站源码,包含全景图片,全景视频等。数据存储全部存于OSS云端或本地,源码完全开源可自行二次开发。 环境要求:PHP5.5.X+MYSQL5.6.X+伪静态 熟悉linux系统推荐使用LAMP,web服务器最好使用apache,不要使用nginx(发布大全景图需要时间可能需要20多分钟, nginx超时机制不好控制)。 Windows系统推荐使用phpstudy。Liunx推荐宝塔控制面板apache 前端为HTML5开发,自适应手机版! 1、支持VR虚拟现实、全景视频、环物全景、说一说、点赞评论、重力感应、智能视频嵌入、场景切换热点、加载进度条、 地图导航、光晕flash特效、物体全景嵌入、场景自播、场景解说、雷达导航等业内前沿功能。 2、支持windows、Linux、Mac、安卓、IOS等几乎所有的系统观看。支持CDN图片转存,极大的减轻的服务器流量费用。 3、支持用户权限分配。方便会员制收费。
YOLO系列算法目标检测数据集,包含标签,可以直接训练模型和验证测试,数据集已经划分好,包含数据集配置文件data.yaml,适用yolov5,yolov8,yolov9,yolov7,yolov10,yolo11算法; 包含两种标签格:yolo格式(txt文件)和voc格式(xml文件),分别保存在两个文件夹中,文件名末尾是部分类别名称; yolo格式:<class> <x_center> <y_center> <width> <height>, 其中: <class> 是目标的类别索引(从0开始)。 <x_center> 和 <y_center> 是目标框中心点的x和y坐标,这些坐标是相对于图像宽度和高度的比例值,范围在0到1之间。 <width> 和 <height> 是目标框的宽度和高度,也是相对于图像宽度和高度的比例值; 【注】可以下拉页面,在资源详情处查看标签具体内容;
环境监测系统源代码全套技术资料.zip
Matlab领域上传的视频均有对应的完整代码,皆可运行,亲测可用,适合小白; 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作
四轮转向系统横摆角速度控制simulink仿真模型,利用滑模控制算法,基于八自由度车辆模型,控制有比较好的效果,附参考说明。
YOLO系列算法目标检测数据集,包含标签,可以直接训练模型和验证测试,数据集已经划分好,包含数据集配置文件data.yaml,适用yolov5,yolov8,yolov9,yolov7,yolov10,yolo11算法; 包含两种标签格:yolo格式(txt文件)和voc格式(xml文件),分别保存在两个文件夹中,文件名末尾是部分类别名称; yolo格式:<class> <x_center> <y_center> <width> <height>, 其中: <class> 是目标的类别索引(从0开始)。 <x_center> 和 <y_center> 是目标框中心点的x和y坐标,这些坐标是相对于图像宽度和高度的比例值,范围在0到1之间。 <width> 和 <height> 是目标框的宽度和高度,也是相对于图像宽度和高度的比例值; 【注】可以下拉页面,在资源详情处查看标签具体内容;
02142数据结构导论历年真题及答案(2012-2018共13套).rar 02331数据结构历年真题共267页2009.10-2019.4.rar 24数据结构201704_8.pdf 25数据结构201710_10.pdf 26数据结构201804_11.pdf 27数据结构201810_9.pdf 全国2021年04月高等教育自学考试02331数据结构试题及答案.docx 全国2022年04月高等教育自学考试02331数据结构试题及答案.docx 数据结构-课件.rar 第l六讲.ppt 第一讲.ppt 第七讲.ppt 第三讲.ppt 第九讲.ppt 第二讲.ppt 第五讲.ppt 第八讲.ppt 第四讲.ppt
验收确认单表格.docx
内存搜索工具(易).rar
饮食管理系统项目源代码全套技术资料.zip
【项目简介】 代码主干网络采用Swin-Transformer 家族系列,包括【tiny、small、base】三种模型。pretrained和freeze_layers参数为是否采用官方预训练模型和是否仅训练分类头。为了做对比消融试验,优化器采用了Adam和SGD、AdamW三种。损失函数采用多类别的交叉熵、学习率优化策略采用cos余弦退火算法 【评估网络】 评估的指标采用loss和准确率(accuracy),分别会在训练集和验证集上进行评估、输出、绘制曲线图像。同时会在训练集、验证集进行一系列评估,包含混淆矩阵、recall、precision、F1 score等等曲线图像,以及recall、precision、F1 score、特异度的输出信息等等。 【具体各类别的指标在json文件中查看】 【如果想要更换数据集训练,参考readme文件】 【本项目为8种番茄病害图片(约4k张数据),包含数据集和标签,可以一键运行】
windows电脑下载OpenHarmony鸿蒙命令行工具hdc_std。内容来源于网络分享,如有侵权请联系我删除。另外如果没有积分的同学需要下载,请私信我。
本项目可以作为小程序毕设项目,主要功能为音乐播放器,主要功能是:可以播放歌曲(采用mp3网络连接实现)、专辑封面播放时可以旋转,能够实现开始和暂停播放,可以点击下一首歌曲,主页面实现动态轮播图
考研学习分享功能的描述可以涵盖以下几个主要模块,旨在为考研学生提供一个互动、资源共享、经验交流的平台: 1. 用户注册与个人信息管理 学生可以通过邮箱或手机号注册账户,填写个人信息,如姓名、专业、目标院校等。 用户可设置学习目标和进度,方便记录自己的学习历程。 2. 学习资料共享 用户可以上传、下载考研相关学习资料,如教材、真题、笔记、复习计划等。 提供文件分类功能,按学科、院校、难度等进行整理,方便用户查找。 支持多种文件格式,如PDF、Word、Excel、图片等。 3. 复习经验分享 学生可以发布自己的复习经验文章,分享复习方法、备考心得、时间管理技巧等。 提供文章评论和互动功能,其他学生可以点赞、评论、提问,促进经验交流。 设置专栏或专题,帮助学生快速找到自己感兴趣的复习内容。 4. 考研小组与社交功能 学生可以创建或加入学习小组,组内成员可共享资料、讨论问题、互相鼓励。 提供私信、群聊功能,方便学员在小组内进行实时讨论和交流。 支持设置小组学习目标和定期检查进度,增加学习动力。 5. 在线课程与讲座 提供考研各科目(如英语、数学、政治等)的在线课程资源,用户可以报名参加。