Java CPU飙升 排查

一、概述

CPU 是整个电脑的核心计算资源,CPU的最小执行单元是 线程
在现代操作系统中,进程和线程是两种主要的调度单位;
进程是程序中正在运行的一个应用程序,而线程是系统分配处理器时间资源的基本单位。一个进程至少包括一个线程,通常称为主线程,而操作系统通过调度线程来高效地分配和管理CPU资源‌;
进程‌:进程是操作系统进行资源分配和调度的基本单位,是一个具有一定独立功能的程序在数据集上的一次动态执行过程。进程之间相互独立,每个进程运行在其专用的且受保护的内存空间中‌;

线程‌:线程是进程中的一个相对独立的执行单元,是CPU调度的最小单位。一个进程可以包含多个线程,这些线程共享进程的资源,但可以并行执行不同的任务‌  ;

 二、原因分析

1.CPU 上下文切换过多

对于 CPU 来说,同一时刻下每个 CPU 核心只能运行一个线程,如果有多个线程要执行,CPU 只能通过上下文切换的方式来执行不同的线程。

具体步骤包括:

1、保存当前上下文:将当前进程或线程的寄存器值、程序计数器、堆栈指针等信息保存到进程控制块(PCB)或线程控制块(TCB)中。

2、选择下一个要运行的任务:操作系统根据调度算法选择下一个运行的进程或线程。

3、加载新上下文:从选定的进程或线程的PCB/TCB中恢复其状态信息,如寄存器值和程序计数器等。

4、切换到新任务:CPU开始执行新选择的进程或线程。

这个过程需要 CPU 执行内核相关指令实现状态保存,如果较多的上下文切换会占据大量 CPU 资源,从而使得 cpu 无法去执行用户进程中的指令,导致响应速度下降。

在 Java 中,文件 IO、网络 IO、锁等待、线程阻塞等操作都会造成线程阻塞,从而触发上下文切换;

大量的 IO 操作,例如读写文件、网络通信等;

2.CPU 资源过度消耗

在程序中创建了大量的线程,或者有线程一直占用 CPU 资源无法被释放,比如死循环、不合理的递归操作;

大量的计算操作,例如复杂的算法、大量的数值计算等;

大量的数据库操作,导致数据库连接池的耗尽和数据库负载过高;

大量的线程创建和销毁操作,以及线程间的竞争和同步操作;

频繁GC;

1.代码中某个位置读取数据量较大 ,导致系统内存耗尽,从而导致Full GC次数过多;

2.JVM堆内存设置得太小,应用程序可能需要频繁地创建新对象,导致堆内存很快被填满,从而导致Full GC次数过多;

3.长时间持有不再使用的对象引用,导致这些对象不能被回收,随着时间的推移,内存泄漏;

4.创建了很多生命周期很短的对象,这些对象死后很快就会变成垃圾,增加了GC的压力;、5.频繁分配大对象(如大数组或大字符串)可能导致老年代内存很快被填满,触发Full GC;

 三、排查

1.CPU

1.使用 top 命令:找出哪个 Java 进程(PID)占用了较高的 CPU 资源。

例如,发现某个 java 进程占用了大部分 CPU 资源,比如 PID 为 123456

2.使用 top -H -p <PID>:查看特定进程(如 Java 进程)中各个线程的 CPU 占用情况。

top -H -p 123456

该命令会显示每个线程的 CPU 使用情况以及线程 ID (TID),帮助找出哪个线程可能引发了高 CPU 占用。

3.将线程 ID 转换为十六进制

Java 堆栈中使用的是十六进制的线程 ID,需将 top 命令中获取的线程 ID 转换为十六进制,便于后续匹配:

例如,如果 TID 是 456789,可以执行:

printf "%x\n" 456789

得到的输出为 6f855,这个 ID 将用于查找 Java 堆栈中的问题线程。

4.生成 Java 进程的线程栈

一旦确定了可能的问题线程 ID,使用 jstack 或 jcmd 来获取 Java 线程的堆栈信息。

使用 jstack 命令:生成特定 Java 进程的线程栈信息。

jstack -l 1234 > log.txt

使用 jcmd

jcmd <PID> Thread.print > log.txt

生成的 log.txt 文件将包含所有线程的堆栈信息。

5.分析线程栈

通过 jstack 或 jcmd 获取的线程栈中,找到与高 CPU 占用对应的线程,方法是根据之前转换为十六进制的 TID 来搜索线程。

