为什么PermSize和MaxPermSize的设置值和实际值不同?

时间:2016-03-30 10:50:00

标签: java tomcat jvm out-of-memory permgen

我使用tomcat的JAVA_OPTS变量设置了PermSize和MaxPermSize的值,如下所示

JAVA_OPTS="$JAVA_OPTS -XX:PermSize=512M"
JAVA_OPTS="$JAVA_OPTS -XX:MaxPermSize=512M"

并将Xms和Xmx的值设置为

JAVA_OPTS="$JAVA_OPTS -Xms1024M"
JAVA_OPTS="$JAVA_OPTS -Xmx1024M"

但是当我使用命令jmap -heap [process id]检查perm-gen的实际大小时,它们显示为

Heap Configuration:
   MinHeapFreeRatio = 40
   MaxHeapFreeRatio = 70
   MaxHeapSize      = 792723456 (756.0MB)
   NewSize          = 1310720 (1.25MB)
   MaxNewSize       = 17592186044415
   OldSize          = 5439488 (5.1875MB)
   NewRatio         = 2
   SurvivorRatio    = 8
   **PermSize         = 21757952 (20.75MB)**
   **MaxPermSize      = 85983232 (82.0MB)**
   G1HeapRegionSize = 0 (0.0MB)


Perm Generation:
   **capacity = 69271552 (66.0625MB)**
   **used     = 69247376 (66.03944396972656MB)**
   **free     = 24176 (0.0230560302734375MB)**
   **99.96509967035242% used**

为什么permgen空间的实际分配与使用属性PermSize和MaxPermSize分配的内容不同?

附加信息:安装tomcat服务器的linux机器的RAM是:

             total       used       free     shared    buffers     cached
Mem:       3089928    3006592      83336          0      67828    1874144
-/+ buffers/cache:    1064620    2025308
Swap:      1020088        112    1019976

1 个答案:

答案 0 :(得分:1)

在Jenkins构建期间错过了setenv.sh文件,而且此文件是从tomcat.env获取自定义用户配置因此导致问题。