Java的jvm你应该知道的(jvm有什么)

createh51个月前 (02-01)技术教程25

JVM中类的装载是由类加载器(ClassLoader)和它的子类来实现的,Java中的类加载器是一个重要的Java运行时系统组件,它负责在运行时查找和装入类文件中的类。 由于Java的跨平台性,经过编译的Java源程序并不是一个可执行程序,而是一个或多个类文件。当Java程序需要使用某个类时,JVM会确保这个类已经被加载、连接(验证、准备和解析)和初始化。类的加载是指把类的.class文件中的数据读入到内存中,通常是创建一个字节数组读入.class文件,然后产生与所加载类对应的Class对象。加载完成后,Class对象还不完整,所以此时的类还不可用。当类被加载后就进入连接阶段,这一阶段包括验证、准备(为静态变量分配内存并设置默认的初始值)和解析(将符号引用替换为直接引用)三个步骤。最后JVM对类进行初始化,包括:1)如果类存在直接的父类并且这个类还没有被初始化,那么就先初始化父类;2)如果类中存在初始化语句,就依次执行这些初始化语句。 类的加载是由类加载器完成的,类加载器包括:根加载器(BootStrap)、扩展加载器(Extension)、系统加载器(System)和用户自定义类加载器(java.lang.ClassLoader的子类)。从Java 2(JDK 1.2)开始,类加载过程采取了父亲委托机制(PDM)。PDM更好的保证了Java平台的安全性,在该机制中,JVM自带的Bootstrap是根加载器,其他的加载器都有且仅有一个父类加载器。类的加载首先请求父类加载器加载,父类加载器无能为力时才由其子类加载器自行加载。JVM不会向Java程序提供对Bootstrap的引用。下面是关于几个类加载器的说明:

Bootstrap:一般用本地代码实现,负责加载JVM基础核心类库(rt.jar);

Extension:从java.ext.dirs系统属性所指定的目录中加载类库,它的父加载器是Bootstrap;

System:又叫应用类加载器,其父类是Extension。它是应用最广泛的类加载器。它从环境变

量classpath或者系统属性java.class.path所指定的目录中记载类,是用户自定义加载器的默认

父加载器。


造成 OutOfMemoryError 内存泄露典型原因:对象已经死了,无法通过垃圾收集器进行自动回收,需要通过找出泄露的代码位置和原因,才好确定解决方案。

分析步骤:

1. 用工具生成 java 应用程序的 heap dump(如 jmap)

2. 使用 Java heap 分析工具(如 MAT),找出内存占用超出预期的嫌疑对象

3. 根据情况,分析嫌疑对象和其他对象的引用关系。

4. 分析程序的源代码,找出嫌疑对象数量过多的原因。

2)支配树(Dominator Tree)

MAT 提供了一个称为支配树(Dominator Tree)的对象图。支配树体现了对象实例间的支配关系,在此视图中列出了每个对象(Object Instance)与其引用关系的树状结构,同时包含了占用内存的大小和百分比。

通过 Dominator Tree 视图可以很容易的找出占用内存最多的几个对象(根据Retained Heap 或 Percentage 排序),和 Histogram 类似,可以通过不同的方式进行分组显示。

Histogram 视图和 Dominator Tree 视图的角度不同,前者是基于类的角度,后

者是基于对象实例的角度,并且可以更方便的看出其引用关系。

以上只是一个初步的介绍,mat 还有更强大的使用,比如对比堆内存,在生产环

境中往往为了定位问题,每隔几分钟 dump 出一下内存快照,随后在对比不同时

间的堆内存的变化来发现问题。



1.JDK 本身提供了很丰富的性能监控工具,除了集成式的 visualVM 和 jConsole 外,还有jstat,jstack,jps,jmap,jhat 小工具,这些都是性能调优的常用工具。

. Jconsole : jdk 自带,功能简单,但是可以在系统有一定负荷的情况下使用。对垃圾回收算法有很详细的跟踪。

. JProfiler:商业软件,功能强大。

. VisualVM:JDK 自带,功能强大,与 JProfiler 类似。

. MAT:MAT(Memory Analyzer Tool),一个基于 Eclipse 的内存分析工具。

2.VisualVM 是 javajdk 自带的牛逼的调优工具,也是平时使用最多调优工具,几乎涉及了 jvm 调优的方方面面。启动起来后和 jconsole 一样同样可以选择本地和远程,如果需要监控远程同样需要配置相关参数。

VisualVM 可以根据需要安装不同的插件,每个插件的关注点都不同,有的主要监控 GC,有的主要监控内存,有的监控线程等。

3.JConsole 是一个 JMX(JavaManagementExtensions,即 Java 管理扩展)的 JVM 监控与管理工具,监控主要体现在:堆栈内存、线程、CPU、类、VM 信息这几个方面,而管理主要是对 JMXMBean(managed beans,被管理的 beans,是一系列资源,包含对象、接口、设备等)的管理,不仅能查看 bean 的属性和方法信息,还能够在运行时修改属性或调用方法。

4.MAT(Memory Analyzer Tool),一个基于 Eclipse 的内存分析工具,是一个快速、功能丰富的 Java heap 分析工具,它可以帮助我们查找内存泄漏和减少内存消耗。

可以利用 visualvm 或者是 jmap 命令生产堆文件在进行内存分析。

相关文章

阿里P9级架构师马士兵花四小时让你搞懂JVM底层原理(附JVMpdf)

JVM面试难题当面试官向你提问JVM的实战问题时,你是否感觉到无所适从?想解决生产环境中的GC问题,你是否感觉到狗咬刺猬,无处下嘴?面对JVM的海量参数,你是否感觉到迷茫无助?看过很多的JVM文章,但...

Java虚拟机(jvm)-简介(深入浅出:java虚拟机设计与实现)

一、Java运行时虚拟机内存区域划分1.元空间(Metaspace)元空间(Metaspace)从java8开始替换掉了原来的方法区(Method Area)。相比方法区(Method Area)在元...

教你用Java开发一个简单的JVM(java开发实例教程)

一、前言几年前,接到一个开发任务:用Java开发能运行Java智能合约的虚拟机。在开发Java智能合约时,只能使用智能合约SDK提供的类和一些Java常用类(8种基本数据类型包装类;String、Bi...

Java面试篇基础部分-JVM详细介绍(java面试必备 基础知识篇)

JVM的运行机制JVM(Java Virtual Machine)是用于运行Java字节码的虚拟计算机,其中包括一套字节码的指令集、程序寄存器、虚拟机栈、虚拟机堆、本地方法区、垃圾回收器。JVM运行在...

JAVA面试题每日一练:描述一下JVM加载class文件的原理机制?

Java是一门高度平台独立的编程语言,但在这个跨平台的特性背后,Java虚拟机(JVM)却承担了一个至关重要的任务:类加载。类加载不仅是Java程序执行的前提,它还是保证Java平台安全性和可扩展性的...

读完这份JVM高级笔记,彻底玩转Java虚拟机,面试再也不用“虚”

提到Java虚拟机(JVM),可能大部分人的第一印象是“难”,但当让我们真正走入“JVM世界”的时候,会发现其实问题并不像我们想象中的那么复杂。唯一真正令我们恐惧的,其实是恐惧本身。JVM 一直都是面...