我使用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
答案 0 :(得分:1)
在Jenkins构建期间错过了setenv.sh文件,而且此文件是从tomcat.env获取自定义用户配置因此导致问题。