首页 > 其他分享 >Jvm调优

Jvm调优

时间:2022-09-01 10:57:40浏览次数:49  
标签:年轻 代会 XX 调优 GC 内存 Jvm 年老

首先我们可以使用各种JVM工具,查看当前日志,分析当前JVM参数设置,并且分析当前堆内存快照和gc日志,根据实际的各区域内存划分和GC执行时间,觉得是否进行优化,当然我们也可以直接生成堆的dump文件,进行分析,比如GC时间超过1-3秒,或者频繁GC,则必须进行一个优化

1.针对JVM堆的设置,一般可以通过-Xms -Xmx限定其最小、最大值,为了防止垃圾收集器在最小、最大之间收缩堆而产生额外的时间,通常把最大、最小设置为相同的值

 2.年轻代和年老代将根据默认的比例(1:2)分配堆内存, 可以通过调整二者之间的比率NewRadio来调整二者之间的大小,也可以针对回收代

  比如年轻代,通过 -XX:newSize -XX:MaxNewSize来设置其绝对大小。同样,为了防止年轻代的堆收缩,我们通常会把-XX:newSize -XX:MaxNewSize设置为同样大小

3.年轻代和年老代设置多大才算合理
  1)更大的年轻代必然导致更小的年老代,大的年轻代会延长普通GC的周期,但会增加每次GC的时间;小的年老代会导致更频繁的Full GC
  2)更小的年轻代必然导致更大年老代,小的年轻代会导致普通GC很频繁,但每次的GC时间会更短;大的年老代会减少Full GC的频率
如何选择应该依赖应用程序对象生命周期的分布情况:
  如果应用存在大量的临时对象,应该选择更大的年轻代;如果存在相对较多的持久对象,年老代应该适当增大。但很多应用都没有这样明显的特性。 在抉择时应该根据以下两点:   1)本着Full GC尽量少的原则,让年老代尽量缓存常用对象,JVM的默认比例1:2也是这个道理   2)通过观察应用一段时间,看其他在峰值时年老代会占多少内存,在不影响Full GC的前提下,根据实际情况加大年轻代,比如可以把比例控制在1:1。但应该给年老代至少预留1/3的增长空间
4.在配置较好的机器上(比如多核、大内存),可以为年老代选择并行收集算法:-XX:+UseParallelOldGC****
5.线程堆栈的设置:每个线程默认会开启1M的堆栈,用于存放栈帧、调用参数、局部变量等,对大多数应用而言这个默认值大了,一般256K就足用

标签:年轻,代会,XX,调优,GC,内存,Jvm,年老
From: https://www.cnblogs.com/jerrybky/p/16645717.html

相关文章

  • jvm优化-步骤
    1、监控分析分析GC日志及dump文件,判断是否需要优化,确定瓶颈问题点。2、生成GC日志命令:-Xloggc:./gc.log-XX:+PrintGCDetails-XX:+PrintGCDateStamps在线分析网站:ht......
  • JVM和java体系结构
    前言:JVM(JavaVirtualMachine)是java虚拟机,是java上层框架的基础,欲练神功,先练内功!JVM和java体系结构  一次编译,到处运行.跨平台   不同语言使用编译器......
  • 打开Eclipse时提示“JVM is not suitable for this product”问题的解决
    今天打开Eclipse时弹出一个错误提示,无法正常打开。“Version1.8.0_131oftheJVMisnotsuitableforthisproduct.Version:11orgreaterisrequired.”之前印象......
  • JVM基础(狂神)
    JVM探究谈谈你对JVM的理解?java8虚拟机和之前的变化更新什么是OOM,什么是栈溢出?怎么分析JVM的常用调优参数有哪些?内存快照如何抓取,怎么分析Dump文件?谈谈JVM中,你对类加......
  • 性能调优读书笔记(下篇)
    一、并行程序开发优化1、Future设计模式publicclassClient{publicDatarequest(finalStringqueryStr){finalFutureDatafuture=newFutureData(......
  • mysql之sql调优
    一、性能分析1.慢查询日志:慢查询日志记录了所有执行时间超过指定时间的所有sql配置方法修改my.cnf文件如下:#开启慢日志查询slow_query_log=1......
  • Java的三大版本以及JDK、JRE、JVM
    Java的三大版本以及JDK、JRE、JVMJava的三大版本JavaSE:标准版(桌面程序、控制台开发...)JavaME:嵌入式开发(手机、小家电)JavaEE:企业级开发(web端、企业级开发)JDK、JRE、J......
  • nginx调优
    本文中,红色字体为nginx调优建议值。  1.Linux系统资源限制配置调优linux资源限制配置文件是/etc/security/limits.conf;限制用户进程的数量对于linux系统的稳定性非......
  • JVM理解2
    1、垃圾回收(GC)GC(GarbageCollection,即垃圾回收)的基本原理:将内存中不再被使用的对象进行回收。垃圾回收主要是发生在堆内存里面,在1.8以后FULLGC也会发生在metaspace中。......
  • 问题记录_IDEA启动报错:Failed to create JVM. JVM Path
    问题记录_IDEA启动报错:FailedtocreateJVM.JVMPath  起因下午写代码的时候感觉IDEA有点卡,不应该啊,我16G咋回卡呢,分配的内存也不小,于是又去加大内存分配,结果IDE......