java GC

JVM GC 对象引用树

编写一个Java应用,在while(true)循环中每隔5秒new一个长度为1024的byte数组。

  1. 用jstat gcutil观察java进程执行时各代的变化情况(答案中贴出过程图片)。
  2. 用jmap导出java进程的heap,并用jhat观察内存占用排序(用web访问jhat服务,贴出排序图)。
  3. 分别使用parallelOldGC及CMS执行程序,打印gc log。(贴出两种不同的GC log)。

(1)

public class HelloWorld {
public static void main(String args[]) throws Exception{
int i=0;
while(true){
i++;
Thread.sleep(5000);
byte tem[]=new byte[1024];
System.out.println(“Hello World :”+i);
}
}

}
“`
这里写图片描述

(2)
1、使用ps -aux| grep xxx 获取要分析的java进程
2、jmap -dump:live,format=b,file=jmap.dat xxx(进程ID号)
用jmap得到进程的运行时内存镜像
3、jhat -J-Xmx1g jamp.dat
用jhat进行内存分析,指定jhat使用的内存为1g
4、jhat启动后会建立一个http server 端口为7000,之后可以通过

这里写图片描述

(3) 配置ParallelGC :
-XX:+UseParallelOldGC
配置CMS:
-XX:+UseConcMarkSweepGC
打印GC日志:
-verbose:gc -XX:+PrintGCTimeStamps -XX:+PrintGCDetails -Xloggc: GC.log

Java -verbose:gc 中参数-verbose:gc 表示输出虚拟机中GC的详细情况
-verbose:gc 等同于-XX:+PrintGC,都是打印GC的简要信息。

使用UseParallelOldGC的情况:
这里写图片描述
使用 UseConcMarkSweepGC的情况:
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值