[转帖]GC日志分析工具——GCViewer案例
一、GCViewer介绍
业界较为流行分析GC日志的两个工具——GCViewer、GCEasy。GCEasy部分功能还是要收费的,今天笔者给大家介绍一下GCViewer的使用与功能点。
二、GCViewer 使用
2.1 编译
首先,在github上搜索GCViewer项目,并下载到本地。GCViewer项目没有提供现成的release版本,利用如下maven编译命令即可完成GCViewer的编译工作,最终生成一个gcviewer-1.36.jar。
mvn clean install -DskipTests
注:
- 官网上给出的maven命令并没有-DskipTests,笔者在编译过程中tests部分有异常导致编译失败,因此添加了-DskipTests。
- 在编译时,有异常表示要依赖git、svn,因此在编译前请安装这两个软件。
为了方便看官们去使用该工具,笔者将编译好的jar,存放百度网盘,欢迎下载。
链接:https://pan.baidu.com/s/1CCX6bg3zw-HtcX5Ls9CBXQ提取码:ea5q
2.2 GCViewer介绍
双击gcviewer-1.36.jar,即可见到主界面,如下图:
接着,选择要分析的gc日志文件,即可出现分析界面,主要关注Chart、Event detail、summary/memory/pause三个标签页。
2.2.1 Chart
Chart标签页把每次GC的采集信息,转换成图表用以展示,包括堆的总大小、堆的使用量、单次full gc的时间等(有些折线是特定GC收集器所特有的)。
乍一看该图形,有点乱乱的感觉,大家可以点击工具栏中的view,选择自己感兴趣的曲线,如下所示:
2.2.2 Event detail
Event detail标签页如下图所示,展示了minor GC和full GC触发的原因、次数、最长时间、最短时间等信息。
由图可知
触发Young CG的原因有:
- allocation failure,年轻代没有足够的内存去存放对象。
- gclocker failure,JNI临界区被释放时会触发一次GC。
触发Full GC的原因有:
- ergonomics,当新生代要晋升到老年代的占用空间,要大于老年代剩余内存空间时,便会触发full gc。
- metadata gc threshold,metadata空间不够用时,便会触发一次full gc。(metadata的初始值可以使用java -XX:+PrintFlagsInitial命令来看看)
- Heap Dump Initiated GC,执行jmap -dump:live pid,或jstat -gccause pid。
- system gc,显示调用了System.gc()。
2.2.3 Summary、Memory、Pause
- 进程运行66+h。
- heap最大使用率达到 99.8%。
- full gc最多的一次回收了14G heap。
- 老年代最大使用率达到100%。
- 新生代最大使用率达到99.7%。
- 灰色部分参数由于JVM参数设置原因,没有相应的值。
Pause标签页展示的信息与Event detail标签页高度重合。
三、参考链接
https://docs.oracle.com/javase/8/docs/technotes/tools/unix/java.html
[转帖]GC日志分析工具——GCViewer案例的更多相关文章
- 【转】gc日志分析工具
性能测试排查定位问题,分析调优过程中,会遇到要分析gc日志,人肉分析gc日志有时比较困难,相关图形化或命令行工具可以有效地帮助辅助分析. Gc日志参数 通过在tomcat启动脚本中添加相关参数生成gc ...
- GC之七--gc日志分析工具
性能测试排查定位问题,分析调优过程中,会遇到要分析gc日志,人肉分析gc日志有时比较困难,相关图形化或命令行工具可以有效地帮助辅助分析. Gc日志参数 通过在tomcat启动脚本中添加相关参数生成gc ...
- jvm的GC日志分析 [转]
jvm的GC日志分析 标签: jvm内存javagc 2015-06-22 16:37 1566人阅读 评论(1) 收藏 举报 分类: Java(4) JVM的GC日志的主要参数包括如下几个: ...
- JAVA 从GC日志分析堆内存 第七节
JAVA 从GC日志分析堆内存 第七节 在上一章中,我们只设置了整个堆的内存大小.但是我们知道,堆又分为了新生代,年老代.他们之间的内存怎么分配呢?新生代又分为Eden和Survivor,他们的比 ...
- 日志分析工具ELK配置详解
日志分析工具ELK配置详解 一.ELK介绍 1.1 elasticsearch 1.1.1 elasticsearch介绍 ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分 ...
- GoAccess日志分析工具使用文档
----Sevck 2016/3/4 17:24:13 #1软件说明: GoAccess是一款开源.实时,运行在命令行终端下的web日志分析工具.该工具提供快速.多样的HTTP状态统计,可以令管理员不 ...
- 可视化日志分析工具Gltail的安装与使用
可视化日志分析工具Gltail的安装与使用 GlTail.rb 是一款带有浓郁的 Geek 风格的可视化日志分析工具,它采用 Ruby 技术构建,并利用 OpenGL 图形技术进行渲染,呈现 ...
- 强大的日志分析工具 -- NSLogger
转:http://www.cnblogs.com/yingkong1987/p/3329945.html 强大的日志分析工具 -- NSLogger 源码:https://github.com/fpi ...
- Log Parser 微软强大的日志分析工具
Log Parser(微软网站下载)是微软公司出品的日志分析工具,它功能强大,使用简单,可以分析基于文本的日志文件.XML 文件.CSV(逗号分隔符)文件,以及操作系统的事件日志.注册表.文件系统.A ...
- Mysql 配置慢查询日志(SlowQueryLog)以及使用日志分析工具
[ 查看系统关于慢查询的设置 ] mysql> show variables like '%slow%'; +---------------------------+-------------- ...
随机推荐
- C++ 惯用法之 RAII
RAII(Resource Acquisition Is Initialization)资源获取即初始化,是 C++ 中最基本.应用最广范的惯用法(idiom)之一. RAII 的基本思想是通过构造/ ...
- 第四部分_Shell脚本数组和其他变量
数组定义 ㈠ 数组分类 普通数组:只能使用整数作为数组索引(元素的下标) 关联数组:可以使用字符串作为数组索引(元素的下标) ㈡ 普通数组定义 可以切片 一次赋予一个值 #数组名[索引下标]=值 ar ...
- 华为云GaussDB支撑华为MetaERP系统全面替换
摘要:目前MetaERP已经覆盖了华为公司100%的业务场景和80%的业务量. 本文分享自华为云社区<强渡大渡河!华为云GaussDB支撑华为MetaERP系统全面替换>,作者: 华为云头 ...
- 本地已存在jar包,maven打包还是去下载
解决方法 在pom文件里面添加以下: file后修改为本地仓库的位置 oss file:C:\Users\admin\.m2\repository <pluginRepositories> ...
- 我教你解决 Ubuntu 常见的三个问题:Window和Ubuntu无法复制,有另一个软件包管理程序正在运行、无法获得锁 /var/lib/apt/lists/lock - open (11: 资源暂时不可用)
第一个问题:当自己遇到这个问题的时候,查阅很多资料,发现很多需要安装一大推东西,又是安装,又是重启,最后还是没有搞定.最后还是通过这三行命令搞定了.sudo apt-get autoremove op ...
- AtCoder Beginner Contest 335 总结
ABC335总结 A.202<s>3</s> 翻译 给你一个由小写英文字母和数字组成的字符串 \(S\). \(S\) 保证以 2023 结尾. 将 \(S\) 的最后一个字符 ...
- 【ToolChains】CLion(VS2019) + CMake + Vcpkg 的使用
参考博客: https://blog.51cto.com/u_15075510/4201238 http://t.csdn.cn/pADDU https://zhuanlan.zhihu.com/p/ ...
- 0x41 数据结构进阶-并查集
A题 程序自动分析 题目链接:https://ac.nowcoder.com/acm/contest/1031/A 题目描述 在实现程序自动分析的过程中,常常需要判定一些约束条件是否能被同时满足. 考 ...
- 实战指南 | Serverless 架构下的应用开发
作者 | 刘宇.田初东.卢萌凯.王仁达 UC Berkeley认为Serverless架构的出现过程类似于40多年前从汇编语言转向高级语言的过程,在未来Serverless架构的使用会飙升,或许服务器 ...
- 8、SpringBoot 事务
系列导航 springBoot项目打jar包 1.springboot工程新建(单模块) 2.springboot创建多模块工程 3.springboot连接数据库 4.SpringBoot连接数据库 ...