例如:

"Thread-1" #10 prio=5 os_prio=0 tid=0x00007f84600c0800 nid=0x6f855 runnable [0x00007f845c7a1000] java.lang.Thread.State: RUNNABLE at com.example.MyClass.myMethod(MyClass.java:123) at ...其中,nid=0x162e 对应的正是 top 命令中显示高 CPU 占用的线程。

查看该线程的堆栈信息,可以推断线程是否处于繁忙的循环、锁竞争、IO阻塞等情况。

2.内存

java程序内存问题排查(jmap,jstat)_java jmap分析内存-CSDN博客

排查Java的内存问题_排查java哪里耗内存-CSDN博客

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

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

相关文章

Qt creator ,语言家功能缺失解决方法

1、找到工具->外部->配置 2、添加目录&#xff0c;双击命名语言家 3、在语言家目录下&#xff0c;添加工具 双击重命名lupdate&#xff0c;即更新翻译 %{CurrentDocument:Project:QT_INSTALL_BINS}\lupdate%{CurrentDocument:Project:FilePath}%{CurrentDocument:Projec…

Taro小程序开发性能优化实践

我们团队在利用Taro进行秒送频道小程序的同时&#xff0c;一直在探索性能优化的最佳实践。随着需求的不断迭代&#xff0c;项目中的性能问题难免日积月累&#xff0c;逐渐暴露出来影响用户体验。适逢双十一大促&#xff0c;我们趁着这个机会统一进行了Taro性能优化实践&#xf…

springboot471基于协同过滤算法商品推荐系统(论文+源码)_kaic

摘 要 传统办法管理信息首先需要花费的时间比较多&#xff0c;其次数据出错率比较高&#xff0c;而且对错误的数据进行更改也比较困难&#xff0c;最后&#xff0c;检索数据费事费力。因此&#xff0c;在计算机上安装协同过滤算法商品推荐系统软件来发挥其高效地信息处理的作用…

进程间关系与守护进程

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 进程间关系与守护进程 收录于专栏[Linux学习] 本专栏旨在分享学习Linux的一点学习笔记&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目录 1. 进程组 什…

【NLP 16、实践 ③ 找出特定字符在字符串中的位置】

看着父亲苍老的白发和渐渐老态的面容 希望时间再慢一些 —— 24.12.19 一、定义模型 1.初始化模型 ① 初始化父类 super(TorchModel, self).__init__()&#xff1a; 调用父类 nn.Module 的初始化方法&#xff0c;确保模型能够正确初始化。 ② 创建嵌入层 self.embedding n…

javaEE-多线程编程-3

目录 java 常见的包 : 回调函数: 什么是线程: 第一个线程: 验证多线程执行: 内核: 调用sleep()方法: 执行结果分析: 线程创建的几种方式: 1.继承Thread类,重写run()方法. 2.实现Runnable接口,重写run()方法. 3.继承Thread类,重写run()方法.但使用匿名内部类 4.实现…

怎么在idea中创建springboot项目

最近想系统学习下springboot&#xff0c;尝试一下全栈路线 从零开始&#xff0c;下面将叙述下如何创建项目 环境 首先确保自己环境没问题 jdkMavenidea 创建springboot项目 1.打开idea&#xff0c;选择file->New->Project 2.选择Spring Initializr->设置JDK->…

设计模式期末复习

一、设计模式的概念以及分类 是一套被反复使用&#xff0c;多数人知晓&#xff0c;经过分类编目&#xff0c;代码设计经验的总结&#xff0c;描述了在软件设计的过程中不断重复发生的问题&#xff0c;以及该问题的解决方案&#xff0c;他是解决特定问题的一系列套路&#xff0c…

Github——网页版上传文件夹

第一步&#xff1a;创建一个新的仓库或进入已存在的仓库页面 第二步&#xff1a;点进对应的文件夹下&#xff0c;然后 点击 “Upload files” 第三步&#xff1a;将文件夹拖拽到上传区域 打开资源管理器&#xff0c;将要上传的文件夹从计算机中拖拽到上传区域。 注意&#xf…

高级的SQL查询技巧有哪些?

成长路上不孤单&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a;&#x1f60a; 【14后&#x1f60a;///C爱好者&#x1f60a;///持续分享所学&#x1f60a;///如有需要欢迎收藏转发///&#x1f60a;】 今日分享关于高级SQL查询技巧方面的相关内容&#xf…

