当前位置: 首页 > news >正文

JVM常用指令

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<Integer> list = new ArrayList<>();int i = 0;while (true) {list.add(i);}}
}

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

http://www.lryc.cn/news/28753.html

相关文章:

  • 排序中常见的一些指标
  • 51单片机入门————数码管显示
  • Spring事务未生效场景
  • servlet注解开发
  • mysql一联合主键
  • openpnp - 判断吸嘴是否指定了正确的旋转轴
  • 【办公类-19-03】办公中的思考——Python批量统一文件名的序号(保教主任整理打印文件)
  • MySQL约束
  • x86 平台利用 qemu-user-static 实现 arm64 平台 docker 镜像的运行和构建
  • 找工作经验分享
  • C语言学习之路--操作符篇,从知识到实战
  • 【华为OD机试2023】端口合并 C++ Java Python
  • C++常用头文件整理
  • Linux内核4.14版本——drm框架分析(2)——connector分析
  • dev GridControl 按条件纵向合并单元格
  • aws eks 集群初始化过程中pause容器的启动逻辑
  • Numpy专栏目录(长期更新)
  • English Learning - L2 第1次小组纠音 [ɑː] [ɔː] [uː] 2023.2.25 周六
  • 博客系统程序(页面设计)
  • 【死锁的排查工具有哪些?】
  • JUC包:CyclicBarrier源码+实例讲解
  • Trace、Metrics、Logging 选型
  • Java验证码
  • 5天带你读完《Effective Java》(四)
  • 探索密码学的未来:SM1、SM2、SM3、SM4、同态加密、密态计算、隐私计算和安全多方计算
  • 【教程】去水印开源工具Lama Cleaner在Windows的安装和使用
  • 驾考笔记_2023
  • 【架构师】跟我一起学架构——调用链
  • [神经网络]Swin Transformer网络
  • 【分布式】什么是分布式,分布式和集群的区别又是什么?答案在正文。