美文网首页
JVM性能调优参数摘要

JVM性能调优参数摘要

作者: 林海小盆友 | 来源:发表于2019-12-20 23:46 被阅读0次
    标示 功能 说明
    -server 使用server编译器 适用于需要长时间运行,同时又要高性能的应用
    -client 使用client编译器 适用于启动时间优先的应用
    -XX:+TieredCompilation 使用tiered编译 适用于希望取得最佳性能,又有足够的内存支撑额外编译代码的应用
    -XX:ReservedCodeCacheSize=<MB> 指定JIT编译器进行代码编译的保留空间
    -XX:InitialCodeCacheSize=<MB> 指定JIT编译器编译代码分配的初始空间
    -XX:CompileThreshold=<N> 指定一段代码或循环执行多少次后进行编译
    -XX:+PrintCompilation 打印JIT编译器的操作日志
    -XX:+CICompilerCount=<N> 设置JIT编译器使用的线程数
    标示 功能 说明
    -XX:+UseSerialGC 使用单线程垃圾回收算法 适用于容量小于100MB的堆
    -XX:+UseParallelOldGC 应用线程停顿时使用多线程对老年代进行垃圾回收 如果你的应用能够容忍偶尔发生长时间停顿,而你又希望用最小的CPU消耗取得最大吞吐量,可以考虑使用这个参数
    -XX:+UseParallelGC 应用线程停顿时使用多线程对新生代进行垃圾回收
    -XX:+UseConcMarkSweepGC 使用后台线程以最低停顿时间回收老年代垃圾对象 如果你有充足的CPU资源可以运行后台线程,你的堆也相对较小,并且你不希望垃圾收集的停顿时间过长,可以考虑使用这个参数
    -XX:+UseParNewGC 应用线程停顿时使用多线程对新生代进行垃圾回收 与ConcMarkSweepGC标志结合使用
    -XX:+UseG1GC 应用线程停顿时使用多线程对新生代进行垃圾回收,使用后台线程对老年代进行垃圾回收,以最大程度减少停顿 如果你有足够的CPU资源可以运行后台线程,你的堆也比较大,同时你又不希望有长时间的停顿,可以考虑使用这个参数
    -Xms 指定堆的初始大小
    -Xmx 指定堆的最大值
    -XX:NewRatio 指定新生代与老年代之间的比例
    -XX:NewSize 指定新生代的初始大小
    -XX:MaxNewSize 指定新生代的最大值
    -Xmn 指定新生代的初始值最大值
    -XX:PermSize=N 指定永久代的初始值
    -XX:MaxPermSize=N 指定永久代的最大值
    -XX:MetaspaceSize=N 指定元空间的初始大小
    -XX:MaxMetaspaceSize=N 指定云空间的最大容量
    -XX:ParallelGCThreads=N 指定垃圾收集使用的线程数 如果系统上同时运行了多个JVM,可以适当减少该值。如果堆空间非常大且CPU资源充足可以适当增大该值
    -verbose:gc 开启基本GC日志 建议一直开启
    -Xloggc:<path> 指定GC日志输出文件路径
    -XX:+PrintGC 开启基本GC日志 建议一直开启
    -XX:+PrintGCDetails 开启详细GC日志
    -XX:+PrintGCTimeStamps 为GC日志中的每个条目打印时间戳
    -XX:+PrintGCDateStamps 为GC日志中的每个条目打印日期时间戳
    -XX:+PrintReferenceGC 打印GC过程中的软引用和弱引用信息 如果程序中有使用软引用或弱引用,建议使用这个参数
    -XX:+UseGCLogFileRotation 开启GC日志循环,以节省空间 长期运行的程序建议使用这个参数
    -XX:NumberOfGCLogFiles=N 开启GC日志循环时,保留多少个日志文件
    -XX:GCLogFileSize=N 开启GC日志循环时,指定每个文件的大小
    -XX:+UseAdaptiveSizePolicy 使JVM根据GC目标调整堆大小
    -XX:+PrintAdaptiveSizePolicy 在GC日志中输出大小调整的详细信息
    -XX:+PrintTenuringDistribution 在GC日志中输出对象保持的信息
    -XX:InitialSurvivorRatio=N 设置新生代中预留给Survivor空间的大小
    -XX:MinSurvivorRatio=N 设置新生代空间中用于自适应调整Survivor空间大小
    -XX:TargetSurvivorRatio=N 设置Survivor空间保留的空闲空间
    -XX:InitialTenuringThreshold=N JVM试图在Survivor空间保持对象的GC周期
    -XX:MaxTenuringThreshold=N 设置JVM可以将一个对象保持在Survivor空间的最大GC周期数
    -XX:MaxGCPauseMillis 为多线程垃圾收集器设置最长停顿时间,堆的大小会依据该目标动态调整
    -XX:GCTimeRatio=N 为多线程垃圾收集器设置在垃圾收集上花费的时间比例
    -XX:CMSInitiatingOccupancyFraction=N 设置CMS垃圾收集器开启老年代后台扫描的时机 如果发生并发失效,应该适当减少该参数的值
    -XX:+UseCMSInitiatingOccupancyOnly 通知CMS收集器仅通过-XX:CMSInitiatingOccupancyFraction标志决定何时启动后台扫描 与-XX:CMSInitiatingOccupancyFraction一起使用
    -XX:ConcGCThreads=N 设置CMS收集器后台扫描线程数 如果发生并发失效,同时又有大量的空闲CPU资源时,可以适当提高该值
    -XX:+CMSPermGenSweepingEnabled 通知CMS收集器对永久代进行整理
    -XX:CMSInitiatingPermOccupancyFraction=N 设置CMS开启永久代扫描的时机
    -XX:+CMSClassUnloadingEnabled 设置CMS收集器在永久代扫描结束后卸载类
    -XX:CMSIncrementalMode 设置CMS以增量模式运行
    -XX:CMSIncrementalModeSafetyFactor=N 影响增量式CMS垃圾收集后台线程的运行频度
    -XX:CMSIncrementalDutyCycleMin=N 影响增量式CMS垃圾收集后台线程的运行频度
    -XX:CMSIncrementalDutyCycleMax=N 影响增量式CMS垃圾收集后台线程的运行频度
    -XX:+CMSIncrementalDutyCycle 影响增量式CMS垃圾收集后台线程的运行频度
    -XX:InitiatingHeapOccupancyPerent 设置G1收集开启后台扫描的时机 如果发生并发失败应该适当减小该参数
    -XX:G1MaxedGCCountTarget=N 设置混合GC次数
    -XX:G1HeapRegionSize=N 设置G1分区的大小
    -XX:HeapDumpOnOutOfMemoryError JVM堆转储
    -XX:HeapDumpPath=<Path> 设置自动堆转储的文件名
    -XX:SoftRefLRUPolicyMSPerMB=N 设置使用多长时间后软引用对象可以被回收 内存不足的情况下,减少这个值可以更快的回收软引用对象
    -XX:MaxDirectMemorySize=N 设置本地内存最大值
    -XX:+UseLargePages 设置JVM从操作系统的大页面系统中分配页面 如果操作系统支持,这个参数可以改善性能

    相关文章

      网友评论

          本文标题:JVM性能调优参数摘要

          本文链接:https://www.haomeiwen.com/subject/cqjwnctx.html