JVM之Arthas的dashboard命令以及CPU飙高场景

 

博主介绍:✌全网粉丝5W+,全栈开发工程师,从事多年软件开发,在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战,博主也曾写过优秀论文,查重率极低,在这方面有丰富的经验✌

博主作品:《Java项目案例》主要基于SpringBoot+MyBatis/MyBatis-plus+MySQL+Vue等前后端分离项目,可以在左边的分类专栏找到更多项目。《Uniapp项目案例》有几个有uniapp教程,企业实战开发。《微服务实战》专栏是本人的实战经验总结,《Spring家族及微服务系列》专注Spring、SpringMVC、SpringBoot、SpringCloud系列、Nacos等源码解读、热门面试题、架构设计等。除此之外还有不少文章等你来细细品味,更多惊喜等着你哦

🍅uniapp微信小程序🍅面试题软考题免费使用,还可以使用微信支付,扫码加群。由于维护成本问题得不到解决,可能将停止线上维护。

🍅文末获取联系🍅精彩专栏推荐订阅👇🏻👇🏻 不然下次找不到哟

Java项目案例《100套》
https://blog.csdn.net/qq_57756904/category_12173599.html
uniapp小程序《100套》

https://blog.csdn.net/qq_57756904/category_12173599.html

有需求代码永远写不完,而方法才是破解之道,抖音有实战视频课程,某马某千等培训都是2万左右,甚至广东有本科院校单单一年就得3万4年就12万学费,而且还没有包括吃饭的钱。所以很划算了。另外博客左侧有源码阅读专栏,对于求职有很大帮助,当然对于工作也是有指导意义等。在大城市求职,你面试来回一趟多多少少都在12块左右,而且一般不会一次性就通过,还得面试几家。而如果你对源码以及微服务等有深度认识,这无疑给你的面试添砖加瓦更上一层楼。

最后再送一句:最好是学会了,而不是学废了!!

2

dashboard 是 Arthas 中一个非常强大的命令,用于实时监控 Java 应用的运行状态。它可以显示 JVM 的 CPU、内存、线程、GC 等信息,帮助开发者快速定位性能问题。


1. 启动 Arthas

在终端中启动 Arthas:

java -jar arthas-boot.jar

选择需要诊断的 Java 进程(输入进程编号)。


2. 使用 dashboard 命令

在 Arthas 命令行中输入:

dashboard

此时会进入一个实时监控界面,显示当前 Java 应用的运行状态。


3. dashboard 界面详解

dashboard 界面通常分为以下几个部分:

1. ID

  • 当前 Java 进程的 ID。

2. NAME

  • 当前 Java 进程的名称。

3. GROUP

  • 当前 Java 进程的组。

4. PRIORITY

  • 当前 Java 进程的优先级。

5. STATE

  • 当前 Java 进程的状态。

6. CPU

  • Total:JVM 进程占用的 CPU 百分比。

  • User:用户态 CPU 占用百分比。

  • Sys:内核态 CPU 占用百分比。

7. MEMORY

  • Used:已使用的内存大小。

  • Max:最大可用内存大小。

  • Usage:内存使用率。

8. THREAD

  • Total:当前 JVM 中的线程总数。

  • RUNNABLE:处于可运行状态的线程数。

  • BLOCKED:处于阻塞状态的线程数。

  • WAITING:处于等待状态的线程数。

  • TIMED_WAITING:处于定时等待状态的线程数。

9. GC

  • Young GC:年轻代 GC 的次数和时间。

  • Full GC:老年代 GC 的次数和时间。

10. Runtime

  • Uptime:JVM 运行时间。

  • Start Time:JVM 启动时间。

11. Class Loading

  • Loaded:已加载的类数量。

  • Unloaded:已卸载的类数量。

12. Thread Details

  • 显示当前占用 CPU 最高的线程信息,包括:

    • ID:线程 ID。

    • NAME:线程名称。

    • STATE:线程状态。

    • CPU%:线程占用的 CPU 百分比。

    • TIME:线程运行时间。


4. 常用操作

刷新频率

  • 默认情况下,dashboard 每秒刷新一次。

  • 可以通过 -i 参数设置刷新间隔(单位:秒):

    dashboard -i 2

    每 2 秒刷新一次。

退出 dashboard

  • 按下 q 键退出 dashboard 界面,返回 Arthas 命令行。


5. 使用场景

1. 监控 CPU 使用率

  • 查看 CPU 部分,确认 JVM 进程的 CPU 使用率是否过高。

  • 查看 Thread Details,找到占用 CPU 最高的线程。

2. 监控内存使用情况

  • 查看 MEMORY 部分,确认内存使用率是否过高。

  • 如果内存使用率持续增长,可能存在内存泄漏。

3. 监控线程状态

  • 查看 THREAD 部分,确认是否有大量线程处于 BLOCKED 或 WAITING 状态。

  • 如果有,可能存在锁竞争或资源等待问题。

4. 监控 GC 情况

  • 查看 GC 部分,确认 Young GC 和 Full GC 的次数和时间。

  • 如果 Full GC 频繁发生,可能存在内存不足或内存泄漏问题。


