zoukankan      html  css  js  c++  java
  • JVM的一些工具的简要使用

    JConsole(可视化工具)

    运行

    JConsole内存监控

    测试代码

    import java.util.ArrayList;
    import java.util.List;
    
    public class A {
    	byte[] b1 = new byte[128*1024];
    	public static void main(String[] args) {
    		try {
    			Thread.sleep(5000);
    		}catch(Exception e) {
    			
    		}
    		System.out.println("start...");
    		fill(1000);
    	}
    	private static void fill(int n) {
    		List<A> jlist = new ArrayList<A>();
    		for(int i=0;i<n;i++) {
    			try {
    				Thread.sleep(100);
    			}catch(Exception e) {
    				jlist.add(new A());
    			}
    		}
    	}
    }
    

    然后开启jconsole进行连接。

    连接后执行一次GC后会发现Eden区域直降一次。

    JConsole线程监控。

    测试代码:

    import java.util.Scanner;
    
    public class A {
    	byte[] b1 = new byte[128*1024];
    	public static void main(String[] args) {
    		Scanner sc = new Scanner(System.in);
    		sc.next();
    		new Thread(()->{
    			while(true) {
    				
    			}
    		},"while true线程").start();	
    		new Thread(()->{
    			synchronized(A.class) {
    				try {
    					Thread.sleep(60000000);
    				}catch(InterruptedException e) {
    					e.printStackTrace();
    				}	
    			}
    		},"wait 线程").start();
    		
    	}
    }
    

    这里看到我们有俩个线程。

    JPS(JVM Process status)

    JPS是使用的频率最高的工具,和linux下的ps命令差不多(把J去掉就是一个ps)。

    因为我这里开启了一个eclipse,所以运行结果如下所示:

    如果打开任务管理器,就会发现这里的11612就是我们的pid

    因此JPS能够查看:本地虚拟机唯一ID(lvmid local virtual machine id)

    测试代码:

    import java.util.Scanner;
    
    public class A {
    	public static void main(String[] args) {
    		Scanner sc = new Scanner(System.in);
    		sc.next();
    	}
    }
    

    使用jps -l 查看主类

    jps -l
    

    使用jps -m 查看运行时的参数

    jps -m
    

    使用jps -v 查看虚拟机参数

    jps -v
    

    (上次写的程序还留着参数,所以看起来会有很多)

    使用mlv就能查看所有参数。

    jps -mlv
    

    Jstat(JVM state)

    能看到类加载,内存,垃圾收集。

    jstat -gcutil
    

    能查指定id的GC

    看这个就已经蒙蔽了,所以我们来看一下官方文档。

    链接在这

    看完之后翻译一下:

    参数 作用
    S0 Survivor空间0的利用率占当前容量的百分比
    S1 Survivor空间1的利用率占当前容量的百分比
    E Eden区域。。。
    O 老年代

    等等

    jstat -gcutil 8082 1000
    

    每隔1000ms导出一次gc

    元空间:本质和永久代类似,都是对JVM规范中方法区的实现。不过元空间与永久代的最大区别在于:元空间并不在虚拟机中,而是使用本地内存。因此,默认情况下,元空间的大小仅受本地内存限制。

    jinfo

    实时查看和调整虚拟机的各种参数。

    jinfo -flag UseG1GC 8082
    

    我们可以看到eclipse使用的就是G1收集器。

    还可以动态的去修改JVM参数设置。

    jmap

    将jvm堆内存dump下来

    jmap -dump:format=b,file=C:UsersGodofOrangeDesktopa.bin 8082
    

    显示堆中的统计信息。

    jmap -histo 8028 > a.txt
    

    jstack

    打印线程信息

    jstack -F 8028
    

    打印栈信息

    jstack -m 8028
    

  • 相关阅读:
    使用手机重量加速器
    改变 Pivot 的 HeaderTemplate
    页面构造函数和 Load 事件的执行次数
    给 ListBox 的 DataTemplate 模板中的 元素设置动画
    在ItemsControl 中,添加头部下拉更新
    (转) Unix 时间戳 与 .NET 时间转换
    图片保存到本机(链接)
    IsHitTestVisible="False" 的功能
    回到顶部按钮
    ssh访问服务器端visdom
  • 原文地址:https://www.cnblogs.com/godoforange/p/11569594.html
Copyright © 2011-2022 走看看