【JVM】6、聊聊JVM常用参数设置

整体考虑堆大小

-Xms3550m, 初始化堆大小。通常情况和-Xmx大小设置一样,避免虚拟机频繁自动计算后调整堆大小。 
-Xmx3550m,最大堆大小。

考虑分代设置堆大小

首先通过jstat等工具查看应用程序正常情况下需要堆大小,再根据实际情况设置。

新生代

-xmn2g,新生代大小。Sun官方推荐配置为整个堆的3/8。 
-XX:SurvivorRatio=8。Eden和Survivor的比值。

老年代

老年代=整个堆大小-新生代-永久代

永久代

-XX:Permsize=512m,设置永久代初始值。 
-XX:MaxPermsize=512m,设置永久代的最大值。 
注:Java8没有永久代说法,它们被称为元空间,-XX:MetaspaceSize=N

考虑本机直接内存

-XX:MaxDirectMemorySize=100M。默认与Java堆大最大值(-Xmx)

考虑虚拟机栈

每个线程池的堆栈大小。在jdk5以上的版本,每个线程堆栈大小为1m,jdk5以前的版本是每个线程池大小为256k。一般设置256k。 
-Xss256K.

考虑选择垃圾收集器

Serial收集器(串行收集器)

历史最悠久的串行收集器。参数-XX:UseSerialGC。不太常用。

ParNew和ParOld收集器(并发收集器)

Serial的多线程版本收集器。

Parallel Scavenge(吞吐量优先垃圾收集器)

并行收集器,不同于多线程收集器ParNew,关注吞吐量的收集器。 
-XX:MaxGCPauseMillis=10,设置垃圾收集停顿的最大毫秒数。 
-XX:GCTimeRatio=49,垃圾收集器占比,默认是99。 
-XX:+UseAdaptiveSeizPolicy,GC自适应调节策略。 
-XX:+UseParallelGC,虚拟机Server模式默认值,使用Parallel Scavenge + Serial Old进行内存回收。 
-XX:+UseParallelOldGC, 使用Parallel Scavenge + Parallel Old 进行内存回收。

CMS

CMS作为老年代收集器,不能与Parallel Scavenge并存。可能会有内存碎片问题。 
-XX:+UserConcMarkSweepGC,新生代默认用ParNew收集。也可以用-XX:+UserParNewGC强制指定新生代用ParNew收集 
-XX:ParallelGCThreads=4,设置垃圾收集线程数。默认是(CPU数量+3)/4。垃圾收集线程数不少于25%,当CPU数量小于4的时候影响大。 
-XX:CMSInitiatingOccupancyFraction=80,老年代垃圾占比达到这个阈值开始CMS收集,1.6默认是92。设置过高容易导致并发收集失败,会出现SerialOld收集的情况。 
-XX:+UseCMSCompactAtFullCollection,在FULL GC的时候, 对年老代的压缩增加这个参数是个好习惯。可能会影响性能,但是可以消除碎片。 
-XX:CMSFullGCsBeforeCompaction=1,多少次后进行内存压缩。 
-XX:+CMSParallelRemarkEnabled, 为了减少第二次暂停的时间,开启并行remark,降低标记停顿

G1(Garbage First)

-XX:+UseG1GC,谨慎使用,需要经过线上测试,还没有被设置为默认垃圾收集器。 
之前的垃圾收集器收集的范围是新生代或者老年代,而G1垃圾收集器收集的范围包括新生代和老年代整个堆。G1将Java堆划为多个大小相同的独立区域(Region),垃圾收集单位是Region。G1垃圾收集适合至少大于4G内存得系统。并且不会产生内存空间碎片。

其他参数

-XX:MaxTenuringThreshold=30,晋升老年代的年龄。 
-XX:PretenureSizeThreshold=?,晋升老年代的对象大小。没设置过。

考虑日志打印

-verbose:gc,打印GC日志 
-XX:+PrintGC,打印GC基本日志 
-XX:+PrintGCDetails,打印GC详细日志 
-XX:+PrintGCTimeStamps,打印相对时间戳 
-XX:+PrintGCApplicationStoppedTime,打印垃圾回收期间程序暂停的时间 
-XX:+PrintGCApplicationConcurrentTime,打印每次垃圾回收前,程序未中断的执行时间 
-XX:+PrintTenuringDistribution:查看每次minor GC后新的存活周期的阈值 
-XX:+PrintTLAB,查看TLAB空间的使用情况 
-Xloggc:filename,把相关日志信息记录到文件以便分析

考虑OOM(堆溢出)时保留现场日志

当抛出OOM时进行heapdump

-XX:+HeapDumpOnOutOfMemoryError,JVM异常自动生成堆转储 
-XX:HeapDumpPath=,堆转储文件名

转自:http://blog.csdn.net/csujiangyu/article/details/52071473

时间: 2024-10-08 10:17:15

【JVM】6、聊聊JVM常用参数设置的相关文章