6. 示例

场景 1:CPU 飙升

  1. 启动 Arthas:

    java -jar arthas-boot.jar

  2. 输入 dashboard,查看 CPU 和 Thread Details

  3. 找到占用 CPU 最高的线程,记录其线程 ID。

  4. 使用 thread <线程ID> 查看线程堆栈,定位问题代码。

具体模拟场景

1、模拟线程一直消耗CPU资源,注意一定要给线程加上一个名字才能更好排查系统问题

package ceam.test.controller;import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
@RequestMapping("/poi/thread")
public class ThreadController {@GetMappingpublic void thread() {Thread thread = new Thread(() -> {while (true) {System.out.println("=======模拟线程一直在消耗CPU资源,Arthas中可以看到其CPU很高======");}}, "threadController-test");thread.start();}
}

2、启动Arthas跟进该接口对应的进程

3、dashboard查看可见ID为54的线程CPU最高,即我们自己创建的线程threadController-test

4、thread -n  3

可见threadController-test这个线程消耗CPU资源是最高的

5、thread 线程ID,排查具体问题代码

可见是在执行run方法时消耗资源的,在ThreadController代码的第15行位置

场景 2:内存泄漏

  1. 启动 Arthas:

    java -jar arthas-boot.jar

  2. 输入 dashboard,查看 MEMORY 部分。

  3. 如果内存使用率持续增长,使用 heapdump 导出堆内存快照,进一步分析。


7. 总结

dashboard 是 Arthas 中最常用的命令之一,能够实时监控 Java 应用的运行状态,帮助开发者快速定位以下问题:

  • CPU 飙升:查看 CPU 和 Thread Details

  • 内存泄漏:查看 MEMORY 和 GC

  • 线程问题:查看 THREAD 和 Thread Details

通过 dashboard,可以快速了解系统的整体运行状况,为后续的深入排查提供方向。

3

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/30718.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JSAR 基础 1.2.1 基础概念_空间小程序

JSAR 基础 1.2.1 基础概念_空间小程序 空间空间自由度可嵌入空间空间小程序 最新的技术进展表明&#xff0c;官网之前的文档准备废除了&#xff0c;基于xsml的开发将退出历史舞台&#xff0c;three.js和普通web结合的技术将成为主导。所以后续学习请移步three.js学习路径&#…

蓝桥杯嵌入式组第七届省赛题目解析+STM32G431RBT6实现源码

文章目录 1.题目解析1.1 分而治之&#xff0c;藕断丝连1.2 模块化思维导图1.3 模块解析1.3.1 KEY模块1.3.2 ADC模块1.3.3 IIC模块1.3.4 UART模块1.3.5 LCD模块1.3.6 LED模块1.3.7 TIM模块 2.源码3.第七届题目 前言&#xff1a;STM32G431RBT6实现嵌入式组第七届题目解析源码&…

Java之IO流

什么是IO流 存储和读取数据的解决方案 I&#xff1a;input:输入 O&#xff1a;output&#xff1a;输出 流&#xff1a;像水流一样传输数据 IO流的作用 用于读取数据&#xff08;本地文件&#xff0c;网络&#xff09; IO流的分类 流的方向&#xff1a; 输入流&#xff…

Python入门———条件、循环

目录 语句 顺序语句 条件语句 缩进和代码块 判断年份是否是闰年 空语句 pass 循环 while 循环 求5的阶乘&#xff1a; 求1&#xff01;2&#xff01;3&#xff01;4&#xff01;5&#xff01; for循环 打印1-10 打印2&#xff0c;4&#xff0c;6&#xff0c;8&#x…

JWT的学习

1、HTTP无状态及解决方案 HTTP一种是无状态的协议&#xff0c;每次请求都是一次独立的请求&#xff0c;一次交互之后就是陌生人。 以CSDN为例&#xff0c;先登录一次&#xff0c;然后浏览器退出&#xff0c;这个时候在进入CSDN&#xff0c;按理说服务器是不知道你已经登陆了&…

【接口负载】✈️整合 Resilience4j 指定接口负载,避免过载

目录 &#x1f44b;前言 &#x1f378;一、应用场景 &#x1f37b;二、 代码实现 &#x1f379;三、扩展 &#x1f378;四、章末 &#x1f44b;前言 小伙伴们大家好&#xff0c;上次本地实操了下针对百万级数据量如何快速排序、指定条件获取等&#xff0c;文章内容包括&am…

CSS—网格布局Grid

网格布局grid 提供了带有行和列的基于网格的布局系统&#xff0c;无需使用浮动和定位。 当 HTML 元素的 display 属性设置为 grid 或 inline-grid 时&#xff0c;它就会成为网格容器。 更多布局模式可以参考之前的博客&#xff1a; ​​​​​​CSS—flex布局、过渡transit…

表格columns拼接两个后端返回的字段(以umi框架为例)

在用组件对前端项目进行开发时&#xff0c;我们会遇到以下情况&#xff1a;项目原型中有取值范围这个表字段&#xff0c;需要存放最小取值到最大取值。 而后端返回给我们的数据是返回了一个最小值和一个最大值&#xff0c; 在columns中我们需要对这两个字段进行拼接&#xff0…

