【面试题总结】JVM02:JVM参数调优、类加载机制
四、JVM参数调优
1、调优工具
(1)jvisualvm:jdk提供的性能分析工具,可以监控java进程,对dump文件分析;查看应用程序的详细信息,针对不同插件,实现监控GC过程、内存、进程、线程等,也可以实现对Tomcat的监控
(2)Jps(Process Status):查看Java进程
(3)Jstat:使用命令行的方式监控Java应用程序的资源和性能,加参数gc/compile/class/gccapacity/gcnew/gcoldcapacity/printcompilation查看各种信息
(4)jmap:内存映像工具,可以生成dump堆转储快照,也可加参数“-XX:+HeapDumpOnOutOfMemoryError”在OOM时自动生成dump文件
(5)jhat:将dump出来的hprof文件转成html的形式,加参数在OOM时自动生成文件到指定路径
(6)jstack:查看线程的调用堆栈
(7)jinfo:查看正在运行的 java 应用程序的扩展参数
2、利用工具调优
(1)查看堆信息
- 查看不同代空间分配,从而看不同代划分是否合理
- 查看对象引用情况,以避免内存泄漏
- 查看垃圾回收过程,查看垃圾回收算法设置是否合理
- 查看堆内存和对象信息
(2)线程监控
- 监控线程数量、状态
- 使用dump查看线程内部运行情况
- 避免产生死锁
(3)热点分析
- CPU 热点:查看哪些方法占用CPU
- 内存热点:查看占用空间大的对象
(4)快照查看
- 对比两次快照的对象情况,避免浮动垃圾或遗漏对象等现象
(5)检查内存泄漏
- 避免系统资源(堆、栈、进程等)错误使用
3、调优参数
(1)分类
-开头的标准参数:数据模型选择、类搜索路径
-X开头的非标准参数:设置堆栈大小
-XX开头的不安全参数:堆和垃圾回收器设置
(2)堆设置
初始堆(-Xms)、最大堆(-Xmx)、永久代大小(-XX:MaxPermSize)
年轻代(-XX:NewSize=n)、新老代比值(-XX:NewRatio=n)
(3)回收器设置
设置串行(-XX:+UseSerialGC)、并行(-XX:+UseParallelGC)、并发收集器(-XX:+ UseConcMarkSweepGC)
(4)并行收集器设置
使用CPU数(-XX:ParallelGCThreads=n)、并行搜集暂停时间、垃圾回收时间占比(-XX:GCTimeRatio=n)
(5)并发收集器
设置增量模式(-XX:+CMSIncrementalMode)、设置并行收集使用的CPU数
五、类加载机制
1、类文件结构

魔数:确定文件是否符合class文件规范
文件版本、常量池、文件类型(类/接口)
字段、属性、方法集合
2、类加载机制
类从被加载到虚拟机内存中开始,到卸载出内存为止,它的整个生命周期包括:加载、验证、准备、解析、初始化、使用、卸载7个阶段,验证、准备、解析3个部分统称为连接
(加载-连接-初始化)

3、类加载各阶段作用
加载:获取二进制字节流、转换到内存
验证:验证文件格式、元数据、字节码、符号引用
准备:为类变量分配内存并设置初始值
解析:常量池内的符号引用替换为直接引用
初始化:执行类构造器
4、常用类加载器
(1)启动类加载器(Bootstrap ClassLoader,NO1):是虚拟机的一部分,将lib目录的类库加载到虚拟机内存;如果编写自定义加载器,将启动类置为空;
(2)扩展类加载器(Extension ClassLoader,NO2):加载\lib\ext目录或系统变量指定的类库,开发者可以直接使用;
(3)应用程序类加载器 (Application ClassLoader,NO3):加载用户路径(ClassPath)所指定的类库,是默认的类加载器;
(4)(自定义)类加载器均继承ClassLoader类,调用(重写)loadClass()完成类加载,findClass()尝试从父类中记载。
5、类与类加载器的关系
由类加载器和类本身才能确定在JVM中的唯一性
比较两个类是否“相等”,只有在这两个类是由同一个类加载器加载的前提下才有意义
例如:如果被不同的累加器加载,即使是同一个class文件,两个类也不相等
6、双亲委派模型
(1)程序加载
三种类加载器相互配合进行加载,也可加入自定义类加载器

