JVM的GC日志的主要参数

 

-Xmn1024m -Xms2500m -Xmx2500m -XX:+UseConcMarkSweepGC -XX:CMSInitiatingOccupancyFraction=70 -XX:MaxDirectMemorySize=256m -XX:+UseCMSInitiatingOccupancyOnly -XX:SurvivorRatio=8 -XX:+ExplicitGCInvokesConcurrent -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=256m -XX:-OmitStackTraceInFastThrow -XX:+PrintGCDetails -XX:+PrintGCDateStamps -Xloggc:/var/www/logs/gc-%%t.log -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=5 -XX:GCLogFileSize=10m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/var/www/logs -Djava.io.tmpdir=/var/www/tmp
-Xmn1024m -Xms2500m -Xmx2500m -XX:+UseConcMarkSweepGC 
-XX:CMSInitiatingOccupancyFraction=70 -XX:MaxDirectMemorySize=256m 
-XX:+UseCMSInitiatingOccupancyOnly -XX:SurvivorRatio=8 
-XX:+ExplicitGCInvokesConcurrent -XX:MetaspaceSize=128m 
-XX:MaxMetaspaceSize=256m -XX:-OmitStackTraceInFastThrow 
-XX:+PrintGCDetails -XX:+PrintGCDateStamps 
-Xloggc:/var/www/logs/gc-%%t.log 
-XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=5 
-XX:GCLogFileSize=10m -XX:+HeapDumpOnOutOfMemoryError 
-XX:HeapDumpPath=/var/www/logs -Djava.io.tmpdir=/var/www/tmp

 一:理解GC日志格式,读GC日志的方法

1:开启日志

 

-verbose:gc 

-XX:+PrintGCDetails 

-XX:+PrintGCDateStamps

-Xloggc:/path/gc.log

-XX:+UseGCLogFileRotation  启用GC日志文件的自动转储 (Since Java)

-XX:NumberOfGClogFiles=1  GC日志文件的循环数目 (Since Java)

-XX:GCLogFileSize=1M  控制GC日志文件的大小 (Since Java)

-XX:+PrintGC包含-verbose:gc

-XX:+PrintGCDetails //包含-XX:+PrintGC

只要设置-XX:+PrintGCDetails 就会自动带上-verbose:gc和-XX:+PrintGC

-XX:+PrintGCDateStamps/-XX:+PrintGCTimeStamps 输出gc的触发时间

 

二:参数配置和理解

1:参数分类和说明

jvm参数分固定参数和非固定参数

1):固定参数

如:-Xmx,-Xms,-Xmn,-Xss.

2):非固定参数

如:

-XX:+<option> 启用选项

-XX:-<option> 不启用选项

-XX:<option>=<number> 给选项设置一个数字类型值,可跟单位,例如 128k, 2g

-XX:<option>=<string> 给选项设置一个字符串值,例如-XX:HeapDumpPath=./dump.log

 

2:JVM可设置参数和默认值

1):-XX:+PrintCommandLineFlags

打印出JVM初始化完毕后所有跟最初的默认值不同的参数及它们的值,jdk1.5后支持.

线上建议打开,可以看到自己改了哪些值.

2):-XX:+PrintFlagsFinal

显示所有可设置的参数及"参数处理"后的默认值。参数本身只从JDK6 U21后支持

可是查看不同版本默认值,以及是否设置成功.输出的信息中"="表示使用的是初始默认值,而":="表示使用的不是初始默认值

如:jdk6/7 -XX:+MaxTenuringThreshold 默认值都是15,但是在使用CMS收集器后,jdk6默认4 , jdk7默认6.

 

三:JVM内存区域理解和相关参数

一图胜千言,直接上图

1):物理分代图.

 

物理分代是除G1之外的JVM 内存分配方式,jvm 通过-Xmx,-Xmn/newRatio等参数将jvm heap划分成物理固定大小,对于不同场景比例应该设置成多少很考验经验.

一篇JVM CMS优化讲解的非常好的文章: how-tame-java-gc-pauses

 

2) 逻辑分代图(G1)

逻辑分代是以后的趋势(PS:jdk8连perm都不区分了。), 不需要使用者在纠结Xms/Xmn,SurvivorRatio等比例问题,采用动态算法调整分代大小。

### JVM Garbage Collection (GC) 日志配置与分析 #### 配置 GC 日志 为了生成 GC 日志,可以通过设置 JVM 参数来启用并控制其行为。以下是常用的参数及其作用: - `-Xlog:gc`: 启用基本的 GC 日志记录功能[^1]。 - `-Xlog:gc*:file=gc.log`: 将详细的 GC 事件写入到指定文件 `gc.log` 中[^2]。 - `-Xlog:gc+heap=trace`: 记录堆分配和垃圾回收的详细信息[^3]。 完整的命令行示例如下所示: ```bash java -Xms512m -Xmx1g \ -Xlog:gc*:file=gc.log:time,uptime,pid,tid,level,tags \ YourApplication ``` 此命令设置了初始堆大小为 512MB (`-Xms`) 和最大堆大小为 1GB (`-Xmx`),并将带有时间戳、运行时间、进程 ID 等标签的日志输出至 `gc.log` 文件中。 #### 解读 GC 日志 GC 日志通常包含以下几类重要信息: 1. **Full GC**: 表示整个堆被清理的情况。如果频繁发生 Full GC,则可能意味着存在内存泄漏或者堆空间不足的问题。 2. **Young GC**: 只针对年轻代对象进行清理的操作。相比 Full GC 更加高效且耗时较短。 3. **暂停时间 (Pause Time)**: 指每次 GC 运行期间应用程序线程停止的时间长度。过长的停顿会影响用户体验。 一段典型的 GC 日志片段如下: ``` [0.769s][info][gc,start ] GC(0) Pause Young (Normal) (G1 Evacuation Pause) [0.769s][info][gc,task ] GC(0) Using 8 workers of max 8 for evacuation ... [0.774s][info][gc,end ] GC(0) End of GC [0.774s][info][gc ] GC(0) Pause TotalTime: 0.005 seconds ``` 上述日志表明一次年轻的 G1 收集完成,在大约 5 毫秒内结束。 #### 使用工具分析 GC 日志 除了手动解析外,还可以利用专门设计用于处理这些复杂数据流的应用程序来进行更深入的理解。一些流行的选项包括 VisualVM 和 Eclipse MAT(Memory Analyzer Tool)。 通过导入预先准备好的 `.hprof` 或者自定义格式化的文本报告形式进入以上提到过的任意一款软件界面之后,用户便能够获得关于内存分布状况以及潜在性能瓶颈所在位置等方面更为直观清晰的画面展示效果了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值