FastStone 10.x 注册码

简介 FastStone Capture是一款经典好用的屏幕截图软件&#xff0c;在屏幕截图领域具有广泛的应用和众多优势。 软件基本信息 FastStone Capture体积小巧&#xff0c;占用内存少&#xff0c;这使得它在运行时不会给计算机系统带来过多的负担&#xff0c;即使在配置较低的电脑…

K8S详解(5万字详细教程)

目录 ​编辑 一、集群管理命令 二、命名空间 1. 获取命名空间列表 2. 创建命名空间 3. 删除命名空间 4. 查看命名空间详情 三、Pod 1. Pod概述 2. Pod相位状态 3. 管理命令 3.1 获取命名空间下容器(pod)列表 3.2 查看pod的详细信息 3.3 创建 && 运行 3.4 …

费舍尔信息矩阵全面讲述

费舍尔信息矩阵&#xff08;Fisher Information Matrix&#xff09; 费舍尔信息矩阵是统计学中一个非常重要的概念&#xff0c;尤其在参数估计、最大似然估计&#xff08;MLE&#xff09;和贝叶斯推断中具有广泛的应用。它反映了参数估计的不确定性程度&#xff0c;也可以用来…

Zookeeper的监听机制

Zookeeper的监听机制是其实现分布式协调服务的一个核心功能。 它允许客户端注册Watcher&#xff08;观察者&#xff09;来监听特定的Znode&#xff08;节点&#xff09;上的事件&#xff0c;当Znode的状态发生变化时&#xff0c;Zookeeper会向注册了Watcher的客户端发送通知。…

[原创](Modern C++)现代C++的第三方库的导入方式: 例如Visual Studio 2022导入GSL 4.1.0

[简介] 常用网名: 猪头三 出生日期: 1981.XX.XX 企鹅交流: 643439947 个人网站: 80x86汇编小站 编程生涯: 2001年~至今[共23年] 职业生涯: 21年 开发语言: C/C、80x86ASM、PHP、Perl、Objective-C、Object Pascal、C#、Python 开发工具: Visual Studio、Delphi、XCode、Eclipse…

2002 - Can‘t connect to server on ‘192.168.1.XX‘ (36)

参考:2002 - Can‘t connect to server on ‘192.168.1.XX‘ (36) ubantu20.04&#xff0c;mysql5.7.13 navicat 远程连接数据库报错 2002 - Can’t connect to server on ‘192.168.1.61’ (36) 一、查看数据库服务是否有启动&#xff0c;发现有启动 systemctl status mysql…

漏洞检测工具:允许TRACE方法漏洞

允许TRACE方法漏洞 漏洞定义 TRACE方法是HTTP协议中定义的一种调试方法&#xff0c;主要用于测试或诊断Web服务器连接。Web服务器在配置时未正确禁用HTTP TRACE方法&#xff0c;从而允许客户端向服务器发送TRACE请求&#xff0c;并导致服务器返回可能包含敏感信息的响应。 漏…

linux socket编程之udp_dict_serve服务端--引入配置文件

注意&#xff1a;本篇博客只是对上一篇博客功能的增加 1.创建配置文件(翻译) Dict.txt apple: 苹果 banana: 香蕉 cat: 猫 dog: 狗 book: 书 pen: 笔 happy: 快乐的 sad: 悲伤的 run: 跑 jump: 跳 teacher: 老师 student: 学生 car: 汽车 bus: 公交车 love: 爱 hate: 恨 hell…

ESP32S3 使用LVGL驱动LCD屏(ST7789主控)

ESP32S3 使用LVGL驱动LCD屏&#xff08;ST7789主控&#xff09; 目录 1 分析原理图 2 驱动、点亮LCD(ST7789) 2.1 在工程中添加目录、文件 2.2 添加esp_lvgl_port组件 2.3 对工程进行必要的配置 2.4 编写必要代码 3 烧录、验证 1 分析原理图 要使用SOC驱动LCD屏&#…

Sigrity Optimize PI CapGen仿真教程文件路径

为了方便读者能够快速上手和学会Sigrity Optimize PI和 Deacap Generate 的功能&#xff0c;将Sigrity Optimize PI CapGen仿真教程专栏所有文章对应的实例文件上传至以下路径 https://download.csdn.net/download/weixin_54787054/90171471?spm1001.2014.3001.5503