Java技术债务Java技术债务

  •  首页
  •  分类
  •  归档
  •  标签
  • 博客日志
  • 资源分享
  •  友链
  •  关于本站
注册
登录

JVM之配置介绍(一)

JVM

文章目录

  • 基础配置
  • 内存溢出配置
  • 回收器选择
  • 响应时间优先的并发收集器
  • 垃圾回收统计信息

基础配置

  • **Xms2048m:**JVM启动时申请的最小内存,默认为系统物理内存的1/64,但是小于1G
  • **Xmx2048m:**JVM启动时申请的最大内存,默认为系统物理内存的1/4,但是小于1G;默认当空余堆内存小于40%时,JVM会增大heap到-Xmx指定的大小;可通过
  • **XX:MinHeapFreeRation:**改变比例;当空余堆内存大于70%时,JVM会减小heap的大小到-Xms指定的大小,可通过-XX:MaxHeapFreeRation来指定这个比列。

注:最大内存可以设置为与-Xms相同,用来避免每次垃圾回收完成后重新分配内存。

  • **XX:MinHeapFreeRation:**可改变JVM最小剩余堆内存大小比例,增大到指定最大内存
  • **XX:MaxHeapFreeRation:**可改变JVM最大剩余堆内存大小比例,减小到指定最小内存
  • **Xmn2g:**设置年轻代大小为2G,堆大小=年轻带大小+老年代大小+永久代(元空间)大小;所以增大年轻代后,将会减小年老代大小。此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8。
  • **Xss128k:**设置每个线程堆栈的大小;相同物理环境下,减小值能生成更多的线程,但是操作系统中同一个进程内的线程数是有限制的,不能无限生成,经验值在3000~5000左右。
  • XX:NewRatio=4:设置年轻代(包括Eden和两个Survivor区)与老年代的比值设置为4,则年轻代与老年代所占比值为1:4,年轻代占整个堆栈的1/5。
  • XX:SurvivorRatio=4:设置年轻代中Eden区和Survivor区的比值设置为4,则Eden去和两个Survivor区的比值为4:2,一个Survivor去占整个年轻代的1/6。
  • XX:MaxPermSize=16m:设置持久代大小为16m。
  • XX:MaxTenuringThreshold=4:设置垃圾最大年龄,如果设置为0,则年轻代对象不经过年轻代直接进入老年代,可以提高效率。如果值较大,则会在年轻代中频繁复制,造成CPU的使用。
  • XX:+PrintGCDetails:输出打印垃圾回收的详细日志

内存溢出配置

  • XX:+HeapDumpOnOutOfMemoryError
  • **XX:HeapDumpPath=/var/log/jvm/app -XX:ErrorFile=/var/log/jvm/app/java_error_%p.log:**内存溢出时将错误日志输出到指定日志文件中。

回收器选择

JVM给了三种选择:串行收集器、并行收集器、并发收集器,但是串行收集器只适用于小数据量的情况,

  • **XX:+UseParallelGC:**选择垃圾收集器为并行收集器。此配置仅对年轻代有效。即上述配置下,年轻代使用并发收集,而年老代仍旧使用串行收集。
  • **XX:ParallelGCThreads=20:**配置并行收集器的线程数,即:同时多少个线程一起进行垃圾回收。此值最好配置与处理器数目相等。
  • **XX:+UseParallelOldGC:**配置年老代垃圾收集方式为并行收集。
  • **XX:MaxGCPauseMillis=100:**设置每次年轻代垃圾回收的最长时间,如果无法满足此时间,JVM会自动调整年轻代大小,以满足此值。
  • **XX:+UseAdaptiveSizePolicy:**设置此选项后,并行收集器会自动选择年轻代区大小和相应的Survivor区比例,以达到目标系统规定的最低相应时间或者收集频率等,此值建议使用并行收集器时,一直打开。
  • XX:+UseSerialGC 设置串行收集器

响应时间优先的并发收集器

并发收集器主要是保证系统的响应时间,减少垃圾收集时的停顿时间。适用于应用服务器、电信领域等。

  • **XX:+UseConcMarkSweepGC:**设置年老代为并发收集。测试中配置这个以后,-XX:NewRatio=4的配置失效了,原因不明。所以,此时年轻代大小最好用-Xmn设置。
  • **XX:+UseParNewGC:**设置年轻代为并行收集。可与CMS收集同时使用。JDK5.0以上,JVM会根据系统配置自行设置,所以无需再设置此值。
  • XX:CMSFullGCsBeforeCompaction 由于并发收集器不对内存空间进行压缩、整理,所以运行一段时间以后会产生“碎片”,使得运行效率降低。此值设置运行多少次GC以后对内存空间进行压缩、整理。
  • XX:+UseCMSCompactAtFullCollection 打开对年老代的压缩。可能会影响性能,但是可以消除碎片

