java 跟踪 gc_Java GC机制及原理 项目实际遇到GC问题解决思路和经验总结

1.什么是GC及基础知识介绍

GC(Garbage Collection) 简称垃圾收集 垃圾回收

JVM运行时数据区:

654f227e65b2c747c4f2aa763166fd68.png

1.方法区存储类的信息(包括类的名称、方法信息、字段信息)、静态变量、常量以及编译器编译后的代码等

2.堆(heap)存储对象的信息,分为新生代(Eden,Survivor1,Survivor2)和老年代,永久代

3.程序计数器,存储的数据所占空间的大小不会随程序的执行而发生改变,因此,对于程序计数器是不会发生内存溢出现象(OutOfMemory)的

4.Java栈(stack)是Java方法执行的内存模型

5.本地方法栈则是为执行本地方法(Native Method)服务的

2. 垃圾回收策略

讲到垃圾回收,那么什么时候对象需要回收,如何去判断对象是存活还是死亡,我们采用引用计数法来判断对象是否存活,当一个对象被引用时,计数器值加1,当引用失效时减1.

强引用与弱引用的区别:

强引用:类似Object obj = new Object();只要强引用还存在,垃圾回收器不会收集被引用的对象

软引用:用来描述还有用但非必需的对象

通过可达性分析算法来判断对象是否需要被回收

垃圾回收策略有 标记清除法(会产生过多的内存碎片),复制法(内存使用率不高),标记整理法

垃圾收集器分类

Serial收集器:发展历史最悠久的收集器

ParNew收集器

Minor GC & Major GC & Full GC

从年轻代空间(包括 Eden 和 Survivor 区域)回收内存被称为 Minor GC

Major GC 是清理老年代内存

Minor GC是清理年轻代(Eden和Survivor区域)内存

Full GC 是清理整个堆空间—包括年轻代和永久代

CMS(Concurrent Mark Sweep)收集器:是一种以获取最短停顿时间为目标的垃圾收集器

3.GC问题常用命令介绍

jps(Java Virtual Machine Process Status Tool);//虚拟机进程状况工具

jstat;//虚拟机统计信息监视工具

jstat -gcutil 19473;//统计gc信息

jstat -gc 4588 250 20;//每250毫秒查询进程4588垃圾收集情况 一共查询20次

jstat -gcold 4588;//查看老年代gc存储量

jstat -gcnew 4588;//查看年轻代gc存储量

-gc:监视堆内存情况,包括eden区,s1,s2,老年代和永久代的内存容量

-gcnew:监视新生代GC情况

-gcold:监视老年代GC情况

jinfo;//Java配置信息工具

jmap;//java内存映像工具

使用jmap生成dump文件

jmap -dump:format=b,file=eclipse.bin 14949;//14949进程号

jhat;//虚拟机堆转储快照分析工具

jstack;//java堆栈跟踪工具

关于GC重要命令介绍

关于jps

jps是用于查询jvm进程信息的

主要参数有:

-q 不输出类名、Jar名和传入main方法的参数

-m 输出传入main方法的参数

-l 输出main类或Jar的全限名

-v 输出传入JVM的参数

比如输入

jps -m -l

会显示下面的信息

15089 org.apache.catalina.start

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值