Git系列之git tag和ReleaseMilestone

以下是关于 Git Tag、Release 和 Milestone 的深度融合内容&#xff0c;并补充了关于 Git Tag 的所有命令、详细解释和指令实例&#xff0c;条理清晰&#xff0c;结合实际使用场景和案例。 1. Git Tag 1.1 定义 • Tag 是 Git 中用于标记特定提交&#xff08;commit&#xf…

SQLiteStudio:一款免费跨平台的SQLite管理工具

SQLiteStudio 是一款专门用于管理和操作 SQLite 数据库的免费工具。它提供直观的图形化界面&#xff0c;简化了数据库的创建、编辑、查询和维护&#xff0c;适合数据库开发者和数据分析师使用。 功能特性 SQLiteStudio 提供的主要功能包括&#xff1a; 免费开源&#xff0c;可…

VMware workstation 17安装过程详细指南

VMware 17安装过程详细指南 一、准备工作 在开始安装 VMware 之前&#xff0c;你需要确保你的计算机满足以下条件&#xff1a; 操作系统&#xff1a;VMware Workstation 支持多种 Windows 和 Linux 操作系统。确保你的操作系统版本在 VMware 支持的范围内。 硬件要求&#…

【从零开始学习计算机科学】计算机组成原理(六)异常事件处理

【从零开始学习计算机科学】计算机组成原理&#xff08;六&#xff09;异常事件处理 异常事件处理异常处理的数据通路异常事件入口地址 异常事件处理 异常和中断事件改变处理机正常指令的执行顺序。异常指令执行过程中&#xff0c;由于操作非法和指令非法引起的事件。陷阱指陷…

基于DeepSeek的智慧医药系统(源码+部署教程)

运行环境 智慧医药系统运行环境如下&#xff1a; 前端&#xff1a; HTMLCSS后端&#xff1a;Java AIGCDeepseekIDE工具&#xff1a;IDEA技术栈&#xff1a;Springboot HTMLCSS MySQL 主要角色 智慧医药系统主要分为两个角色。 游客 尚未进行注册和登录。具备登录注册、…

WinUI 3 支持的三种窗口 及 受限的窗口透明

我的目标 希望能够熟悉 WinUI 3 窗口的基本使用方式&#xff0c;了解可能出现的问题 。 WinUI 3 支持三种窗口模式&#xff0c;分别为&#xff1a;常规窗口模式、画中画模式、全屏模式。 窗口模式&#xff1a;常规 即我们最常见的普通窗口。 支持&#xff1a;显示最大化按钮…

《云原生监控体系构建实录:从Prometheus到Grafana的观测革命》

PrometheusGrafana部署配置 Prometheus安装 下载Prometheus服务端 Download | PrometheusAn open-source monitoring system with a dimensional data model, flexible query language, efficient time series database and modern alerting approach.https://prometheus.io/…

VBA 数据库同一表的当前行与其他行的主键重复判断实现方案1

目的&#xff0c;判断是否主键重复&#xff0c;不重复则登录新数据&#xff0c;重复则不登录。 定义类型&#xff1a; DataRecord   tableName 表名   rowNumber 行号   columnName 列名   data 数据 想要实现的代码逻辑如下&#xff1a; 模拟数据库的登录过程。假设…

MySql的in和join对比谁更高效

公司有个SQl根据时间判断是否变化进而更新到主表通知下游服务告知变化 首先看下优化前和优化后的sql&#xff1a; 优化前&#xff1a;执行很慢 UPDATE vrs_video SET updated_at now() WHEREvrs_video.id IN (SELECT DISTINCTvideo_id FROMvrs_play_source WHEREvrs_play_…

用BGE Large ZH 1.5获取向量以及重排序构建生产环境可用restful API的Python代码讲解

开篇 嘿&#xff0c;各位小伙伴&#xff01;今天我们来聊一个超级有趣的话题&#xff1a;embedding向量化数据。听起来很高大上对不对&#xff1f;别担心&#xff0c;让我用最简单的方式告诉你这是啥。 想象一下&#xff0c;你有一大堆文字、图片或者其他数据&#xff0c;想要…

【OneAPI】网页截图API-V2

API简介 生成指定URL的网页截图或缩略图。 旧版本请参考&#xff1a;网页截图 V2版本新增全屏截图、带壳截图等功能&#xff0c;并修复了一些已知问题。 全屏截图&#xff1a; 支持全屏截图&#xff0c;通过设置fullscreentrue来支持全屏截图。全屏模式下&#xff0c;系统…

1个基于 Three.js 的 Vue3 组件库

大家好&#xff0c;我是大澈&#xff01;一个喜欢结交朋友、喜欢编程技术和科技前沿的老程序员&#x1f468;&#x1f3fb;‍&#x1f4bb;&#xff0c;关注我&#xff0c;科技未来或许我能帮到你&#xff01; Tres.js 是一个基于 Three.js 的 Vue 3 组件库&#xff0c;旨在简…