JVM常用指令
创始人
2024-05-28 17:39:25
0

JVM常用指令

  • 1.准备工作
  • 2.jps
  • 3. jconsole
  • 4.jstat
  • 5.jstack
  • 6.jmap
  • 7.jvisualvm工具
  • 8.自动dump内存信息

1.准备工作

在idea中编写代码

public class JVMTest {@Testpublic void test() throws InterruptedException {while (true) {Thread.sleep(1000);System.out.println(123);}}
}

配置虚拟机的设置
在这里插入图片描述
配置如下:保证堆大小始终是10M

-Xms10m -Xmx10m

在这里插入图片描述
之后运行程序即可。

2.jps

jps 查看java进程概述

在这里插入图片描述

3. jconsole

输入jconsole 打开java监控和管理控制台

在这里插入图片描述
选择
在这里插入图片描述

选择不安全链接
在这里插入图片描述
点击-内存,可以查看年轻代垃圾收集的次数
在这里插入图片描述
看右下角,鼠标悬浮第一列
在这里插入图片描述

看右下角,鼠标悬浮第二列
在这里插入图片描述

看右下角,鼠标悬浮第三列
在这里插入图片描述
可以发现峰值处发生GC
在这里插入图片描述
点击线程标签
在这里插入图片描述
点击VM概要
在这里插入图片描述

4.jstat

jstat 观察gc情况

常用

jstat -gcutil 进程号

在这里插入图片描述

查看年轻代gc信息

jstat -gcnew 进程号

在这里插入图片描述

查看老年代gc信息

jstat -gcold 进程号

在这里插入图片描述

5.jstack

jstack 查看进程内的线程信息

jstack 进程号

在这里插入图片描述

6.jmap

jmap 查看堆内存使用状况

常用指令
这里的file是当前路径

jmap -dump:file=文件名 进行号

在这里插入图片描述

文件生成
在这里插入图片描述

jmap -heap 进行号

在这里插入图片描述

7.jvisualvm工具

jdk中自带该工具,去jdk的安装目录中bin下找jvisualvm.exe用管理员打开即可
在这里插入图片描述
双击进入监控界面
在这里插入图片描述
概述中,可以看到堆内存配置的大小
在这里插入图片描述
监控中可以点击触发垃圾回收
在这里插入图片描述
点击堆dump类似jmap -dump 操作
在这里插入图片描述
点击dump之后,可以查看基本信息
在这里插入图片描述
点击类之后可以查看类的实例占用的内存大小
在这里插入图片描述
刚才下载的dump文件,可以用这个工具查看
在这里插入图片描述
在概要中可以查看信息
在这里插入图片描述
类中可以查看占用的内存
在这里插入图片描述
因为linux系统中没有相关的图形化界面,我们的做法是利用jmap -dump:file=文件名称 进程号 dump文件到指定路径,然后下载dump文件后,在本机windows系统中通过jvisualvm工具来查看。

8.自动dump内存信息

更改虚拟机配置

-Xms10m -Xmx10m -XX:+HeapDumpOnOutOfMemoryError

在这里插入图片描述
更改java代码

public class JVMTest {@Testpublic void test() throws InterruptedException {ArrayList list = new ArrayList<>();int i = 0;while (true) {list.add(i);}}
}

点击运行,发现直接OOM了
在这里插入图片描述
我们去项目相关文件夹中,找到dump的文件
在这里插入图片描述
jvisualvm工具装载dump文件,通过概要查看
在这里插入图片描述
类中可以查看具体的错误信息
在这里插入图片描述

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
【PdgCntEditor】解... 一、问题背景 大部分的图书对应的PDF,目录中的页码并非PDF中直接索引的页码...
修复 爱普生 EPSON L4... L4151 L4153 L4156 L4158 L4163 L4165 L4166 L4168 L4...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...