【JVM-04】线上CPU100%

【JVM-04】线上CPU100%

  • 1. 如何排查
  • 2. 再举一个例子

1. 如何排查

⼀般CPU100%疯狂GC,都是死循环的锅,那怎么排查呢?先进服务器,⽤top -c 命令找出当前进程的运⾏列表按⼀下 P 可以按照CPU使⽤率进⾏排序显示Java进程 PID 为 2609 的java进程消耗最⾼。

[root@VM-8-7-centos ~]# top -c

在这里插入图片描述

然后我们需要根据PID 查出CPU⾥⾯消耗最⾼的进程
使⽤命令 top -Hp 2609 找出这个进程下⾯的线程,继续按P排序

[root@VM-8-7-centos ~]# top -Hp 2609

可以看到 2854 CPU消耗最⾼
在这里插入图片描述
2854是⼗进制的,我们需要转换为⼗六进制,转换结果:b26
接下来就需要导出我们的进程快照了,看看这个线程做了啥

[root@VM-8-7-centos ~]# jstack -l 2609 > ./2609.stack

再⽤grep查看⼀下线程在⽂件⾥做了啥

[root@VM-8-7-centos ~]# cat 2609.stack |grep 'b26' -C 8

这⾥就随便定位⼀个,基本上这样查都可以定位到你死循环的那个类。
在这里插入图片描述

2. 再举一个例子

public class FullCPU {public static void main(String[] args) {while(true){}}
}java -cp . FullCPU

在这里插入图片描述

PID (进程标识符)
[root@VM-8-7-centos ~]# top -Hp 12844

结合起来,top -Hp 12844 命令的作用是:
-H 显示所有线程 -p12844 只显示 PID 为 12844 的进程信息

  1. 启动 top 命令。
  2. 显示 PID 为 12844 的进程及其所有线程的详细信息。
  3. 实时更新该进程和线程的资源使用情况。

在这里插入图片描述

[root@VM-8-7-centos ~]# jstack -l 12844 > ./12844.stack1284516进制为0x322d
cat 12844.stack |grep '0x322d' -C 8

在这里插入图片描述

[root@VM-8-7-centos ~]# jstack -l 12844 > ./12844.stack执行这个命令后,jstack 工具将生成一个包含 PID 为 12844 的 Java 进程的所有线程的当前状态的快照,并将其保存到 ./12844.stack 文件中。文件内容通常包括每个线程的堆栈跟踪、线程状态以及锁信息。

完整命令:cat 12844.stack | grep '0x322d' -C 8

  1. 这条命令首先使用 cat 命令显示 12844.stack 文件的内容。
  2. 然后通过管道符 | 将 cat 命令的输出传递给 grep 命令。
  3. grep 命令搜索包含 ‘0x322d’ 的行,并显示该行及其上下 8 行的内容。

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

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

相关文章

苏东坡传-读书笔记七

苏堤和西湖之与杭州,正如美女花容月貌上的双眸。我常想,倘若西湖之是空空的一片水——没有苏堤那秀美的修眉和虹彩般的仙岛,一画龙点睛增其神韵,那西湖该望之如何?几百年来的中国游客,春季到来之时,向西湖…

throw和catch关键字的作用。

在C中,throw和catch是异常处理机制的关键字,它们共同工作以处理在程序执行过程中发生的异常情况。 throw 关键字 throw关键字用于抛出一个异常。当程序遇到无法处理的错误时,它会使用throw语句抛出一个异常。这通常是因为遇到了某些无法恢复…

使用Vue 2 + Element UI搭建后台管理系统框架实战教程

后台管理系统作为企业内部的核心业务平台,其界面的易用性和功能性至关重要。Vue 2作为一个成熟的前端框架,以其轻量级和高效著称,而Element UI则是一套专为桌面端设计的Vue 2组件库,它提供了丰富的UI元素和组件,大大简…

如何在Python中实现一个简单的爬虫程序

如何在Python中实现一个简单的爬虫程序 随着互联网的发展,数据已成为当今社会最宝贵的资源之一。而爬虫程序则成为了获取互联网数据的重要工具之一。本文将介绍如何在Python中实现一个简单的爬虫程序,并提供具体的代码示例。 确定目标网站 在开始编写爬…

【Python】已解决:urllib.error.HTTPError: HTTP Error 403: Forbidden

文章目录 一、分析问题背景二、可能出错的原因三、错误代码示例四、正确代码示例五、注意事项 已解决:urllib.error.HTTPError: HTTP Error 403: Forbidden 一、分析问题背景 在使用Python的urllib库中的urlopen或urlretrieve函数下载文件时,有时会遇到…

Android动画:提升用户体验的关键技术

Android平台上的动画技术不仅仅是界面美化的手段,它更是提升用户体验、增强交互性和吸引用户注意力的重要工具。从简单的过渡动画到复杂的视图动态效果,Android开发者可以利用丰富的动画API创造出令人印象深刻的应用程序。本文将深入探讨Android动画的多…