(2)双亲委派模型
尝试将请求委派给父类加载器
所有的加载请求都传送到顶层的启动类加载器中
当父类加载器反馈自己无法完成这个加载请求(它的搜索范围中没有找到所需的类)时,子加载器才会尝试自己去加载。
【面试题总结】JVM02:JVM参数调优、类加载机制的更多相关文章
- JVM参数调优
JVM参数调优 JVM参数调优是一个很头痛的问题,可能和应用有关系,下面是本人一些调优的实践经验,希望对读者能有帮助,环境LinuxAS4,resin2.1.17,JDK6.0,2CPU,4G内存,d ...
- (转)JVM参数调优八大技巧
这里和大家分享一下JVM参数调优的八条经验,JVM参数调优,这是很头痛的问题,设置的不好,JVM不断执行FullGC,导致整个系统变得很慢,网站停滞时间能达10秒以上,相信通过本文的学习你对JVM参数 ...
- SpringBoot-内部运行jvm参数调优
SpringBoot JVM参数调优 这个根据服务器的内存大小,来设置堆参数. -Xms :设置Java堆栈的初始化大小 -Xmx :设置最大的java堆大小 实例参数-XX:+PrintGCDeta ...
- 性能测试三十六:内存溢出和JVM常见参数及JVM参数调优
堆内存溢出: 此种溢出,加内存只能缓解问题,不能根除问题,需优化代码堆内存中存在大量对象,这些对象都有被引用,当所有对象占用空间达到堆内存的最大值,就会出现内存溢出OutOfMemory:Java h ...
- 【学习】011 JVM参数调优配置
自动内存管理机制 Java虚拟机原理 所谓虚拟机,就是一台虚拟的机器.他是一款软件,用来执行一系列虚拟计算指令,大体上虚拟机可以分为 系统虚拟机和程序虚拟机, 大名鼎鼎的Visual Box.Vmar ...
- JVM参数调优:Eclipse启动实践
本文主要参考自<深入理解 Java 虚拟机>.这本书是国人写的难得的不是照搬代码注释的且不是废话连篇的技术书,内容涵盖了 Java 从源码到字节码到执行的整个过程,包括了 JVM(Java ...
- JVM参数调优总结
一.前言 要想成为一名高级Java开发具备JVM调优的能力必不可少,能够根据项目实际情况进行JVM调优的前提是理解JVM原理和常用JVM参数的含义及作用,虽然<深入理解Java虚拟机>这本 ...
- Java后端进阶-JVM参数调优
package com.study.performance; import org.springframework.boot.SpringApplication; import org.springf ...
- jvm 参数调优
FROM: http://www.cnblogs.com/redcreen/archive/2011/05/04/2037057.html#CMSInitiatingOccupancyFraction ...
- SpringBoot-外部运行jvm参数调优
外部运行调优 java -server -Xms32m -Xmx32m -jar springboot_v2.jar
随机推荐
- 怎样编写正确、高效的 Dockerfile
基础镜像 FROM 基础镜像 基础镜像的选择非常关键: 如果关注的是镜像的安全和大小,那么一般会选择 Alpine: 如果关注的是应用的运行稳定性,那么可能会选择 Ubuntu.Debian.Cent ...
- 第一个Django应用 - 第二部分:Django数据库配置,模型和后台
汇总操作 注:polls为应用名 1.执行命令:python manage.py migrate,生成默认的数据库表等 2.修改应用的models.py文件,添加数据库表模型等 3.INSTALLED ...
- 最佳实践:4个黄金指标和USE方法
Prometheus鼓励用户监控所有的东西,首先是及时发现问题其次是要能够快速对问题进行定位. 4个黄金指标 4个黄金指标可以在服务级别帮助衡量终端用户体验.服务中断.业务影响等层面的问题. 主要关注 ...
- 安全强化Linux 服务器的七个步骤
这篇入门文章将向你介绍基本的 Linux 服务器安全知识.虽然主要针对 Debian/Ubuntu,但是你可以将此处介绍的所有内容应用于其他 Linux 发行版.我也鼓励你研究这份材料,并在适用的情况 ...
- 集合框架——LinkedList集合源码分析
目录 示例代码 底层代码 第1步(初始化集合) 第2步(往集合中添加一个元素) 第3步(往集合中添加第二个元素) 第4步(往集合中添加第三个元素) LinkedList添加元素流程示意图 第5步(删除 ...
- PAT520 钻石争霸赛 7-6 随机输一次
#include<bits/stdc++.h> using namespace std; typedef long long ll; const int maxn = 1000; ll n ...
- Windows Socket 接口简介
Windows Socket接口是Windows下网络编程的接口,在介绍Windows Socket接口之前,首先要简单介绍一下TCP/IP协议和描述网络系统架构的 OSI模型,以及TCP/IP模型 ...
- 2022.3.12 提高A组总结&反思
今天有点上头了 T1:开场秒,大水题,一眼莫队了,最后没打 T2:开场以为是费用流,后来发现费用流做不了,在做T3的时候突然发现可以状压,也没打 T3:这道题给我极大的亲切感,导致我一个上午硬钢这道题 ...
- 通过openlayers加载dwg格式的CAD图并与互联网地图叠加
Openlayers介绍 Openlayers是一个基于Javacript开发,免费.开源的前端地图开发库,使用它,可以很容易的开发出WebGIS系统.目前Openlayers支持地图瓦片.矢量数 ...
- JavaScript基本语法(数组与JSON)
5.数组 #①使用new关键字创建数组 // 1.创建数组对象 var arr01 = new Array(); // 2.压入数据 arr01.push("apple"); ar ...