
JVM性能调优实践
文章平均质量分 93
一网打尽常用JVM参数,性能优化方案
BUG指挥官
天下一亩三
展开
-
什么情况会发生Full GC?如何避免频繁Full GC?
Full GC(Full Garbage Collection)是Java虚拟机中进行垃圾回收的一种操作,它的目标是清理整个Java堆内存,包括年轻代(Young Generation)、年老代(Old Generation或Tenured Generation)、以及永久代(在Java 8及之前的版本中,而在Java 8及之后的版本中由Metaspace取代,所以这里可以理解为元空间Metaspace)。原创 2024-02-23 11:35:15 · 1856 阅读 · 0 评论 -
虚拟机的内存结构
熟悉 Java 语言特性的同学都知道,相比 C、C++ 等编程语言,Java 无需通过手动方式回收内存,内存中所有的对象都可以交给 Java 虚拟机来帮助自动回收;而像 C、C++ 等编程语言,需要开发者通过代码手动释放内存资源,否则会导致内存溢出。尽管如此,如果编程不当,Java 应用程序也可能会出现内存溢出的现象,例如下面这个异常!它表示当前服务已出现内存溢出,简单的说就是当服务出现了内存不足时,就会抛异常。这种异常是怎么出现的呢?该如何解决呢?原创 2024-02-21 16:29:37 · 235 阅读 · 0 评论 -
FullGC 40 次/天优化为 10 天 1 次
就在我还在调查入口流量的问题时,另外一个同事找到了根本的原因,原来是在某个条件下,会查询表中所有未处理的指定数据,但是由于查询的时候 where 条件中少加了模块这个条件,导致查询出的数量达 40 多万条,而且通过 log 查看当时的请求和数据,可以判断这个逻辑确实是已经执行了的,dump 出的内存中只有 4W 多个对象,这个是因为 dump 时候刚好查询出了这么多个,剩下的还在传输中导致的。在优化的过程中,我们的主管发现了有个对象 T 在内存中有一万多个实例,而且这些实例占据了将近 20M 的内存。原创 2023-09-06 10:25:08 · 126 阅读 · 0 评论 -
JVM参数的分类及常用参数
查看其他更多JVM相关参数可以参考官方文档:本篇文章介绍常用JVM参数,主要有GC日志、运行时数据区(栈、堆、元空间、直接内存)、OOM、垃圾收集器相关的参数,有效理解参数可以更好的进行JVM调优。原创 2023-03-17 10:32:08 · 756 阅读 · 0 评论