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.调整堆内存大小

相关推荐
源分享3 天前
Java线程同步的多种实现方法(非常详细)
java·开发语言·jvm
JAVA9653 天前
JAVA面试-JVM篇 03-JVM运行时数据区哪些是线程私有的哪些是共享的
java·jvm·面试
伶俜664 天前
鸿蒙原生应用实战(十八)ArkUI 记账本:SQLite 账单 + 图表统计 + 分类管理
jvm·sqlite·harmonyos
IronMurphy4 天前
多线程问!
java·jvm·spring
unique4 天前
AI Coding 采集方案探索
jvm·人工智能·oracle
cfm_29144 天前
JVM GC日志解析
jvm
不良使4 天前
鸿蒙PC迁移:使用Electron`logseq-master-ohos` 鸿蒙适配全记录
jvm·electron·harmonyos
cfm_29144 天前
JVM深度详解:Class常量池、运行时常量池、字符串常量池、包装类对象池
java·jvm
JAVA9655 天前
JAVA面试-JVM篇 02-G1垃圾收集器的工作原理是什么与CMS的区别
java·jvm·面试