当前位置:网站首页>JVM Notes

JVM Notes

2022-08-04 04:05:00 wuhui2100

一、JVM笔记

1、根可达算法(javaAn object marked for recycling),Generally, it starts from four root nodes(线程栈变量、静态变量、常量池、JNI指针)

在这里插入图片描述

2、GC回收三种算法(According to the neutralization and application of these three algorithms, it forms its own uniqueGC)

在这里插入图片描述

​ 1)、Mark-Sweep:标记清除

​ Delete the marked memory、Whether the corresponding memory address;resulting in the formation of fragmented spaces,So that the allocation fails when a large space object is required

在这里插入图片描述

​ 2)、Copying:拷贝

​ Allocate several large spaces,According to the root reachable algorithm, find the available data and put it into another large space,Delete the corresponding large space to be reclaimed again

​ 缺点:浪费空间

在这里插入图片描述

​ 3)、Mark-Compact:标记压缩

​ When recycling, the available ones are reordered by the way

​ 缺点:效率低,比copy还低

在这里插入图片描述

3、堆内存逻辑分区

Java1.8The default is to divide the memory into two generations,Recycling generally uses the tape recycling mechanism;It is divided into new generation and old generation

新生代使用copying(拷贝算法),老年代使用Mark Compact(标记压缩算法)

The ratio of the new generation to the old generation in memory is 1:3,而新生代中eden与survivor比例是8:1:1

​ 1)、新生代使用copying(拷贝算法)

​ The first garbage collection of the young generation(major gc)Will Eden area(eden)The surviving data is copied to the surviving area(survivor-0)之后将edenZone deletion and recycling;

​ The second will be Eden(eden)Objects surviving in (survivor-0)幸存区0All objects are copied to the survivor area1(survivor-1)中 将对应的eden与survivor-0都回收;

​ The third timesurvivor-1拷贝回survivor-0中,回收eden与survivor-0区;

​ 循环上面三个步骤;When the surviving object reaches the collection count threshold, the corresponding object is moved to the old generation

​ 2)、老年代使用Mark Compact(标记压缩算法)或者Mark Sweep(标记清除算法)结合使用

​ Triggered when the old generation reaches the set thresholdfull gc

在这里插入图片描述

4、General diagram of the garbage collector

The garbage collector evolves as memory continues to grow

在这里插入图片描述

1)、serial The garbage collector is a few megabytes to tens of megabytes in memory,单线程的垃圾收集器(The process executed during recycling needs to be stopped and needs to wait for the recycling to complete,to use the program again)

​ 即年轻代使用serial,老年代使用serial old垃圾收集器回收

2)、 Parallel ScavengeThe garbage collector is a few hundred megabytes to several megabytes of memoryG时,多线程垃圾收集器(The process executed during recycling needs to be stopped and needs to wait for the recycling to complete,to use the program again),Java1.8默认使用PS+PO的垃圾收集器组合

​ 即年轻代使用Parallel Scavenge,老年代使用Parallel Old垃圾回收器

3)、CMS垃圾收集器,When the memory is dozensG时(Multithreading is not always better),引入CMS垃圾回收,That is, multiple worker threads work concurrently with multiple garbage collection threads

在这里插入图片描述

​ The simultaneous operation of the worker thread and the garbage collection thread may lead to misunderstanding that an object can be garbage collected,It needs a three-color marking algorithm to solve:

黑色标记:Satisfy yourself already marked、Objects that have already pointed to themselves are also marked(孩子)则为黑色

灰色标记:Mark it yourself done,Objects that have not yet been marked are marked in gray

白色标记:还没有遍历到的节点

在这里插入图片描述

当上图B->D,没有扫描到,业务逻辑实现A->D产生了,则会将Das garbage,CMS解决方案就是将A标记为灰色,Still missing the mark(不建议使用CMS

在这里插入图片描述

4)、Epsilon在jvmNo garbage disposal is done,用于开发jvmpersonnel transferbug,And when it's big and not neededgcobject can be used to mark,Prevent other garbage collectors from operating on it
5)、G1垃圾收集器,Partitioning algorithm reclaims part of the area,All young generations will be reclaimed when reclaimed,When the new generation is largeSTW很长

​ Mainly for the partition algorithm,Concurrent collection will be partially recycled,压缩空闲空间不会延长GC的暂停时间,更容易预测GC暂停时间,Use for scenarios that do not require high throughput;G1Mainly physical generation(a small area),logical zoning

在这里插入图片描述

6)、ZGC垃圾回收器

​ Use paging algorithm(go lang回收算法),ZGCThe core algorithm of 颜色指针,Also partition,However, the new generation and the old generation are no longer partitioned,

在这里插入图片描述

​ 7)、Shenandoah,Red Hat provides an open source garbage collector

5、Java命令进行定位

1)、jsp 列出Java中所有进程
2)、jinfo + 进程号 List related properties under the current process
3)、jstat Javadata tracking information

​ jstat -gc(参数) + 进程号 : 跟踪gc的一些信息

​ jstat -gc(参数) + 进程号 + Refresh milliseconds :跟踪gcThe number of milliseconds in which some information is refreshed

4)、jstack + 线程 View the call stack information of all threads under the current process

​ 当存在cpuCan be used when memory soars:

​ top :See which process is usingcpu很高

​ top -hp + 进程号 : Check out which thread to usecpu很高

​ 最后使用jstack Check the corresponding stack information to see which method has a problem

5)、jmap There are two major functions to check the occupancy of the object in the heap memory(The proportion of memory occupied by objects of different classes),Generate a heap dump file(怀疑jvm内存有bugThis memory can be exported for analysis)

​ jmap histo + 进程号 :Generate an object graph

​ jmap histo + 进程号 | head 20 : Generates the largest front in the object graph20The proportion of each class object

使用jmap有一个严重的问题:When dumping the heap to a file,will be stuck,Run until the dump is successful(Not recommended for production environments 用)

6)、使用arthas(阿尔萨斯)工具

​ arthas阿里开源的jvm诊断工具,Covers the above command,主要有:

​ 1、dashboard : 仪表盘,Check which thread occupies more support

​ 2、head dump: 堆转储文件

​ 3、thread :List except all threads,看那个cpuEat more threads

​ thread -d : 查看是否存在死锁

​ 4、jvm : 列出java中设置的jvm参数,and which garbage collectors are used

​ 5、jad : 反编译java代码

​ 6、redefine : 在线修改class

​ 7、trace :Stand-alone link tracking,Distributed link tracing is used(zipkin)

原网站

版权声明
本文为[wuhui2100]所创,转载请带上原文链接,感谢
https://yzsam.com/2022/216/202208040354514984.html