jvm工具-jps、jstat、jmap、jstack

2024-06-16 22:52
文章标签 java 工具 jvm jmap jstack jstat jps

本文主要是介绍jvm工具-jps、jstat、jmap、jstack,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、jps

jps -v 【输出进程启动参数

[root@VM-8-2-centos ~]# jps -v
12401 Jps -Dapplication.home=/usr/local/jdk1.8.0_241 -Xms8m
16964 jar

其他参考

Java八股文必看,入门到深入理解jvm虚拟机之基础故障指令【jps,jstate...】-CSDN博客 

二、jstat

jstat -gc 【vmid】 【查看Java堆的状态】

[root@VM-8-2-centos dian-xhf]# jstat -gc 16964S0C    S1C    S0U    S1U      EC       EU        OC         OU       MC     MU    CCSC   CCSU   YGC     YGCT    FGC    FGCT     GCT   
12288.0 8192.0  0.0    0.0   147968.0 26136.3   55808.0    25116.2   59136.0 56068.7 7680.0 7058.2     15    0.223   3      0.341    0.564

jstat -gcutil 【vmid】 【查看Java堆占用百分比】

[root@VM-8-2-centos dian-xhf]# jstat -gcutil 16964S0     S1     E      O      M     CCS    YGC     YGCT    FGC    FGCT     GCT   0.00   0.00  17.66  45.00  94.81  91.90     15    0.223     3    0.341    0.564

S0 幸存0区域
S1 幸存1区域
E 伊甸园区
O 老年区
M 元空间 【有可能是P,表示永久代。具体的和jdk版本有关,笔者jdk版本是8】
YGC 年轻代的GC,也就是Minor GC ,轻量GC ,次数15
YGCT 轻量GC所耗时间 0.223秒
FGC 重量级GC次数 3
FGCT 重量级GC所耗时间 0.341秒
GCT 所有GC所耗费时间 0.564秒

三、jmap 

jmap -heap pid

打印 Java 堆概要信息,包括使用的 GC 算法、堆配置参数和各代中堆内存使用情况;

> jmap -heap 10352jmap -heap 10352
Attaching to process ID 10352, please wait...
Debugger attached successfully.
Server compiler detected.
JVM version is 25.201-b09using thread-local object allocation.
Parallel GC with 4 thread(s)Heap Configuration://对应jvm启动参数-XX:MinHeapFreeRatio设置JVM堆最小空闲比率(defalut 40)MinHeapFreeRatio         = 0 //对应jvm启动参数 -XX:MaxHeapFreeRatio设置JVM堆最大空闲比率(default 70)MaxHeapFreeRatio         = 100//对应jvm启动参数-XX:MaxHeapSize=设置JVM堆的最大大小MaxHeapSize              = 4280287232 (4082.0MB)//对应jvm启动参数-XX:NewSize=设置JVM堆的‘新生代’的默认大小NewSize                  = 89128960 (85.0MB)//对应jvm启动参数-XX:MaxNewSize=设置JVM堆的‘新生代’的最大大小MaxNewSize               = 1426587648 (1360.5MB)//对应jvm启动参数-XX:OldSize=<value>:设置JVM堆的‘老年代’的大小OldSize                  = 179306496 (171.0MB)//对应jvm启动参数-XX:NewRatio=:‘新生代’和‘老生代’的大小比率NewRatio                 = 2//对应jvm启动参数-XX:SurvivorRatio=设置年轻代中Eden区与Survivor区的大小比值SurvivorRatio            = 8//对应jvm启动参数-XX:MetaspaceSize=<value>:设置JVM堆的‘元空间’的初始大小// jdk1.8 永久代已经被元空间所取代MetaspaceSize            = 21807104 (20.796875MB)CompressedClassSpaceSize = 1073741824 (1024.0MB)//对应jvm启动参数-XX:MaxMetaspaceSize= :设置JVM堆的‘元空间’的最大大小MaxMetaspaceSize         = 17592186044415 MBG1HeapRegionSize         = 0 (0.0MB)
//堆内存分布
Heap Usage:
//新生代的内存分布
PS Young Generation
//Eden区内存分布
Eden Space://Eden区总容量capacity = 1425539072 (1359.5MB)//Eden区已使用used     = 28510792 (27.19001007080078MB)//Eden区剩余容量free     = 1397028280 (1332.3099899291992MB)//Eden区使用比率2.0000007407724003% used
From Space:capacity = 524288 (0.5MB)used     = 65536 (0.0625MB)free     = 458752 (0.4375MB)12.5% used
To Space:capacity = 524288 (0.5MB)used     = 0 (0.0MB)free     = 524288 (0.5MB)0.0% used
PS Old Generationcapacity = 128974848 (123.0MB)used     = 24006808 (22.894676208496094MB)free     = 104968040 (100.1053237915039MB)18.613557893086256% used13410 interned Strings occupying 1194568 bytes.

jmap -histo pid

打印 Java 堆中对象直方图,通过该图可以获取每个 class 的对象数目,占用内存大小和类全名信息,带上 :live,则只统计活着的对象;

>jmap -histo 10352num     #instances         #bytes  class name
----------------------------------------------1:      27073797      433180752  java.lang.Integer2:          5442       16503144  [I3:          5005        6143944  [B4:         33835        3446608  [C5:          9721         855448  java.lang.reflect.Method6:         33751         810024  java.lang.String7:          6494         717416  java.lang.Class8:         14303         457696  java.util.concurrent.ConcurrentHashMap$Node...

jmap -histo:live pid

打印 Java 堆中对象直方图,通过该图可以获取每个 class 的对象数目,占用内存大小和类全名信息,带上 :live,则只统计活着的对象;统计 heap 中所有生存的对象的情况, 这个命令会先触发 gc 再统计:

> jmap -histo:live 10352num     #instances         #bytes  class name
----------------------------------------------1:         27483        2670608  [C2:          6453         713152  java.lang.Class3:         27300         655200  java.lang.String4:         12861         411552  java.util.concurrent.ConcurrentHashMap$Node5:          6364         327688  [Ljava.lang.Object;6:          2496         219648  java.lang.reflect.Method7:           874         178440  [B...

jmap -dump:live,format=b,file=a.log pid

以 hprof 二进制格式将 Java 堆信息输出到文件内,该文件可以用 JProfiler、VisualVM 或 jhat 等工具查看;

  • 使用 MAT 分析工具,如 jhat 命令分析 hprof 文件

JDK 常用工具 —— jmap 详解-CSDN博客

四、jstack

jstack(Stack Trace for Java)命令用于生成虚拟机当前时刻的线程快照。

Java八股文必看,入门到深入理解jvm虚拟机之基础故障指令【jps,jstate...】-CSDN博客

分析工具jprofiler 

这篇关于jvm工具-jps、jstat、jmap、jstack的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1067779

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只