垃圾回收统计信息

  • XX:+PrintGCApplicationConcurrentTime 打印每次垃圾回收前,程序未中断的执行时间
  • XX:+PrintGCApplicationStoppedTime 打印垃圾回收期间程序暂停的时间。
  • XX:PrintHeapAtGC 打印GC前后的详细堆栈信息

基础配置

  • **Xms2048m:**JVM启动时申请的最小内存,默认为系统物理内存的1/64,但是小于1G
  • **Xmx2048m:**JVM启动时申请的最大内存,默认为系统物理内存的1/4,但是小于1G;默认当空余堆内存小于40%时,JVM会增大heap到-Xmx指定的大小;可通过
  • **XX:MinHeapFreeRation:**改变比例;当空余堆内存大于70%时,JVM会减小heap的大小到-Xms指定的大小,可通过-XX:MaxHeapFreeRation来指定这个比列。

注:最大内存可以设置为与-Xms相同,用来避免每次垃圾回收完成后重新分配内存。

  • **XX:MinHeapFreeRation:**可改变JVM最小剩余堆内存大小比例,增大到指定最大内存
  • **XX:MaxHeapFreeRation:**可改变JVM最大剩余堆内存大小比例,减小到指定最小内存
  • **Xmn2g:**设置年轻代大小为2G,堆大小=年轻带大小+老年代大小+永久代(元空间)大小;所以增大年轻代后,将会减小年老代大小。此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8。
  • **Xss128k:**设置每个线程堆栈的大小;相同物理环境下,减小值能生成更多的线程,但是操作系统中同一个进程内的线程数是有限制的,不能无限生成,经验值在3000~5000左右。
  • XX:NewRatio=4:设置年轻代(包括Eden和两个Survivor区)与老年代的比值设置为4,则年轻代与老年代所占比值为1:4,年轻代占整个堆栈的1/5。
  • XX:SurvivorRatio=4:设置年轻代中Eden区和Survivor区的比值设置为4,则Eden去和两个Survivor区的比值为4:2,一个Survivor去占整个年轻代的1/6。
  • XX:MaxPermSize=16m:设置持久代大小为16m。
  • XX:MaxTenuringThreshold=4:设置垃圾最大年龄,如果设置为0,则年轻代对象不经过年轻代直接进入老年代,可以提高效率。如果值较大,则会在年轻代中频繁复制,造成CPU的使用。
  • XX:+PrintGCDetails:输出打印垃圾回收的详细日志

内存溢出配置

  • XX:+HeapDumpOnOutOfMemoryError
  • **XX:HeapDumpPath=/var/log/jvm/app -XX:ErrorFile=/var/log/jvm/app/java_error_%p.log:**内存溢出时将错误日志输出到指定日志文件中。

回收器选择

JVM给了三种选择:串行收集器、并行收集器、并发收集器,但是串行收集器只适用于小数据量的情况,

  • **XX:+UseParallelGC:**选择垃圾收集器为并行收集器。此配置仅对年轻代有效。即上述配置下,年轻代使用并发收集,而年老代仍旧使用串行收集。
  • **XX:ParallelGCThreads=20:**配置并行收集器的线程数,即:同时多少个线程一起进行垃圾回收。此值最好配置与处理器数目相等。
  • **XX:+UseParallelOldGC:**配置年老代垃圾收集方式为并行收集。
  • **XX:MaxGCPauseMillis=100:**设置每次年轻代垃圾回收的最长时间,如果无法满足此时间,JVM会自动调整年轻代大小,以满足此值。
  • **XX:+UseAdaptiveSizePolicy:**设置此选项后,并行收集器会自动选择年轻代区大小和相应的Survivor区比例,以达到目标系统规定的最低相应时间或者收集频率等,此值建议使用并行收集器时,一直打开。
  • XX:+UseSerialGC 设置串行收集器

响应时间优先的并发收集器

