实例讲解JVM参数调优的八条经验
本文将介绍JVM参数调优,这是很头痛的问题,设置的不好,JVM不断执行Full GC,导致整个系统变得很慢,网站停滞时间能达10秒以上,这种情况如果没隔几分钟就来一次,自己都受不了。这种停滞在测试的时候看不出来,只有网站pv达到数十万/天的时候问题就暴露出来了。
要想配置好JVM参数,需要对年轻代、年老代、救助空间和永久代有一定了解,还要了解jvm内存管理逻辑,最终还要根据自己的应用来做调整。关于JVM参数上网一搜就能搜出一大把,也有很多提供实践的例子,我也按照各种例子测试过,最终还是会出现问题。
经过几个月的实践改善,我就网站(要求无停滞时间)的jvm参数调优给出以下几条经验。
1:建议用64位操作系统,Linux下64位的jdk比32位jdk要慢一些,但是吃得内存更多,吞吐量更大。
2:XMX和XMS设置一样大,MaxPermSize和MinPermSize设置一样大,这样可以减轻伸缩堆大小带来的压力。
3:调试的时候设置一些打印参数,如-XX:+PrintClassHistogram -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintHeapAtGC -Xloggc:log/gc.log,这样可以从gc.log里看出一些端倪出来。
4:系统停顿的时候可能是GC的问题也可能是程序的问题,多用jmap和jstack查看,或者killall -3 java,然后查看java控制台日志,能看出很多问题。有一次,网站突然很慢,jstack一看,原来是自己写的URLConnection连接太多没有释放,改一下程序就OK了。
5:仔细了解自己的应用,如果用了缓存,那么年老代应该大一些,缓存的HashMap不应该无限制长,建议采用LRU算法的Map做缓存,LRUMap的最大长度也要根据实际情况设定。
6:垃圾回收时promotion failed是个很头痛的问题,一般可能是两种原因产生,第一个原因是救助空间不够,救助空间里的对象还不应该被移动到年老代,但年轻代又有很多对象需要放入救助空间;第二个原因是年老代没有足够的空间接纳来自年轻代的对象;这两种情况都会转向Full GC,网站停顿时间较长。第一个原因我的最终解决办法是去掉救助空间,设置-XX:SurvivorRatio=65536 -XX:MaxTenuringThreshold=0即可,第二个原因我的解决办法是设置CMSInitiatingOccupancyFraction为某个值(假设70),这样年老代空间到70%时就开始执行CMS,年老代有足够的空间接纳来自年轻代的对象。
7:不管怎样,永久代还是会逐渐变满,所以隔三差五重起java服务器是必要的,我每天都自动重起。
8:采用并发回收时,年轻代小一点,年老代要大,因为年老大用的是并发回收,即使时间长点也不会影响其他程序继续运行,网站不会停顿。
我的最终配置如下(系统8G内存),每天几百万pv一点问题都没有,网站没有停顿,2009年网站没有因为内存问题down过机。
- $JAVA_ARGS .= " -Dresin.home=$SERVER_ROOT -server
- -Xms6000M -Xmx6000M -Xmn500M -XX:PermSize=500M -XX:MaxPermSize=500M
- -XX:SurvivorRatio=65536 -XX:MaxTenuringThreshold=0 -Xnoclassgc
- -XX:+DisableExplicitGC -XX:+UseParNewGC -XX:+UseConcMarkSweepGC
- -XX:+UseCMSCompactAtFullCollection -XX:CMSFullGCsBeforeCompaction=0
- -XX:+CMSClassUnloadingEnabled -XX:-CMSParallelRemarkEnabled
- -XX:CMSInitiatingOccupancyFraction=90 -XX:SoftRefLRUPolicyMSPerMB=0
- -XX:+PrintClassHistogram -XX:+PrintGCDetails -XX:+PrintGCTimeStamps
- -XX:+PrintHeapAtGC -Xloggc:log/gc.log ";
说明一下, -XX:SurvivorRatio=65536 -XX:MaxTenuringThreshold=0就是去掉了救助空间;
-Xnoclassgc禁用类垃圾回收,性能会高一点;
-XX:+DisableExplicitGC禁止System.gc(),免得程序员误调用gc方法影响性能;
-XX:+UseParNewGC,对年轻代采用多线程并行回收,这样收得快;
带CMS参数的都是和并发回收相关的,不明白的可以上网搜索;
CMSInitiatingOccupancyFraction,这个参数设置有很大技巧,基本上满足(Xmx-Xmn)*(100-CMSInitiatingOccupancyFraction)/100>=Xmn就不会出现promotion failed。在我的应用中Xmx是6000,Xmn是500,那么Xmx-Xmn是5500兆,也就是年老代有5500兆,CMSInitiatingOccupancyFraction=90说明年老代到90%满的时候开始执行对年老代的并发垃圾回收(CMS),这时还剩10%的空间是5500*10%=550兆,所以即使Xmn(也就是年轻代共500兆)里所有对象都搬到年老代里,550兆的空间也足够了,所以只要满足上面的公式,就不会出现垃圾回收时的promotion failed;
SoftRefLRUPolicyMSPerMB这个参数我认为可能有点用,官方解释是softly reachable objects will remain alive for some amount of time after the last time they were referenced. The default value is one second of lifetime per free megabyte in the heap,我觉得没必要等1秒;
网上其他介绍JVM参数的也比较多,估计其中大部分是没有遇到promotion failed,或者访问量太小没有机会遇到,(Xmx-Xmn)*(100-CMSInitiatingOccupancyFraction)/100>=Xmn这个公式绝对是原创,真遇到promotion failed了,还得这么处理。
相关推荐
JVM调优实战 本文档旨在介绍JVM调优...本文档提供了JVM调优实战的详细介绍,包括JVM内存结构、垃圾回收机制、性能优化策略和JVM参数配置等方面的知识点。通过对这些知识点的掌握,读者可以更好地理解和优化JVM的性能。
JVM的性能调优往往依赖于理解和调整这些内存区域的分配大小、垃圾回收策略等参数。通过设置JVM启动参数,如-Xmx、-Xms、-XX:SurvivorRatio等,开发者可以控制堆的大小和新生代与旧生代的比例,以及永久代的大小等,...
本视频教程详细讲解了以上内容,并通过实例演示和代码分析,使学习者能够将理论知识应用到实际项目中,提升Java并发编程和JVM性能调优的专业技能。配合提供的"Java高并发编程与JVM性能调优实战 视频教程 下载下载...
这里我们将详细探讨这些关键知识点,并结合提供的"生产环境jvm调优的实例代码-jvm.zip"中的内容进行深入讲解。 1. **内存配置**:JVM内存分为新生代(Young Generation)、老年代(Tenured Generation/老年代)和...
本教程——“深入JVM内核—原理、诊断与优化视频教程”,将重点讲解这些关键点,帮助开发者提升技术水平,更好地解决实际问题。 首先,我们来探讨JVM的内核原理。JVM主要由类加载子系统、运行时数据区、执行引擎、...
JVM调优实战文档可能涵盖了如何通过监控工具分析内存泄漏,理解GC日志,以及如何调整初始堆大小和最大堆大小等参数,以达到最佳性能和稳定性。 接下来是MySQL 5.6的性能优化。MySQL作为广泛使用的开源关系型数据库...
在本课程中,T01到T05的例子程序涵盖了多个关键的JVM调优知识点,让我们一一探讨。 首先,T01可能涉及的是JVM的基本概念与架构,包括类加载机制、运行时数据区、垃圾收集等。类加载机制涉及到类加载器(ClassLoader...
以上介绍的工具是JVM调优过程中非常重要的组成部分,通过对这些工具的理解和使用,可以有效地监测和调整JVM的状态,进而优化Java应用程序的性能。对于开发人员而言,掌握这些工具的使用方法对于提高程序的稳定性和...
此外,JVM调优涉及许多方面,如设置合理的堆大小、新生代与老年代的比例、线程栈大小等。通过分析JVM的性能指标,如CPU使用率、GC频率和暂停时间,可以发现并解决性能瓶颈。 JVM的动态特性,如类加载的双亲委派模型...
《JVM虚拟机深度讲解》这本书是JAVA开发者深入理解JVM的重要参考资料,它全面而详尽地探讨了Java虚拟机的工作原理与优化技巧。通过阅读本书,开发者可以大幅提升对JVM的理解,从而在编程实践中更好地驾驭这个强大的...
栈分配及实例讲解 server与client模式 调试跟踪参数 介绍常用的JVM参数,包括内存分配、堆栈分配、虚拟机运行模式以及调试跟踪参数。 第四课 GC的算法和种类 引用计数 标记清除 复制算法 标记压缩 可触及性 本章是...
### VM调优实战指南:GC与性能优化 #### 一、GC调优 **1.... GC(Garbage Collection),即垃圾收集,是Java虚拟机(JVM)的一项关键...本文通过具体的实例讲解了JVM的GC调优和性能调优方法,希望能为读者提供实际帮助。
2.4 **SUN JVM调优**:JVM调优包括调整堆大小、设置垃圾回收策略、监控内存使用等,以提高程序性能和减少停顿时间。 2.5 **JVM简单理解** - **Java栈**:每个线程都有自己的Java栈,用于存储局部变量、方法参数和...
本课程的PPT旨在深入讲解JVM的工作原理、内存管理、性能优化等相关知识,帮助学员提升对JVM的理解并能应用于实际开发中。 一、JVM概述 Java虚拟机作为一个抽象的计算机,它负责解析字节码并执行Java程序。JVM的主要...
这份“JVM培训PPT”旨在深入讲解JVM的工作原理、内存管理和性能优化等方面的知识,帮助开发者更好地理解和利用JVM。 **一、JVM结构与工作流程** 1. **类加载子系统**: JVM负责加载、验证、准备、解析和初始化类。...
本文档将详细讲解Java Web系统性能调优的过程,主要关注JVM(Java Virtual Machine)的优化。 1. 性能调优流程 调优通常包括以下三个关键步骤: 1.1 确定调优目标 在开始调优之前,首先需要明确目标,例如减少...
最后,课程还涵盖了JVM在实际项目中的应用,比如大型分布式系统中的JVM调优实践,以及如何通过JVM特性解决实际问题,如线程池管理、类加载冲突、JNI(Java Native Interface)的使用等。 通过这套2020年最新的JVM...
JVM的性能监控与调优是优化Java应用程序的关键步骤,通过工具如JConsole、VisualVM等,开发者可以监控内存使用、CPU消耗、线程状态等,从而找出性能瓶颈并进行优化。理解JVM的工作原理和内存管理,对于编写高效的...
在6小时的视频教程中,作者可能详细讲解了这些概念,并通过实例演示如何分析和优化JVM的性能。笔记54页PDF可能涵盖了关键知识点的总结,便于复习和查阅。 学习JVM对于Java开发者来说至关重要,因为它涉及到性能调优...
6. **JVM调优**:JVM参数调整是优化性能的关键。例如,通过-Xms和-Xmx设置堆大小,-XX:NewRatio调整新生代和老年代比例,-XX:+UseConcMarkSweepGC选择合适的GC算法等。监控工具如VisualVM和JConsole可以帮助分析和...