JVM相关知识3

目录

一定要用双亲委派机制吗?

JDK中有哪些默认的类加载器?

虚拟机基础故障处理工具有哪些?

堆相关的JVM参数

GC性能指标是什么?调优原则是什么?

[如何降低Full GC的频率?](#如何降低Full GC的频率?)


一定要用双亲委派机制吗?

Java虚拟机规范并没有明确要求类加载器的加载机制一定要使用双亲委派模型,只是建议采用这种方式而已。

比如在Tomcat中,类加载器所采用的加载机制就和传统的双亲委派模型有一定区别,当缺省的类加载器接收到一个类的加载任务时,首先会由它自行加载,当它加载失败时,才会将类的加载任务委派给它的超类加载器去执行,这同时也是Servlet规范推荐的一种做法

JDK中有哪些默认的类加载器?

1.启动类加载器,Bootstrap ClassLoader

2.扩展类加载器,Extension ClassLoader

3.应用程序类加载器,AppClassLoader

虚拟机基础故障处理工具有哪些?

1.jConsole:用于对JVM中内存、线程和类等的监控,是一个基于JMX(java management extensions)的GUI性能监控工具。

2.Visual VM:是一个功能强大的多合一故障诊断和性能监控的可视化工具。

3.JProfiler:是由 ej-technologies 公司开发的一款 Java 应用性能诊断工具。功能强大,但是收费。

4.eclipse MAT:MAT(Memory Analyzer Tool)工具是一款功能强大的Java堆内存分析器。可以用于查找内存泄漏以及查看内存消耗情况。

堆相关的JVM参数

-Xms3550m:等价于-XX:InitialHeapSize,设置JVM初始堆内存为3550M

-Xmx3550m:等价于-XX:MaxHeapSize,设置JVM最大堆内存为3550M

-Xmn2g:设置年轻代大小为2G,官方推荐配置为整个堆大小的3/8

-XX:NewRatio=4:设置老年代与年轻代(包括1个Eden和2个Survivor区)的比值

-XX:+UseAdaptiveSizePolicy:自动选择各区大小比例

-XX:PretenureSizeThreadshold=1024:设置让大于此阈值的对象直接分配在老年代,单位为字 节,只对Serial、ParNew收集器有效

GC性能指标是什么?调优原则是什么?

1-停顿时间(或响应时间)

2-吞吐量

3-并发数

4-内存占用

原则:防止出现OOM,进行JVM规划和预调优,解决程序运行中各种OOM,减少Full GC出现的频率,解决运行慢、卡顿问题。

如何降低Full GC的频率?

1.减少进入老年代的对象数量

2.调整堆内存大小

相关推荐
_F_y1 天前
C++重点知识总结
java·jvm·c++
爱学习的阿磊1 天前
使用Fabric自动化你的部署流程
jvm·数据库·python
m0_550024631 天前
持续集成/持续部署(CI/CD) for Python
jvm·数据库·python
云姜.1 天前
线程和进程的关系
java·linux·jvm
heartbeat..1 天前
JVM 性能调优流程实战:从开发规范到生产应急排查
java·运维·jvm·性能优化·设计规范
玄同7651 天前
SQLite + LLM:大模型应用落地的轻量级数据存储方案
jvm·数据库·人工智能·python·语言模型·sqlite·知识图谱
团子的二进制世界1 天前
G1垃圾收集器是如何工作的?
java·jvm·算法
Max_uuc1 天前
【C++ 硬核】打破嵌入式 STL 禁忌:利用 std::pmr 在“栈”上运行 std::vector
开发语言·jvm·c++
Serene_Dream1 天前
JVM 并发 GC - 三色标记
jvm·面试
m0_561359672 天前
使用Python处理计算机图形学(PIL/Pillow)
jvm·数据库·python