-XX:G1NewSizePercent、-XX:G1MaxNewSizePercent 和 -XX:G1ReservePercent 参数说明
时间: 2024-05-14 11:10:28 浏览: 348
-XX:G1NewSizePercent参数是用来设置G1收集器中,年轻代的最小值和最大值之间的比例。默认值为5%,取值范围为0~100。当应用程序的新生代内存使用率达到了最大值时,G1会启动一次Young GC进行垃圾回收。
-XX:G1MaxNewSizePercent参数用于设置G1收集器中,年轻代的最大值和堆内存总大小之间的比例。默认值为60%,取值范围为0~100。当应用程序的新生代内存使用率超过了最大值,且无法通过Young GC进行垃圾回收时,G1会进行Full GC。
-XX:G1ReservePercent参数是用于设置G1收集器在分配Java堆空间时,预留给年轻代和老年代的空间大小的比例。默认值为10%,取值范围为0~100。该参数与-XX:InitiatingHeapOccupancyPercent参数一起使用,用于控制G1收集器的堆空间分配策略。
相关问题
/usr/java/jdk1.8.0_161/bin/java -server -Xms2g -Xmx2g -XX:+UseG1GC -XX:G1HeapRegionSize=16m -XX:G1ReservePercent=25 -XX:InitiatingHeapOccupancyPercent=30 -XX:SoftRefLRUPolicyMSPerMB=0 -verbose:gc -Xloggc:/dev/shm/rmq_srv_gc_%p_%t.log -XX:+PrintGCDetails -XX:+PrintGCDateStamps -XX:+PrintGCApplicationStoppedTime -XX:+PrintAdaptiveSizePolicy -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=5 -XX:GCLogFileSize=30m -XX:-OmitStackTraceInFastThrow -XX:+AlwaysPreTouch -XX:MaxDirectMemorySize=15g -XX:-UseLargePages -XX:-UseBiasedLocking -Drocketmq.client.logUseSlf4j=true -cp .:/usr/local/rocketmq/bin/../conf:/usr/local/rocketmq/bin/../lib/*: -Drmq.logback.configurationFile=/usr/local/rocketmq/conf/rmq.broker.logback.xml org.apache.rocketmq.broker.BrokerStartup -c ../conf/broker.conf
这是一个使用Java语言编写的应用程序的命令行运行指令。该程序是一个消息队列中间件的Broker,使用了RocketMQ框架实现。其中的参数含义如下:
-server:使用JVM的server模式。在多核CPU上提高性能。
-Xms2g:JVM启动时堆内存的最小值为2G。
-Xmx2g:JVM堆内存的最大值为2G。
-XX:+UseG1GC:使用G1垃圾回收器。
-XX:G1HeapRegionSize=16m:G1垃圾回收器内存区域的大小为16M。
-XX:G1ReservePercent=25:预留25%的空间以避免太满引发的性能问题。
-XX:InitiatingHeapOccupancyPercent=30:G1在堆内存使用达到30%时会触发垃圾回收。
-XX:SoftRefLRUPolicyMSPerMB=0:清除软引用的时间间隔为0,即软引用的对象一旦没有被使用就会被立即清除。
-verbose:gc:打印GC日志。
-Xloggc:/dev/shm/rmq_srv_gc_%p_%t.log:将GC日志输出到/dev/shm/rmq_srv_gc_%p_%t.log文件中。
-XX:+PrintGCDetails:打印GC详细信息。
-XX:+PrintGCDateStamps:打印GC时间戳。
-XX:+PrintGCApplicationStoppedTime:打印应用程序停止时间。
-XX:+PrintAdaptiveSizePolicy:打印自适应策略的信息。
-XX:+UseGCLogFileRotation:启用GC日志文件轮换。
-XX:NumberOfGCLogFiles=5:GC日志文件轮换时保留的文件数目。
-XX:GCLogFileSize=30m:GC日志文件的大小为30M。
-XX:-OmitStackTraceInFastThrow:关闭快速抛出异常时的栈信息。
-XX:+AlwaysPreTouch:在JVM启动时预先分配堆内存。
-XX:MaxDirectMemorySize=15g:最大直接内存大小为15G。
-XX:-UseLargePages:不使用大页面。
-XX:-UseBiasedLocking:不使用偏向锁。
-Drocketmq.client.logUseSlf4j=true:使用SLF4J作为日志框架。
-c ../conf/broker.conf:指定Broker的配置文件路径。
-XX:+UseG1GC -XX:G1HeapRegionSize=1m -XX:MaxGCPauseMillis=300 -XX:ParallelGCThreads=4 -XX:ConcGCThreads=1
这是一些Java虚拟机参数,用于配置G1垃圾回收器。这些参数的含义如下:
-XX:+UseG1GC:启用G1垃圾回收器。
-XX:G1HeapRegionSize=1m:设置G1中每个区域的大小为1MB。
-XX:MaxGCPauseMillis=300:设置G1垃圾回收器的最大暂停时间为300毫秒。
-XX:ParallelGCThreads=4:设置G1垃圾回收器的并行线程数为4个。
-XX:ConcGCThreads=1:设置G1垃圾回收器的并发线程数为1个。
这些参数的目的是优化Java应用程序的垃圾回收机制,从而提高应用程序的性能和可靠性。
阅读全文