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

相关推荐
DBWYX8 小时前
JVM 精华
jvm
jiedaodezhuti16 小时前
为什么elasticsearch配置文件JVM配置31G最佳
大数据·jvm·elasticsearch
进击的雷神16 小时前
数据库知识全面考查:从基础概念到实战应用
jvm·数据库·oracle
昔我往昔19 小时前
除了GC哪些地方有用到安全点
java·jvm·安全
胡子发芽20 小时前
面试题:请解释Java中的垃圾回收机制(Garbage Collection, GC),并讨论不同的垃圾回收算法及其优缺点
java·jvm
難釋懷1 天前
Android开发-在应用之间共享数据
android·jvm·oracle
陵易居士1 天前
JVM-类加载子系统
jvm·笔记·学习
开源架构师2 天前
JVM 与云原生的完美融合:引领技术潮流
jvm·微服务·云原生·性能优化·serverless·内存管理·容器化
意倾城2 天前
JVM内存模型
java·jvm
LUCIAZZZ2 天前
JVM之虚拟机运行
java·jvm·spring·操作系统·springboot