首页 > 其他分享 >jvm调优

jvm调优

时间:2023-01-12 16:37:18浏览次数:30  
标签:jvm XX 调优 内存 JVM 大小

jps 

jstat -gc java_pid 

 

 

jstat命令

jstat命令可以查看到很多的jvm信息,详细内容可以自行百度,本篇只介绍我们经常使用的命令。

jstat -gc PID 1000 10

一般最常用的命令就是这个了,它的意思是每1秒打印一次jvm的内存信息,打印10次。

通过此命令可以分析出新生代对象的增长速度,Young GC的触发频率和耗时、老年代的增长速度、Full GC的触发频率和耗时。

分析之后进行合理的jvm参数设置进行调优工作。

里面的各个参数解释如下:

  • S0C:第一个幸存区的大小
  • S1C:第二个幸存区的大小
  • S0U:第一个幸存区的使用大小
  • S1U:第二个幸存区的使用大小
  • EC:伊甸园区的大小
  • EU:伊甸园区的使用大小
  • OC:老年代大小
  • OU:老年代使用大小
  • MC:方法区大小
  • MU:方法区使用大小
  • CCSC:压缩类空间大小
  • CCSU:压缩类空间使用大小
  • YGC:年轻代垃圾回收次数
  • YGCT:年轻代垃圾回收消耗时间
  • FGC:老年代垃圾回收次数
  • FGCT:老年代垃圾回收消耗时间
  • GCT:垃圾回收消耗总时间

PID可以通过jps命令获得,jps就是一个查看java进程的命令,没什么可说的,不清楚的小伙伴百度了解下即可。

jmap和jhat命令

jmap -dump:live,format=b,file=dump.hprof PID

生成内存快照,以供分析内存占用情况。

jhat dump.hprof

分析内存快照,内置了web容器,可以通过浏览器分析堆内存快照。

MAT工具

功能比较强大的内存分析工具,可以替代jhat。

需要注意的一点是,线上导出来的dump如果很大的话,比如有几个GB,使用MAT之前需要修改MemoryAnalyzer.ini文件,修改堆内存的大小足够容纳你的dump文件

常用的监控系统

一般我们可以配置一套自动化监控系统,如果发现JVM出现异常,可以报警,比如发送短信或邮件给负责人。

常用的有Zabbix,Ganglla,Open-Falcon,Prometheus。

如果想要引入一套监控系统,可以自行了解以上监控系统,在其中选择一个。

一套JVM调优的参数模板

以下是王子在jvm调优工作中总结的常用调优参数,在这里分享给小伙伴们,一般合理的配置以下参数就可以获得一个比较好的性能

-Xms2048m 初始堆大小
-Xmx2048m 最大堆大小
-Xmn1024m 年轻代大小
-XX:PermSize=256m 设置持久代(perm gen)初始值(JDK8以后弃用改为-XX:MetaspaceSize)
-XX:MaxPermSize=256m 设置持久代最大值(JDK8以后弃用改为-XX:MaxMetaspaceSize)
-Xss1m 每个线程的堆栈大小(等价于-XX:ThreadStackSize)
-XX:SurvivorRatio Eden区与Survivor区的大小比值(默认为8)
-XX:+DisableExplicitGC 关闭System.gc(),如果系统中使用了nio调用堆外内存,慎用此参数
-XX:MaxTenuringThreshold=15 年轻代垃圾回收最大年龄,默认15,15次后进入老年代
-XX:PretenureSizeThreshold 对象超过多大直接在老年代分配
-XX:+UseParNewGC 使用ParNewGC垃圾回收器
-XX:+UseConcMarkSweepGC 使用CMS内存收集
-XX:CMSInitiatingOccupancyFraction=92 CMS垃圾收集器,当老年代达到92%时,触发CMS垃圾回收
-XX:CMSFullGCsBeforeCompaction=0 多少次后进行内存压缩,默认0

-XX:+CMSScavengeBeforeRemark

