目录
首先你要知道最常见的几个设置参数。
-Xms:为jvm启动时分配的内存,比如-Xms1024m,表示分配1024M
-Xmx:为jvm运行过程中分配的最大内存
-Xmn:设置年轻代内存大小
-XX:SurvivorRatio:设置年轻代eden区和Survivor区域(from区和to区)所占比例。注:此参数设置受UseAdaptiveSizePolicy影响。如果设置成-XX:-UseAdaptiveSizePolicy。from区和to区比例划分公平。否则依据自适应大小计算。详情请看AdaptiveSizePolicy介绍
-XX:-UseAdaptiveSizePolicy:JDK 1.8 默认使用 UseParallelGC 垃圾回收器,该垃圾回收器默认启动了 AdaptiveSizePolicy,会根据GC的情况自动计算计算 Eden、From 和 To 区的大小;
AdaptiveSizePolicy(自适应大小策略) :
JDK 1.8 默认使用 UseParallelGC 垃圾回收器,该垃圾回收器默认启动了 AdaptiveSizePolicy,会根据GC的情况自动计算计算 Eden、From 和 To 区的大小;
-
开启:-XX:+UseAdaptiveSizePolicy
- 关闭:-XX:-UseAdaptiveSizePolicy
配置jvm命令如下:
nohup java -jar -Xms800MB -Xmx1524MB -Xmn1024MB -XX:-UseAdaptiveSizePolicy -XX:SurvivorRatio=4 xxxx.jar --server.port=8185 >system.log 2>&1 &
在服务上查看jvm的内存占用情况:
首先在cmd输入:jps -v 命令查看运行的服务的pid
通过jmap -heap pid 查看各代内存使用情况例如:jmap -heap 9984
可以查看各个代的内存使用情况。如果你看到年轻代中from和to区分配不公平。使用此参数,关闭自适应参数策略:-XX:-UseAdaptiveSizePolicy
-XX:SurvivorRatio可以更改eden区和survivo区占比情况。
例如:-XX:SurvivorRatio=4。则eden:from:to = 4:1:1
eden = 4/4+1+1 = 2/3 from和to = 1/4+1+1=1/6。
具体配置需要根据服务器的需要进行设置。
以上操作是jdk8版本。没有持久代