并发收集器主要是保证系统的响应时间,减少垃圾收集时的停顿时间。适用于应用服务器、电信领域等。

  • **XX:+UseConcMarkSweepGC:**设置年老代为并发收集。测试中配置这个以后,-XX:NewRatio=4的配置失效了,原因不明。所以,此时年轻代大小最好用-Xmn设置。
  • **XX:+UseParNewGC:**设置年轻代为并行收集。可与CMS收集同时使用。JDK5.0以上,JVM会根据系统配置自行设置,所以无需再设置此值。
  • XX:CMSFullGCsBeforeCompaction 由于并发收集器不对内存空间进行压缩、整理,所以运行一段时间以后会产生“碎片”,使得运行效率降低。此值设置运行多少次GC以后对内存空间进行压缩、整理。
  • XX:+UseCMSCompactAtFullCollection 打开对年老代的压缩。可能会影响性能,但是可以消除碎片

垃圾回收统计信息

  • XX:+PrintGCApplicationConcurrentTime 打印每次垃圾回收前,程序未中断的执行时间
  • XX:+PrintGCApplicationStoppedTime 打印垃圾回收期间程序暂停的时间。
  • XX:PrintHeapAtGC 打印GC前后的详细堆栈信息
完
  • 本文作者:Java技术债务
  • 原文链接: https://cuizb.top/myblog/article/1642766982
  • 版权声明: 本博客所有文章除特别声明外,均采用 CC BY 3.0 CN协议进行许可。转载请署名作者且注明文章出处。
阅读全文
Java技术债务

Java技术债务

Java技术债务
Java技术债务
热门文章
  1. ClickHouse使用过程中的一些查询优化(六)2003
  2. MySQL数据库被攻击,被删库勒索,逼迫我使出洪荒之力进行恢复数据764
  3. MySQL主从同步原理458
  4. 线程池的理解以及使用414
  5. Spring Cloud Gateway整合nacos实战(三)409
分类
  • Java
    30篇
  • 设计模式
    27篇
  • 数据库
    20篇
  • Spring
    18篇
  • MySQL
    13篇
  • ClickHouse
    11篇
  • Kubernetes
    10篇
  • Redis
    9篇
  • Docker
    8篇
  • SpringBoot
    7篇
  • JVM
    6篇
  • Linux
    5篇
  • Spring Cloud
    5篇
  • 多线程
    5篇
  • Netty
    4篇
  • Kafka
    4篇
  • 面经
    4篇
  • Nginx
    3篇
  • JUC
    3篇
  • 随笔
    2篇
  • 分布式
    1篇
  • MyBatis
    1篇
  • 报错合集
    1篇
  • 生活记录
    1篇
  • 源码
    1篇
  • 性能优化
    1篇

最新评论

  • MySQL数据库被攻击,被删库勒索,逼迫我使出洪荒之力进行恢复数据2022-05-06
    Java技术债务:@capture 一起探讨学习,服务器被黑很正常,及时做好备份以及做好防护
  • MySQL数据库被攻击,被删库勒索,逼迫我使出洪荒之力进行恢复数据2022-04-13
    capture:我的刚上线两天,网站里就两篇文章也被攻击了,纳闷
  • Java常用集合List、Map、Set介绍以及一些面试问题2022-01-18
    Java技术债务:HashSet和TreeSet 相同点:数据不能重复 不同点: 1、底层存储结构不同; HashSet底层使用HashMap哈希表存储 TreeSet底层使用TreeMap树结构存储 2、唯一性方式不同 HashSet底层使用hashcode()和equal()方法判断 TreeSet底层使用Comparable接口的compareTo判断的 3、HashSet无序,TreeSet有序
  • undefined2021-12-14
    Java技术债务:如果不指定线程池,CompletableFuture会默认使用ForkJoin线程池,如果同一时间出现大量请求的话,会出现线程等待问题,建议使用自定义线程池。。。
  • undefined2021-12-02
    you:很好,对于小白相当不错了,谢谢
  • CSDN
  • 博客园
  • 程序猿DD
  • 纯洁的微笑
  • spring4all
  • 廖雪峰的官方网站
  • 猿天地
  • 泥瓦匠BYSocket
  • crossoverJie
  • 张先森个人博客
  • 越加网

© 2021-2022 Java技术债务 - Java技术债务 版权所有
总访问量 0 次 您是本文第 0 位童鞋
豫ICP备2021034516号
Java技术债务 豫公网安备 51011402000164号

微信公众号

Java技术债务
Java技术债务

专注于Spring,SpringBoot等后端技术探索

以及MySql数据库开发和Netty等后端流行框架学习

日志
分类
标签
RSS

有不足之处也希望各位前辈指出