Tomcat内存配置

1、Tomcat的JVM内存溢出解决方法

在生产环境中,tomcat内存设置不好很容易出现JVM内存溢,最直观的解决方法就是修改Tomcat中的catalina.sh文件。

在catalina.sh文件中,找到cygwin=false,在这一行的前面加入参数,具体如下:

vi TOMCAT_HOME/bin/catalina.sh

JAVA_OPTS="-server -Xms800m -Xmx800m -XX:PermSize=256m -XX:MaxPermSize=512m -XX:MaxNewSize=512m"

其他说明:

        1.“m”说明单位是MB,否则默认是KB

        2.一般使用物理内存的80%作为堆大小

        3.一般把-Xms和-Xmx设为一样大

        4.一般把-Xmn设置为-Xmx值的1/4

        5.一般将堆的总大小的50%到60%分配给新生成的

2、jvm参数的说明

-server 一定要作为第一个参数,启用JDK的server版本,在多个CPU时性能佳

-Xms java Heap初始大小。 默认是物理内存的1/64。

-Xmx java heap最大值。建议均设为物理内存的80%。不可超过物理内存。

-Xmn java heap最小值,一般设置为Xmx的3、4分之一。

-XX:PermSize 设定内存的永久保存区初始大小,缺省值为64M。

-XX:MaxPermSize 设定内存的永久保存区最大大小,缺省值为64M。

-XX:SurvivorRatio=2 生还者池的大小,默认是2。 

-XX:NewSize 新生成的池的初始大小。 缺省值为2M。

-XX:MaxNewSize 新生成的池的最大大小。 缺省值为32M。

+XX:AggressiveHeap 让jvm忽略Xmx参数,疯狂地吃完一个G物理内存,再吃尽一个G的swap。

-Xss 每个线程的Stack大小

-verbose:gc 现实垃圾收集信息

-Xloggc:gc.log 指定垃圾收集日志文件

-XX:+UseParNewGC 缩短minor收集的时间

-XX:+UseConcMarkSweepGC 缩短major收集的时间

-XX:userParNewGC 可用来设置并行收集(多CPU)

-XX:ParallelGCThreads 可用来增加并行度(多CPU)

-XX:UseParallelGC 设置后可以使用并行清除收集器(多CPU)

-XX:PermSize -XX:MaxPermSize

–设置永久区的初始空间和最大空间

-XX:PermSize 设置持久代(perm gen)初始值,物理内存的1/64

-XX:MaxPermSize 设置持久代最大值,物理内存的1/4

–他们表示,一个系统可以容纳多少个类型

参考一部分扩展连接:

https://mp.weixin.qq.com/s/NnFGNzKps2L7kjKJSZLJdg

你可能感兴趣的:(Tomcat,tomcat)