Linux下Tomcat开启查看GC日志

一、开启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

Linux下Tomcat开启查看GC日志

若只是使用,搞懂配置,只需看第二、三、四即可;若想更深入的了解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

下载,必须点击同意协议

Linux下Tomcat开启查看GC日志

(2)安装JDK1.8版本

Linux下Tomcat开启查看GC日志

设置自己的安装路径,取消公告JRE

Linux下Tomcat开启查看GC日志

 

Linux下Tomcat开启查看GC日志

 

Linux下Tomcat开启查看GC日志

(3)设置3个环境变量

① 找到自己安装jdk的bin路径,我的安装路径是 C:\Program Files (x86)\Java\jdk1.8.0_171

Linux下Tomcat开启查看GC日志

② 在高级系统设置--->环境变量--->新建

新建2个环境变量:

  JAVA_HOME

  CLASSPATH

Linux下Tomcat开启查看GC日志

 

Linux下Tomcat开启查看GC日志

修改一个变量:Path

Linux下Tomcat开启查看GC日志

(4)安装完毕,测试

java、javac、java -version 三个命令会有以下效果

Linux下Tomcat开启查看GC日志

 

Linux下Tomcat开启查看GC日志

 

2、运行gchisto,分析gc日志

(1)运行gchisto

解包后,打开cmd命令行,执行下边的命令,注意:自己解包后gchisto的路径

>java -jar D:\gchisto-master\release\GCHisto-java8.jar

(2)打开后效果

Linux下Tomcat开启查看GC日志

(3)分析Tomcat 的gc 日志

① 将linux 下的tomcat 日志sz 到windows 上;

② 导入gchisto中;

③ 查看效果

Linux下Tomcat开启查看GC日志

三、选项参数详解 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

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/3e9263400e6488b1a38c59ba110339c3.html