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…

12寸半导体厂等保安全的设计思路

等级保护(等保)二级和三级的主要区别在于安全要求的严格程度、所需部署的安全措施和设备、以及对安全事件响应和处理的能力。以下是等保二级和三级之间的一些关键区别: 一、 安全要求严格程度: - 等保二级:适用于需要较高安全保护的信息系统,要求能够防范轻微的恶意攻击…

Docker Compose 配置指南

目录 1. Docker Compose 配置1.1 基本配置结构1.2 docker-compose.yml 的各部分1.3 常用配置选项 2. Docker Compose 使用方法2.1 创建 Docker Compose 配置文件2.2 启动服务2.3 查看容器状态2.4 查看服务日志2.5 停止服务2.6 重新构建服务 3. Docker Compose 常用命令3.1 dock…

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

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

手动修改nginx-rtmp模块,让nginx-rtmp-module支持LLHLS

文章目录 1. 背景2. 开发环境搭建2.1 ffmpeg在ubuntu上安装2.2 nginx-rtmp-module在ubuntu上安装2.3 安装vscode环境2. 修改nginx-rtmp-module2.1 主要更新内容2.2 新增配置项2.3 代码更新3. LLHLS验证方法3.1 配置验证3.2 功能验证4. 注意事项5. 已知问题6. 后续计划1. 背景 …

Git的简介

文章目录 一.Git是什么二.核心概念三.工作流程四.Git的优势 下载Git 推荐官网下载 官网地址 一.Git是什么 Git是一个分布式版本控制系统&#xff0c;用于跟踪文件的变化并协调多人对同一项目的开发工作。它就像是一个时光机器&#xff0c;能够记录文件在不同时间点的状态&…

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…

哔哩哔哩视频能保存到本地吗

哔哩哔哩&#xff08;B站&#xff09;视频可以保存到本地&#xff0c;但需要根据具体情况选择方法。以下是一些常见的方式&#xff1a; 使用B站客户端的离线功能 B站官方客户端&#xff08;移动端或PC端&#xff09;提供了离线下载功能&#xff0c;适用于已开通权限的视频。 离…

FreeMarker语法

1. 查找转移 <#function getSubSlot x > <#return (x) ? switch( "1", "L", "2", "R", "" )> </#function> 2. 转换数字 ?number ${mergedMap[placement.sequence].material.subs…

OCR(五)linux 环境 基于c++的 paddle ocr 编译【CPU版本 】

1. 下载 下载opencv4.10 2. 编译opencv 2.1 安装依赖库 sudo apt install -y g ++ sudo apt install -y cmake sudo apt install -y make sudo apt install -y wget sudo apt install -y unzip sudo apt-get install build-essential libgtk2.0-dev libgtk-3-devlibavcodec-…

SQL Server 批量插入数据的方式汇总及优缺点分析

在 SQL Server 中,批量插入数据是非常常见的操作,尤其是在需要导入大量数据时。以下是几种常用的批量插入数据的方式: 1. 使用 INSERT INTO ... VALUES • 特点:适用于少量数据插入。 • 优点:简单易用。 • 缺点:不适合大量数据插入,性能较差。 • 示例:…

对于其他管理的理解(下)

信息系统项目管理师的论文还有可行性分析、安全管理、测试管理、招投标管理等 可行性分析(医生的手术前检查) 1. 明确目标&#xff1a;确定手术的必要性 知识点&#xff1a; 在项目启动阶段&#xff0c;需要明确项目的目的、目标和需求&#xff0c;确定是否有必要开展项目。这…

Linux增加回收站功能

功能简介 rm命令是非常危险的命令&#xff0c;为了防止用户误删文件&#xff0c;所以我们在执行rm命令时将文件添加到回收站&#xff0c;防止误删文件。 相关环境变量 名称描述TRASH_DIR 回收站目录&#xff0c;默认为/Recycle_Bin 文件命名规则 文件名生成格式为 原始文件名…

Github——网页版上传文件夹

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

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

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