Python打字练习

代码解析 导入模块和定义单词列表 import tkinter as tk import randomsample_words ["apple", "banana", "cherry", "date", "fig", "grape", "kiwi", "lemon", "mango", &quo…

LDA主题分析的原理、步骤和实现

当然可以!LDA 主题模型是一种强大的工具,用于从大量文本数据中发现隐藏的主题。让我们更详细地介绍它的原理、步骤和实现。 LDA原理 LDA是一种生成模型,它假设: 每个文档是由若干主题组成的。每个主题是由若干词汇组成的。 具…

vcpkg国内镜像源替换

vcpkg国内镜像源替换 一、从Gitee上下载vcpkg二、全局替换vcpkg/scripts文件下的字符三、回到vcpkg目录下,执行bootstrap-vcpkg.bat文件,等待执行完毕四、全局替换vcpkg/ports文件下的字符 一、从Gitee上下载vcpkg git clone https://gitee.com/mirrors…

全国30省份各省资本存量数据固定资本形成总额永续盘存法(2000-2023年)

各省资本存量数据通过永续盘存法进行了详细的计算,这一方法覆盖了中国30个省份(不包括西藏),提供从2000年起直至2023的资本存量数据集。包括原始数据、测算过程、最终的资本存量结果。 以2000年作为基期年份,依据…

电路笔记(PCB):电流容量(IPC-2221和IPC-2152)+阻抗匹配

电流容量 IPC-2221经验公式 I K T b A c IK\times T^{b}\times A^{c} IKTbAc 这个公式用于估计PCB(Printed Circuit Board,印刷电路板)导线上的电流(I),其中T和A分别表示温度(Temperature&a…

flex布局中子元素内容超出时,子元素本身出现滚动条实现方法

flex布局中子元素宽度平均分配,并且当子元素内容超出时,子元素本身出现滚动条实现方法: 将父元素设置为display: flex,以启用Flexbox布局。将每个子元素的flex属性设置为1,以使其宽度平均分配。设置子元素的overflow属…

toRefs 和 toRef

文章目录 toRefs 和 toReftoRefstoRef toRefs 和 toRef toRefs toRefs 把一个由reactive对象的值变为一个一个ref的响应式的值 import { ref, reactive, toRefs, toRef } from vue; let person reactive({name: 张三,age: 18, }); // toRefs 把一个由reactive对象的值变为一…

ComfyUI流程图、文生图、图生图步骤教学!

前言 leetcode , 209. 长度最小的子数组 给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其总和大于等于 target 的长度最小的子数组 [numsl, numsl1, …, numsr-1, numsr] ,并返回其长度。如果不存在符合条件的子数组,返回 0 …

大厂都在“抢滩”欧洲杯,你该如何蹭上热度?

2024欧洲杯战至第三轮小组赛,德国、瑞士、西班牙、意大利已出线角逐1/8决赛。 云略统计,欧洲杯开战至今,抖音上“欧洲杯”相关话题高达1000个,其中#谁是欧洲杯预言家 话题播放量高达7.57亿,C罗、姆巴佩等国际巨星更是频…

DB-100撕裂开关 JOSEF约瑟 合金接线端子,轻松接线

一、产品概述 型号:DB-100 主要用途:DB-100撕裂开关主要用于监测皮带输送机在运行过程中是否发生纵向撕裂,一旦发现撕裂情况,立即触发报警或停机,以保护设备和生产线的安全运行。 二、技术特点 检测原理:…

Snipaste截图工具的下载

Snipaste是一款简单而强大的桌面截图工具,它不仅支持快速截图,还提供了丰富的编辑和贴图功能,极大地提升了用户的工作效率。 网址:Snipaste 下载 1.进入文件夹解压缩 2.解压缩后打开双击运行 3.快捷键F1截图 F3截图固定桌面 …

springboot的双亲委派

双亲委派模型(Parent Delegation Model)是 Java 类加载机制中的一种设计模式,用于确保 Java 类加载的一致性和安全性。这个模型规定,当一个类加载器加载一个类时,它首先将加载请求委派给父类加载器处理,只有…

(linux基本操作)秒懂用户组的管理

一、用户与用户组的概念 1、为什么要做用户与用户组管理 用户和用户组管理,就是添加用户和用户组,针对每个用户设置不同的密码。 问题:大家平时的笔记本电脑,会设置多个账户吗?为什么? 服务器要添加多账…

2024年6月总结及随笔之打卡网红点

1. 回头看 日更坚持了547天。 读《人工智能时代与人类未来》更新完成读《AI未来进行式》开更并更新完成读《AI新生:破解人机共存密码》开更并持续更新 2023年至2024年6月底累计码字1267912字,累计日均码字2317字。 2024年6月码字90659字,…