并发收集器

  并发收集器(响应时间优先)

  -XX:+UseConcMarkSweepGC:即CMS收集,设置年老代为并发收集。CMS收集是JDK1.4后期版本开始引入的新GC算法。它的主要适合场景是对响应时间的重要性需求大于对吞吐量的需求,能够承受垃圾回收线程和应用线程共享CPU资源,并且应用中存在比较多的长生命周期对象。CMS收集的目标是尽量减少应用的暂停时间,减少Full GC发生的几率,利用和应用程序线程并发的垃圾回收线程来标记清除年老代内存。

  -XX:+UseParNewGC:设置年轻代为并发收集。可与CMS收集同时使用。JDK5.0以上,JVM会根据系统配置自行设置,所以无需再设置此参数。

  -XX:CMSFullGCsBeforeCompaction=0:由于并发收集器不对内存空间进行压缩和整理,所以运行一段时间并行收集以后会产生内存碎片,内存使用效率降低。此参数设置运行0次Full GC后对内存空间进行压缩和整理,即每次Full GC后立刻开始压缩和整理内存。

  -XX:+UseCMSCompactAtFullCollection:打开内存空间的压缩和整理,在Full GC后执行。可能会影响性能,但可以消除内存碎片。

  -XX:+CMSIncrementalMode:设置为增量收集模式。一般适用于单CPU情况。

  -XX:CMSInitiatingOccupancyFraction=70:表示年老代内存空间使用到70%时就开始执行CMS收集,以确保年老代有足够的空间接纳来自年轻代的对象,避免Full GC的发生。

  其它垃圾回收参数

  -XX:+ScavengeBeforeFullGC:年轻代GC优于Full GC执行。

  -XX:-DisableExplicitGC:不响应 System.gc() 代码。

  -XX:+UseThreadPriorities:启用本地线程优先级API.即使 java.lang.Thread.setPriority() 生效,不启用则无效。

  -XX:SoftRefLRUPolicyMSPerMB=0:软引用对象在最后一次被访问后能存活0毫秒(JVM默认为1000毫秒)。

  -XX:TargetSurvivorRatio=90:允许90%的Survivor区被占用(JVM默认为50%)。提高对于Survivor区的使用率。

  辅助信息参数设置

  -XX:-CITime:打印消耗在JIT编译的时间。

  -XX:ErrorFile=./hs_err_pid.log:保存错误日志或数据到指定文件中。

  -XX:HeapDumpPath=./java_pid.hprof:指定Dump堆内存时的路径。

  -XX:-HeapDumpOnOutOfMemoryError:当首次遭遇内存溢出时Dump出此时的堆内存。

  -XX:OnError=";":出现致命ERROR后运行自定义命令。

  -XX:OnOutOfMemoryError=";":当首次遭遇内存溢出时执行自定义命令。

  -XX:-PrintClassHistogram:按下 Ctrl+Break 后打印堆内存中类实例的柱状信息,同JDK的 jmap -histo 命令。

  -XX:-PrintConcurrentLocks:按下 Ctrl+Break 后打印线程栈中并发锁的相关信息,同JDK的 jstack -l 命令。

  -XX:-PrintCompilation:当一个方法被编译时打印相关信息。

  -XX:-PrintGC:每次GC时打印相关信息。

  -XX:-PrintGCDetails:每次GC时打印详细信息。

  -XX:-PrintGCTimeStamps:打印每次GC的时间戳。

  -XX:-TraceClassLoading:跟踪类的加载信息。

  -XX:-TraceClassLoadingPreorder:跟踪被引用到的所有类的加载信息。

  -XX:-TraceClassResolution:跟踪常量池。

  -XX:-TraceClassUnloading:跟踪类的卸载信息。

  关于参数名称等

  标准参数(-),所有JVM都必须支持这些参数的功能,而且向后兼容;例如:

  -client--设置JVM使用Client模式,特点是启动速度比较快,但运行时性能和内存管理效率不高,通常用于客户端应用程序或开发调试;在32位环境下直接运行Java程序默认启用该模式。

  -server--设置JVM使Server模式,特点是启动速度比较慢,但运行时性能和内存管理效率很高,适用于生产环境。在具有64位能力的JDK环境下默认启用该模式。

  非标准参数(-X),默认JVM实现这些参数的功能,但是并不保证所有JVM实现都满足,且不保证向后兼容;

  非稳定参数(-XX),此类参数各个JVM实现会有所不同,将来可能会不被支持,需要慎重使用;

  JVM服务参数调优实战

  大型网站服务器案例

  承受海量访问的动态Web应用

  服务器配置:8 CPU, 8G MEM, JDK 1.6.X

  参数方案:

  -server -Xmx3550m -Xms3550m -Xmn1256m -Xss128k -XX:SurvivorRatio=6 -XX:MaxPermSize=256m -XX:ParallelGCThreads=8 -XX:MaxTenuringThreshold=0 -XX:+UseConcMarkSweepGC

  调优说明:

  -Xmx 与 -Xms 相同以避免JVM反复重新申请内存。-Xmx 的大小约等于系统内存大小的一半,即充分利用系统资源,又给予系统安全运行的空间。

  -Xmn1256m 设置年轻代大小为1256MB.此值对系统性能影响较大,Sun官方推荐配置年轻代大小为整个堆的3/8.

  -Xss128k 设置较小的线程栈以支持创建更多的线程,支持海量访问,并提升系统性能。

  -XX:SurvivorRatio=6 设置年轻代中Eden区与Survivor区的比值。系统默认是8,根据经验设置为6,则2个Survivor区与1个Eden区的比值为2:6,一个Survivor区占整个年轻代的1/8.

  -XX:ParallelGCThreads=8 配置并行收集器的线程数,即同时8个线程一起进行垃圾回收。此值一般配置为与CPU数目相等。

  -XX:MaxTenuringThreshold=0 设置垃圾最大年龄(在年轻代的存活次数)。如果设置为0的话,则年轻代对象不经过Survivor区直接进入年老代。对于年老代比较多的应用,可以提高效率;如果将此值设置为一个较大值,则年轻代对象会在Survivor区进行多次复制,这样可以增加对象再年轻代的存活时间,增加在年轻代即被回收的概率。根据被海量访问的动态Web应用之特点,其内存要么被缓存起来以减少直接访问DB,要么被快速回收以支持高并发海量请求,因此其内存对象在年轻代存活多次意义不大,可以直接进入年老代,根据实际应用效果,在这里设置此值为0.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值