jvm常用参数

JVM 常用参数

  1. 整体考虑堆大小

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

  2. 分代设置堆大小

    1. 新生代

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

    2. 老年代

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

    3. 永久代

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

  3. 本机直接内存

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

  4. 虚拟机栈

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

  5. 选择垃圾收集器

    1. Serial收集器(串行收集器)

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

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

      Serial的多线程版本收集器。

    3. 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 进行内存回收。

    4. CMS

      -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,降低标记停顿

    5. G1(Garbage First)

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

  6. 其他参数

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

  7. 日志打印

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

  8. OOM(堆溢出)时保留现场日志

    当抛出OOM时进行heapdump

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


source

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值