Linux Tomcat JVM 参数调优

版权声明:本文为博主原创文章,转载请注明出处。 https://blog.csdn.net/qq_29694039/article/details/78275195

——————————
Linux Tomcat JVM 参数调优
——————————

  1. 适用场景

    Tomcat 长期运行过程遇到Caused by: java.lang.OutOfMemoryError: PermGen space或java.lang.OutOfMemoryError: Java heap space错误。
    
  2. 异常原因

    PermGen space的全称是Permanent Generation space,是指内存的永久保存区域。这块内存主要是被JVM存放Class和Meta信息的。
    Class在被Loader时就会被放到PermGen space中,它和存放类实例(Instance)的Heap区域不同。
    GC(Garbage Collection)不会在主程序运行期对PermGen space进行清理,所以如果你的应用中有很多CLASS的话,就很可能出现PermGen space错误,
    这种错误常见在web服务器对JSP进行pre compile的时候。如果你的WEB APP下都用了大量的第三方jar,其大小超过了jvm默认的大小(4M)那么就会产生此错误信息了。

Java heap space:

JVM堆的设置是指java程序运行过程中JVM可以调配使用的内存空间的设置.JVM在启动的时候会自动设置Heap size的值,其初始空间(即-Xms)是物理内存的1/64,最大空间(-Xmx)是物理内存的1/4。

Heap size 的大小是Young Generation 和Tenured Generaion 之和。JVM中如果98%的时间是用于GC且可用的Heap size 不足2%的时候将抛出此异常信息。

Heap Size 最大不要超过可用物理内存的80%

一般的要将-Xms和-Xmx选项设置为相同(java垃圾回收机制清理完堆区后不需要重新分隔计算堆区的大小而浪费资源)。而-Xmn为1/4的-Xmx值。

个人对上面这句话做个补充,“推荐Xms和Xmx设置值为相同”,并不适用于所有情况,要根据实际情况而定。 当服务器多个tomcat同时运行时,(Xms要肯定小于Xmx)建议每个tomcat 设置 Xms = 1/2Xmx或2/3Xmx。理由是当某个tomcat高峰时,可以弹性分配内存空间。无可避免以上重新分配分隔内存的效率问题。

  1. 解决办法

    修改TOMCAT_HOME/bin/catalina.sh文件:

    扫描二维码关注公众号,回复: 2914095 查看本文章
# OS specific support.  $var _must_ be set to either true or false.
JAVA_OPTS="-server -Xms2048m -Xmx2048m -XX:PermSize=128M -XX:MaxNewSize=256m -XX:MaxPermSize=512m -Djava.awt.headless=true"

cygwin=false

darwin=false

加入以上红色JAVA_OPTS行记录后重启tomcat服务,其中JAVA_OPTS各参数的具体数值大小须根据实际服务器物理内存大小进行分配。

  1. 监控JVM

    4.1 查看jdk安装路径

可选择的命令:

[root@iZ25bzw04lpZ /]# whereis java
java: /usr/bin/java /usr/share/java

[root@iZ25bzw04lpZ /]# echo $JAVA_HOME
/usr/java/jdk1.7.0_67

[root@iZ25bzw04lpZ /]# which java
/usr/java/jdk1.7.0_67/bin/java

[root@iZ25bzw04lpZ /]# echo $PATH
/usr/java/jdk1.7.0_67/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin

4.2 查看java进程

采用jdk提供的jps(JavaVirtual Machine Process Status Tool)小工具,可查看当前Java进程。

[root@iZ25bzw04lpZ /]# cd ./usr/java/jdk1.7.0_67/
[root@iZ25bzw04lpZ jdk1.7.0_67]# ls -l
total 19760
drwxr-xr-x 2 root root     4096 Jul 10  2015 bin
-rw-r--r-- 1 root root     3339 Jul 26  2014 COPYRIGHT
drwxr-xr-x 4 root root     4096 Jul 10  2015 db
drwxr-xr-x 3 root root     4096 Jul 10  2015 include
drwxr-xr-x 5 root root     4096 Jul 10  2015 jre
drwxr-xr-x 5 root root     4096 Jul 10  2015 lib
-rw-r--r-- 1 root root       40 Jul 26  2014 LICENSE
drwxr-xr-x 4 root root     4096 Jul 10  2015 man
-rw-r--r-- 1 root root      114 Jul 26  2014 README.html
-rw-r--r-- 1 root root      499 Jul 26  2014 release
-rw-r--r-- 1 root root 19902868 Jul 26  2014 src.zip
-rw-r--r-- 1 root root   110114 Jul 25  2014 THIRDPARTYLICENSEREADME-JAVAFX.txt
-rw-r--r-- 1 root root   173559 Jul 26  2014 THIRDPARTYLICENSEREADME.txt
进入JDK目录后,执行bin/jps -v:

[root@iZ25bzw04lpZ jdk1.7.0_67]# bin/jps -v

默认没有设置
15257 Bootstrap -Djava.util.logging.config.file=/Data/tomcat7ssl/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.endorsed.dirs=/Data/tomcat7ssl/endorsed -Dcatalina.base=/Data/tomcat7ssl -Dcatalina.home=/Data/tomcat7ssl -Djava.io.tmpdir=/Data/tomcat7ssl/temp

4.3 查看JVM的GC情况

使用jstat工具查看,语法为:

jstat [ generalOption | outputOptions vmid [interval[s|ms] [count]] ]参数解释:

*Options   -选项,我们一般使用-gcutil查看GC情况

vmid      -VM的进程号,即当前运行的java进程号

interval   -间隔时间,单位为秒或毫秒
[root@iZ25bzw04lpZ jdk1.7.0_67]# bin/jstat -gcutil 15257
  S0     S1     E      O      P     YGC     YGCT    FGC    FGCT     GCT   
  0.00  97.65  29.84  79.97  99.29     17    0.661     1    0.271    0.932

设置完后

18860 Bootstrap
-Djava.util.logging.config.file=/Data/tomcat7ssl/conf/logging.properties
-Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Xms512m -Xmx3072m -Xss1024K -XX:PermSize=128m -XX:MaxPermSize=256m -Djava.endorsed.dirs=/Data/tomcat7ssl/endorsed -Dcatalina.base=/Data/tomcat7ssl -Dcatalina.home=/Data/tomcat7ssl -Djava.io.tmpdir=/Data/tomcat7ssl/temp

[root@iZ25bzw04lpZ jdk1.7.0_67]# bin/jstat -gcutil 18860 3000
  S0     S1     E      O      P     YGC     YGCT    FGC    FGCT     GCT   
  4.68   0.00  97.98  68.79  54.39     14    2.448     1    1.630    4.078

参数说明如下:

S0 -Heap上的Survivor space 0区已使用空间的百分比

S1 -Heap上的Survivor space 1区已使用空间的百分比

E -Heap上Eden space区已使用空间的百分比

O -Heap上的Old space区已使用空间的百分比,达到100%,就是内存溢出了

P -Perm space区已使用空间的百分比,达到100%,就是内存溢出了

YGC -从应用程序启动到采样时发生Yang GC 的次数

YGCT -从应用程序启动到采样时Yang GC所用的时间【单位秒】

FGC -从应用程序启动到采样时Full GC的次数

FGCT -从应用程序启动到采样时Full GC所用的时间

GCT -从应用程序启动到采样时用于垃圾回收的总时间【单位秒】

通过监控O、P数值情况,再次调整JAVA_OPTS相关参数大小达到优化目的。

猜你喜欢

转载自blog.csdn.net/qq_29694039/article/details/78275195