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的一些工具的简要使用的更多相关文章

  1. Capsule:开源的 JVM 应用部署工具

    [编者按]本文作者 Ron Pressler 是 Parallel Universe 公司的创始人,拥有着丰富的高性能开发经验.通过这篇文章,Ron 向大家详细介绍了全新的开源 JVM 部署工具--C ...

  2. jvm系列(七):jvm调优-工具篇

    16年的时候花了一些时间整理了一些关于jvm的介绍文章,到现在回顾起来还是一些还没有补充全面,其中就包括如何利用工具来监控调优前后的性能变化.工具做为图形化界面来展示更能直观的发现问题,另一方面一些耗 ...

  3. 《深入理解Java虚拟机》(五)JVM调优 - 工具

    JVM调优 - 工具 JConsole:Java监视与管理控制台 JConsole是一个机遇JMX(Java Management Extensions,即Java管理扩展)的JVM监控与管理工具,监 ...

  4. Java虚拟机(六):JVM调优工具

    工具做为图形化界面来展示更能直观的发现问题,另一方面一些耗费性能的分析(dump文件分析)一般也不会在生产直接分析,往往dump下来的文件达1G左右,人工分析效率较低,因此利用工具来分析jvm相关问题 ...

  5. JVM命令行工具&垃圾收集器&垃圾收集策略思维导图

    1.JVM命令行工具 2.垃圾回收算法 3.垃圾收集器

  6. JVM调优-工具篇

    原文地址 16年的时候花了一些时间整理了一些关于jvm的介绍文章,到现在回顾起来还是一些还没有补充全面,其中就包括如何利用工具来监控调优前后的性能变化.工具做为图形化界面来展示更能直观的发现问题,另一 ...

  7. JVM G1垃圾回收算法简要介绍

    JVM G1垃圾回收算法简要介绍 G1的特点 能够像CMS垃圾回收算法一样并发操作应用线程(潜台词:多核) 无需太长时间即可压缩空闲内存空间(潜台词:不会引起太多的GC停顿时间) 尽可能地让GC时长可 ...

  8. UAVStack JVM监控分析工具:图形化展示采集及分析监控数据

    摘要:UAVStack推出的JVM监控分析工具提供基于页面的展现方式,以图形化的方式展示采集到的监控数据:同时提供JVM基本参数获取.内存dump.线程分析.内存分配采样和热点方法分析等功能. 引言 ...

  9. java jvm常用命令工具

    [尊重原创文章出自:http://www.chepoo.com/java-jvm-command-tools.html] 一.概述 程序运行中经常会遇到各种问题,定位问题时通常需要综合各种信息,如系统 ...

随机推荐

  1. 右键新建 .md

    右键新建 .md 文件 声明:虽然我成功了,并且右键出来了两个,但是在添加 .html 的过程中又失败了,找不到解决办法. win + r --> regedit --> enter 点击 ...

  2. ECMAScript---变量

    上上篇我们说到ESMAScript是JS的语法规划,JS中的变量.数据类型.语法规范.操作语句.设计模型等都是ES规定的,现在咱们聊一下JS中的变量和常量 变量(variable) 它不是具体值,只是 ...

  3. HDU 2516

    题意略. 思路: 典型的斐波那契博弈,这里说一下结论: 如果先手面对的n不是斐波那契数,那么先手必胜:否则后手胜. 详见代码: #include<bits/stdc++.h> using ...

  4. StackOverflow 周报 - 与高关注的问题过过招(Java)

    本篇文章是 Stack Overflow 周报的第二周,共收集了 4 道高关注的问题和对应的高赞回答.公众号「渡码」为日更,欢迎关注. DAY1.  serialVersionUID 的重要性 关注: ...

  5. c#搭建webapi项目

    一.添加WebApi项目     二.nuget下载WebApi所需的类库引用 install-package Microsoft.AspNet.WebApi install-package Micr ...

  6. P2050 [NOI2012]美食节 动态连边优化费用流

    题意 类似的一道排队等候,算最小总等待时间的题目. 思路 但是这道题的边数很多,直接跑会tle,可以动态加边,就是先连上倒数第一次操作的边,跑一遍费用流,然后对使用了倒数第一条边的点,连上相应的倒数第 ...

  7. CodeForces - 534B-Covered Path+思路

    CodeForces - 534B 题意:给定初始和末尾的速度,和最大加速度和总时间,求出走的最长路程: 我一开始以为代码写起来会很繁琐... #include <iostream> #i ...

  8. CodeForces - 445B - DZY Loves Chemistry-转化问题

    传送门:http://codeforces.com/problemset/problem/445/B 参考:https://blog.csdn.net/littlewhite520/article/d ...

  9. CodeForces 834D The Bakery

    The Bakery 题意:将N个数分成K块, 每块的价值为不同数字的个数, 现在求总价值最大. 题解:dp[i][j] 表示 长度为j 且分成 i 块的价值总和. 那么 dp[i][j] = max ...

  10. 快速构建第一个Flink工程

    本文简述通过maven和gradle快速构建的Flink工程.建议安装好Flink以后构建自己的Flink项目,安装与示例运行请查看:Flink快速入门--安装与示例运行. 在安装好Flink以后,只 ...