CMS重新标记之前尽量进行一次Young GC
-XX:+UseCMSCompactAtFullCollection 在FULL GC的时候, 对老年代的压缩,默认打开
-XX:+CMSParallelInitialMarkEnabled CMS初始标记并行化,增加初始标记速度
-Xverify:no 禁止字节码校验,提高编译速度(jdk13之后作废,生产环境不使用)
-XX:+UseG1GC 使用G1垃圾回收器
-XX:MaxGCPauseMillis=200 目标GC暂停时间,尽可能目标

-XX:+PrintGCTimeStamps
-XX:+PrintGCDetails
-Xloggc:d:idea_gc.log

合并使用,打印GC信息到指定文件

-XX:+HeapDumpOnOutOfMemoryError

表示当JVM发生OOM时,自动生成DUMP文件

-XX:HeapDumpPath=${目录}

表示生成DUMP文件的路径,也可以指定文件名称,例如:-XX:HeapDumpPath=${目录}/java_heapdump.hprof。如果不指定文件名,默认为:java_<pid>_<date>_<time>_heapDump.hprof

总结

到这里本篇文章就结束了,关于JVM部分的文章可能暂时也结束了,下边的话是一些经验之谈。

如何具体的做好JVM调优不是简简单单的一篇文章就能说得清的,不要相信什么网上的万能jvm调优模板,王子提供的模板也只是常用的一些调优参数,一切的调优都需要通过分析实际生产环境情况后,才能做出最适合生产环境的调优方案,真正能证明你价值的地方就在于你的分析并处理问题的能力,而不是说你懂了JVM的原理就可以了,JVM原理只是基础,能把它实际运用才能称它为价值!

标签:jvm,XX,调优,内存,JVM,大小
From: https://www.cnblogs.com/ruiy/p/17047007.html

相关文章

  • 企业应用架构研究系列二十四:SQL Server 数据库调优之XEvent 探查器
    如果入职一些中小型公司,往往需要接手一些很“坑”的项目,到底多坑就不牢骚了,只讲一下,如果破解这些历史遗留的项目问题。项目代码可能短时间无法进行通读研究,我们就需要......
  • jmeter-性能调优
    前提:    1、当CPU、内存和硬盘的使用率非常低,就要从软件找原因;    2、当CPU和硬盘的使用率低,内存的使用率非常高,就要从软件是否存在内存泄漏找原因; ......
  • centos获取系统信息以及系统调优的shell脚本
    #!/bin/bash#2022-08-31#已在在centos7系统下完成测试,获取系统信息和参数调优#Madmaninfo(){echo"+--------------------------------------------------------......
  • 一次JVM GC长暂停的排查过程
    作者:京东科技徐传乐背景在高并发下,Java程序的GC问题属于很典型的一类问题,带来的影响往往会被进一步放大。不管是「GC频率过快」还是「GC耗时太长」,由于GC期间都存在StopTh......
  • JVM 调整和优化
    1.window系统需要到jdk安装目录下,到bin下面:执行相关命令    2. 相关指令 1) jmap-->java内存映射工具jmap命令用于生产堆转存快照。打印出某个java进......
  • 记一次kafka重复消费连带出的JVM问题
    背景:指标对齐服务(CPU密集型)原本指标对齐服务的请求较小,响应速度不会超过1s,采用http同步处理可以解决。但最近接入的业务中有大文件业务,响应时间指数上升,但nginx的超时时间......
  • 【转】nginx调优之使用return代替rewrite做重定向
    使用return代替rewrite做重定向转自:https://www.jianshu.com/p/26dc6c2b5f43原文地址:https://github.com/trimstray/nginx-admins-handbook/blob/master/doc/RULES.md#be......
  • JDK JRE JVM
    JDKJREJVMJDK:JavaDevelopmentKit(包括JRE)JRE:JavaRuntimeenvironmentJVM:JavaVirtualmachine(跨平台)......
  • jvm内存模型
         老年代2/3堆   new新对象      新年代 1/3eden8/10surviors01/10s11/10栈   先进后出线程运行就会分配一个......
  • 第2题- JDK&JRE&JVM
    文章目录​​JDK&JRE&JVM​​​​JDK​​​​JRE​​​​JVM​​​​关系​​JDK&JRE&JVMJDKJavaDevelopmentKit,Java开发工具包。JREJavaRuntimeEnvironment,Jav......