一、开启GC日志
1、在Tomcat 的安装路径下,找到bin/catalina.sh 加上下面的配置,具体参数,自己配置:
[root@CentOS7 tomcat]# vim bin/catalina.sh
Java_OPTS='-Xms512m -Xmx4096m -XX:PermSize=64M -XX:MaxNewSize=128m -XX:MaxPermSize=64m -XX:ParallelGCThreads=8 -XX:+UseConcMarkSweepGC -Xloggc:/usr/local/tomcat/logs/tomcat_gc.log'
2、重启tomcat
[root@centos7 ~]# systemctl restart tomcat
3、查看GC日志
[root@centos7 ~]# cat /usr/local/tomcat/logs/tomcat_gc.log
若只是使用,搞懂配置,只需看第二、三、四即可;若想更深入的了解GC,请详细看完~
二、GC日志分析GC 日志分析,需使用windows 的GC日志分析工具gchisto;
gchisto 工具的源下载地址已经失效,我已经存放在网盘https://pan.baidu.com/s/1XQPTD4irFXpGo28jjTWC6g?qq-pf-to=pcqq.c2c,需要的私聊我
1、windows 安装java 环境(1)去官网下载自己想要的JDK版本
Oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html
下载,必须点击同意协议
(2)安装JDK1.8版本
设置自己的安装路径,取消公告JRE
(3)设置3个环境变量
① 找到自己安装jdk的bin路径,我的安装路径是 C:\Program Files (x86)\Java\jdk1.8.0_171
② 在高级系统设置--->环境变量--->新建
新建2个环境变量:
JAVA_HOME
CLASSPATH
修改一个变量:Path
(4)安装完毕,测试
java、javac、java -version 三个命令会有以下效果
2、运行gchisto,分析gc日志(1)运行gchisto
解包后,打开cmd命令行,执行下边的命令,注意:自己解包后gchisto的路径
>java -jar D:\gchisto-master\release\GCHisto-java8.jar
(2)打开后效果
(3)分析Tomcat 的gc 日志
① 将linux 下的tomcat 日志sz 到windows 上;
② 导入gchisto中;
③ 查看效果
三、选项参数详解 1、堆大小设置① -Xmx3550m -Xms3550m -Xmn2g -Xss128k
-Xmx3550m:设置JVM最大可用内存为3550M。
-Xms3550m:设置JVM初始内存为3550m。此值可以设置与-Xmx相同,以避免每次垃圾回收完成后JVM重新分配内存。
-Xmn2g:设置年轻代大小为2G。整个堆大小=年轻代大小 + 年老代大小 + 持久代大小。持久代一般固定大小为64m,所以增大年轻代后,将会减小年老代大小。此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8。
-Xss128k: 设置每个线程的堆栈大小。JDK5.0以后每个线程堆栈大小为1M,以前每个线程堆栈大小为256K。更具应用的线程所需内存大小进行调整。在相同物理内存下,减小这个值能生成更多的线程。但是操作系统对一个进程内的线程数还是有限制的,不能无限生成,经验值在3000~5000左右。
② -XX:NewRatio=4 -XX:SurvivorRatio=4 -XX:MaxPermSize=16m -XX:MaxTenuringThreshold=0