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:\Users\GodofOrange\Desktop\a.bin 8082
显示堆中的统计信息。
jmap -histo 8028 > a.txt
jstack
打印线程信息
jstack -F 8028
打印栈信息
jstack -m 8028
JVM的一些工具的简要使用的更多相关文章
- Capsule:开源的 JVM 应用部署工具
[编者按]本文作者 Ron Pressler 是 Parallel Universe 公司的创始人,拥有着丰富的高性能开发经验.通过这篇文章,Ron 向大家详细介绍了全新的开源 JVM 部署工具--C ...
- jvm系列(七):jvm调优-工具篇
16年的时候花了一些时间整理了一些关于jvm的介绍文章,到现在回顾起来还是一些还没有补充全面,其中就包括如何利用工具来监控调优前后的性能变化.工具做为图形化界面来展示更能直观的发现问题,另一方面一些耗 ...
- 《深入理解Java虚拟机》(五)JVM调优 - 工具
JVM调优 - 工具 JConsole:Java监视与管理控制台 JConsole是一个机遇JMX(Java Management Extensions,即Java管理扩展)的JVM监控与管理工具,监 ...
- Java虚拟机(六):JVM调优工具
工具做为图形化界面来展示更能直观的发现问题,另一方面一些耗费性能的分析(dump文件分析)一般也不会在生产直接分析,往往dump下来的文件达1G左右,人工分析效率较低,因此利用工具来分析jvm相关问题 ...
- JVM命令行工具&垃圾收集器&垃圾收集策略思维导图
1.JVM命令行工具 2.垃圾回收算法 3.垃圾收集器
- JVM调优-工具篇
原文地址 16年的时候花了一些时间整理了一些关于jvm的介绍文章,到现在回顾起来还是一些还没有补充全面,其中就包括如何利用工具来监控调优前后的性能变化.工具做为图形化界面来展示更能直观的发现问题,另一 ...
- JVM G1垃圾回收算法简要介绍
JVM G1垃圾回收算法简要介绍 G1的特点 能够像CMS垃圾回收算法一样并发操作应用线程(潜台词:多核) 无需太长时间即可压缩空闲内存空间(潜台词:不会引起太多的GC停顿时间) 尽可能地让GC时长可 ...
- UAVStack JVM监控分析工具:图形化展示采集及分析监控数据
摘要:UAVStack推出的JVM监控分析工具提供基于页面的展现方式,以图形化的方式展示采集到的监控数据:同时提供JVM基本参数获取.内存dump.线程分析.内存分配采样和热点方法分析等功能. 引言 ...
- java jvm常用命令工具
[尊重原创文章出自:http://www.chepoo.com/java-jvm-command-tools.html] 一.概述 程序运行中经常会遇到各种问题,定位问题时通常需要综合各种信息,如系统 ...
随机推荐
- 一文搞懂Python可迭代、迭代器和生成器的概念
关于我 一个有思想的程序猿,终身学习实践者,目前在一个创业团队任team lead,技术栈涉及Android.Python.Java和Go,这个也是我们团队的主要技术栈. Github:https:/ ...
- 谈谈JVM垃圾回收
概述 Java运行时区域中,程序计数器,虚拟机栈,本地方法栈三个区域随着线程的而生,随线程而死,这几个区域的内存分配和回收都具备确定性,不需要过多考虑回收问题.而Java堆和方法区则不一样,一个接口的 ...
- node.js 初学 自我笔记整理 day01
node.js 概念问题: Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境. npm是一个node的包管理工具 ,也是一个网站 ,还是一条命令.N ...
- C#开发BIMFACE系列4 服务端API之源上传文件
在注册成为BIMFACE的应用开发者后,要能在浏览器里浏览你的模型或者获取你模型内的BIM数据, 首先需要把你的模型文件上传到BIMFACE.根据不同场景,BIMFACE提供了丰富的文件相关的接口. ...
- Markdown写作入门
什么是Markdown格式 Markdown格式是一种可用普通文本编辑器编写的标记语言,使用者能够通过简单的标记语法,对自己所写文本内容进行简单的格式排版: 优点 语法简洁易学,且功能比纯文本强大: ...
- netcore 中的动态代理与RPC实现(微服务专题)
一.关于RPC的调用 1. 调用者(客户端Client)以本地调用的方式发起调用: 2. Client stub(客户端存根)收到调用后,负责将被调用的方法名.参数等打包编码成特定格式的能进行网络传输 ...
- 【转载】Windows api数据类型
最近在接触windows api函数,看到了很多之前没有看到过的数据类型,发现“个人图书馆”中有个帖子说的挺详细的,特地搬运过来 Windows 数据类型 Delphi 数据类型 描述 LPSTR P ...
- Badboy - 导出脚本,用于JMeter并发测试
参考: http://leafwf.blog.51cto.com/872759/1141011 http://www.51testing.com/html/00/130600-1367743.html ...
- 牛客小白月赛5 E 面积 计算三角形面积模板 波尔约-格维也纳定理 匹克公式
链接:https://www.nowcoder.com/acm/contest/135/E来源:牛客网 题目描述 定义“最大生成图”:在M*N的点阵中,连接一些点形成一条经过所有点恰好一次的回路,且连 ...
- Codeforces Round #481 (Div. 3) B. File Name
题目地址:http://codeforces.com/contest/978/problem/B 题解:一串文件名里不能出现连续的xxx,询问进行几次操作后,文件名才不会出现xxx. 方法:只要遍历一 ...