JVM常用参数设置

-server -Xms8g 初始堆大小 -Xmx8g 最大堆大小 -Xmn2g 年轻代大小 -Xss1024K 每个线程的堆栈大小 -XX:PermSize=256m -XX:MaxPermSize=512m Perm不属于堆内存,由虚拟机直接分配,可通过-XX:PermSize -XX:MaxPermSize 等参数调整其大小 设置持久代(perm gen)初始值   设置持久代最大值 -XX:ParallelGCThreads=8 并行收集器的线程数 -XX:+UseConcMarkSwe

jvm常用参数设置 good

1.堆的大小可以通过 -Xms 和 -Xmx 来设置,一般将他们设置为相同的大小,目的是避免在每次垃圾回收后重新调整堆的大小,比如 -Xms=2g -Xmx=2g 或者 -Xms=512m -Xmx=512m 2.年轻代大小可以通过 -Xmn 来设置,比如-Xmn=2g 或者 -Xmn512m,此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8 3.年老代大小 = 堆大小 – 年轻代大小 4.持久代或者永久代大小可以通过 -XX:PermSize 和 -XX:MaxPermSize 来控

java jvm内存管理/gc策略/参数设置

1. JVM内存管理:深入垃圾收集器与内存分配策略 http://www.iteye.com/topic/802638 Java与C++之间有一堵由内存动态分配和垃圾收集技术所围成的高墙,墙外面的人想进去,墙里面的人却想出来. 概述: 说起垃圾收集(Garbage Collection,下文简称GC),大部分人都把这项技术当做Java语言的伴生产物.事实上GC的历史远远比Java来得久远,在1960年诞生于MIT的Lisp是第一门真正使用内存动态分配和垃圾收集技术的语言.当Lisp还在胚胎时期,

jvm学习 - 虚拟机启动常用参数(2)

介绍 原文地址:1 在启动虚拟机时,可以通过配置不同参数来自定义自己的内存相关信息. 注:以下参数都是直接举例使用,可以通过修改后面的数字和单位直接使用. 参数名称 含义 默认值 使用方式 描述 -Xms 初始堆大小 物理内存的1/64(<1GB) -Xms=2048m 默认(MinHeapFreeRatio参数可以调整)空余堆内存小于40%时,JVM就会增大堆直到-Xmx的最大限制. -Xmx 最大堆大小 物理内存的1/4(<1GB) -Xmx=4096m 默认(MaxHeapFreeRat

网页中插入Flash动画(.swf)代码和常用参数设置

我们现在大部分人做网页,都是直接用DW插入flash,而且DW也是所见即所得,直接生成了相应的flash显示代码.可是我们又有多少人了解这些直接由DW生成的代码呢?其实我接触flash player标签,是在刚学习html的时候,那时书中插入flash只有最简单的<embed src="" width="" height=""></embed>一句,而且在很长一段时间里,只要网页中插入flash我也都是这样写的,当时认为,

highcharts常用参数设置

面积图 var categories= [ '前5日', '前4日', '前3日', '前2日', '前1日', '后1日', '后2日', '后3日', '后4日', '后5日']; item.highcharts({ chart: { type: 'areaspline', zoomType:'x', //width:670, height:260, backgroundColor:'#fcfcfc' //padding:0 }, colors:['#65b5f3','#ff9399','#

android Intent.setFlags 中常用参数设置

FLAG_ACTIVITY_NEW_TASK:当Intent对象包含这个标记时,系统会寻找或创建一个新的task来放置目标Activity. FLAG_ACTIVITY_CLEAR_TOP:当Intent对象包含这个标记时,如果在栈中发现存在Activity实例,则清空这个实例之上的Activity,使其处于栈顶. FLAG_ACTIVITY_SINGLE_TOP:当task中存在目标Activity实例并且位于栈的顶端时,不再创建一个新的,直接利用这个实例. 详细可参考:http://my.o

MySQL——my.cnf常用参数设置说明

[mysqld]lower_case_table_names=1 #是否区分大小写 说明 0:区分大小写,1:不区分大小写read_only=1 # 普通是否可读, 0:关闭可读, 1:开启可读super_read_only=1 # 管理员(super)用户是否可读,超级可读 ,0:关闭可读, 1:开启可读 原文地址:https://www.cnblogs.com/small-wei/p/11993241.html

聊聊JVM(一)相对全面的GC总结(转)

转至:http://blog.csdn.net/iter_zc/article/details/41746265 最近时间比较紧张,要写的东西也有很多,只能想到一点写一点.关于GC,网上的资料太多,之前对一个系统调优的时候又回顾了一下,找了几篇广泛流传的资料,大部分都是大同小异,这里总个总结,希望能够做个相对的全集,并写出一些新的点,比如Card Marking(卡片标记)等. 首先是大家都要提到的GC的基础算法:标记清除,标记整理,复制,分代.这些算法的第一步都是做的一件事: 标记(Mark)