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

相关推荐
qq_189807033 分钟前
mysql如何查看所有数据库用户_mysql用户查询管理命令
jvm·数据库·python
m0_640309308 分钟前
Redis怎样优化客户端拉取拓扑的频率_在客户端层面捕获MOVED异常时才触发全局路由表刷新
jvm·数据库·python
214396512 分钟前
如何利用RMAN修复逻辑坏块_VALIDATE CHECK LOGICAL验证块内结构损坏
jvm·数据库·python
qq_2069013913 分钟前
如何使用 AWS Lambda 和 Python 获取 EMR 集群的标签列表
jvm·数据库·python
2301_7775993715 分钟前
JavaScript中利用类语法模拟实现单例模式的方案
jvm·数据库·python
qq_3422958216 分钟前
Bootstrap制作后台管理系统布局 Bootstrap如何搭建Dashboard框架
jvm·数据库·python
m0_6403093016 分钟前
SQL报表容灾与备份设计_灾备恢复策略
jvm·数据库·python
a95114164220 分钟前
golang如何设计分布式ID生成系统_golang分布式ID生成系统设计指南
jvm·数据库·python
2301_7826591820 分钟前
Go 中高效过滤结构体切片:基于用户名映射去重的最优实践
jvm·数据库·python
2301_8135995520 分钟前
Golang怎么处理HTTP响应_Golang HTTP响应处理教程【对比】
jvm·数据库·python