您当前的位置:首页 > 电脑百科 > 站长技术 > 服务器

线上环境 CPU 使用率飙升如何快速排查?

时间:2023-03-06 12:02:17  来源:微信公众号  作者:飞天小牛肉
这里就不麻烦地建 Web 项目了,用一个最原始的 JAVA 项目来模拟高 CPU 场景。打开 IDEA,创建一个 Java 项目,里面写一个死循环,循环里面不断地创建对象。

相比于一大堆复杂的 JVM 调优过程,本文介绍的排查步骤还是挺简单的,可以帮助各位小伙伴排查一些简单问题,面试官问起来也好过啥也不会(这个 CPU 打满如何排查我被问过好多次......)。

模拟高 CPU 场景

这里就不麻烦地建 Web 项目了,用一个最原始的 Java 项目来模拟高 CPU 场景。打开 IDEA,创建一个 Java 项目,里面写一个死循环,循环里面不断地创建对象:

图片

然后打成 jar 包,这个没啥难度,懒得敲命令的话直接 IDEA 中点几下就可以,File -> Project Settings -> Artifacts:

图片

执行成功后可以在 /out/artifacts/highCpuTest.jar 文件夹下找到 jar 包:

图片

将这个 jar 包上传到服务器中并运行(我是上传到 /home/test 目录下了)。为了防止把服务器搞崩,我选择利用 Docker 运行,并限制了最大内存 200M。具体步骤如下:

这块不是重点哈,可以直接忽略

首先拉取 JDK 镜像并创建一个名为 high-cpu-test 的容器:

# 拉取镜像
docker pull openjdk:8
# 创建并运行容器(-m 200m,设置最大内存 200m)
docker run -d -it --name high-cpu-test  -m 200m openjdk:8

然后将 /home/test/hightCpuTest.jar 复制到 high-cpu-test 容器中的 home 目录下:

# 将 /home/test/hightCpuTest.jar 复制到 high-cpu-test 容器中的 home 目录下
docker cp /home/test/highCpuTest.jar high-cpu-test:/home

这样就可以在 Docker 中执行这个 jar 包了:

# 进入容器内部
docker exec -it high-cpu-test bash

# 执行 jar 包
cd /home
java -jar highCpuTest.jar

排查步骤

你可以选择另开一个终端然后进入 high-cpu-test 容器内部执行以下步骤

1. 找到占用 CPU 最高的进程

首先第一步,利用 top 命令监控 CPU 运行状态,显示进程运行信息,看看到底是哪些进程占用了大量 CPU:

top -c

可以键入大写的 P,使得进程按照 CPU 使用率排序:

图片

可以看到目前占用 CPU 最多的进程的 PID 是 85,遥遥领先于其他进程。

2. 找到占用 CPU 最高的线程

虽然找到了占用 CPU 最高的进程 PID 是 85,但并不能直接就开始定位代码了,因为一个进程中有很多线程,不可能所有线程都占用了大量 CPU,所以我们现在要做的就是找出 PID 85 这个进程中占用 CPU 最高的线程。

执行 top -Hp pid 命令,pid 就是上面我们排查出来的进程 PID:

top -Hp 85

然后同样的,键入大写 P,使得线程按照 CPU 使用率排序:

图片

可以看到目前占用 CPU 最多的进程的 PID 是 95,遥遥领先于其他线程。

3. 打印线程堆栈信息

接下来我们要做的就是打印出 PID 95 这个线程的堆栈信息,然后根据堆栈信息定位代码。

首先,需要通过 printf 命令将 PID 95 转化成 16 进制,因为堆栈里的线程 PID 是用 16 进制表示的

printf "%xn" 95

图片

得到 16 进制的线程 PID 为 0x5f​。这样,就可以通过 jstack 命令查看堆栈信息了:

# jstack 进程 PID | grep '线程 16 进制 PID' -C20
jstack 85 | grep '0x5f' -C20

-C<显示行数> : 除了显示符合样式的那一行之外,并显示该行之前后的内容

执行结果如下图所示:

图片

如上图打印出了线程的堆栈信息,可以看到,定位到了 highCpuThread 线程中的 lambda 代码,具体在第 15 行。Over~



Tags:CPU   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
这里就不麻烦地建 Web 项目了,用一个最原始的 Java 项目来模拟高 CPU 场景。打开 IDEA,创建一个 Java 项目,里面写一个死循环,循环里面不断地创建对象。相比于一大堆复杂的 JVM...【详细内容】
2023-03-06  Tags: CPU  点击:(0)  评论:(0)  加入收藏
这一篇着重讲一下如何查找最耗费CPU的查询,然后分析它们的执行计划和相关的索引。以下是一些可以使用的SQL语句: 查找最耗费CPU的查询:SELECT q.query_id, q.query_tex...【详细内容】
2023-02-26  Tags: CPU  点击:(5)  评论:(0)  加入收藏
近年来,计算机中央处理器已经取得了相当大的进步,晶体管每年都在变小,性能也变得更加强大。每当提到处理器的性能时,人们往往会想到晶体管和频率。实际上,除了更多的晶体管数量和...【详细内容】
2023-01-31  Tags: CPU  点击:(42)  评论:(0)  加入收藏
玩家在选CPU的时候会遇到4核心8线程这样的参数,而且还有很多CPU的线程数并不是核心数的2倍,也导致了很多用户丈二和尚摸不着头脑,陷入核心数越多越好的误区,其实只要明白了核心...【详细内容】
2023-01-30  Tags: CPU  点击:(29)  评论:(0)  加入收藏
最近业主要求要把系统从电信云迁移到区里面的政数云,迁移前电信云是8核16G的配置,迁移后政数云是32核32G的配置,按理说迁移后性能应该非常好,结果老是系统崩溃,查找原因是mysql占...【详细内容】
2023-01-11  Tags: CPU  点击:(34)  评论:(0)  加入收藏
一、CPU的功能:指令控制:完成取指令、分析指令和执行指令的操作,即程序的顺序控制。操作控制:一条指令的功能往往是由若干操作信号的组合来实现的。CPU管理并产生由内存取出的...【详细内容】
2023-01-09  Tags: CPU  点击:(53)  评论:(0)  加入收藏
CPU给人最深刻的印象莫过于底部密密麻麻的针脚了,如果你关注过CPU的针脚,就会发现,随着代数的更新,CPU的针脚数在不断增加,难道针脚数可以决定CPU的性能?其实不管AMD还是英特尔,其...【详细内容】
2023-01-04  Tags: CPU  点击:(40)  评论:(0)  加入收藏
给大家分享一个事情。背景是这样的,我们要测试某个第三方 SDK 运行性能,这是个 CPU 密集型的服务。我想评估一下它运行一遍到底有多吃 CPU,以便评估上线后我们需要部署多少台服...【详细内容】
2022-11-30  Tags: CPU  点击:(42)  评论:(0)  加入收藏
如果CPU风扇出现问题,那么笔记本电脑就容易出现蓝屏、死机等。那么,笔记本cpu风扇转速多少才算正常呢?其实,CPU风扇的转速多少正常并没有一个固定值,只能大概给出一个范围。因为...【详细内容】
2022-11-26  Tags: CPU  点击:(48)  评论:(0)  加入收藏
CPU也称为微处理器或简称为处理器。就像大脑如何控制人体一样,CPU 控制着计算机的所有部分。因此cpu被认为是计算机的大脑。那我们怎么在Linux系统中查看如 Intel Core i3、i...【详细内容】
2022-11-24  Tags: CPU  点击:(118)  评论:(0)  加入收藏
▌简易百科推荐
这里就不麻烦地建 Web 项目了,用一个最原始的 Java 项目来模拟高 CPU 场景。打开 IDEA,创建一个 Java 项目,里面写一个死循环,循环里面不断地创建对象。相比于一大堆复杂的 JVM...【详细内容】
2023-03-06  飞天小牛肉  微信公众号  Tags:CPU   点击:(0)  评论:(0)  加入收藏
如今越来越多的网站已经开始安装SSL证书,只要安装ssl证书之后,可以保障网站的数据安全,关于ssl证书的内容,之前已经介绍过很多了,今天为大家讲解的是Nginx 301永久重定向配置以及...【详细内容】
2023-03-03  沃通WoTrus  今日头条  Tags:Ngnix   点击:(7)  评论:(0)  加入收藏
ChatGPT发布之后,引发了全球范围的关注和讨论,国内各大厂商相继宣布GPT模型开发计划。据各公司官网,2023年2月7日,百度宣布将推出ChatGPT类似产品“文心一言”,预计今年3月展开内...【详细内容】
2023-03-02  架构师技术联盟    Tags:ChatGPT   点击:(7)  评论:(0)  加入收藏
本文分享自华为云社区《【平滑上云】Apache Sentry->Ranger平滑升级方案-云社区-华为云》,作者: 啊喔YeYe 。背景介绍 CDH是Apache Hadoop和相关项目的最完整、最受测试和最...【详细内容】
2023-02-28  蒲公英互联    Tags:Apache   点击:(18)  评论:(0)  加入收藏
哈喽,大家好,我是指北君。最近项目中准备使用消息中间件Apache Pulsar,借着机会先做个简单了解吧。Apache PulsarApache Pulsar是Apache软件基金会顶级项目,是下一代云原生分布...【详细内容】
2023-02-28  Java技术指北    Tags:MQ   点击:(11)  评论:(0)  加入收藏
微信小程序因官方需求文档要求后台使用HTTPS请求进行网络通信,不满足条件的域名和协议无法请求。越来越多的开发者纷纷使用SSL证书实践微信小程序的应用情况,但仍然会碰到各种...【详细内容】
2023-02-28  沃通WoTrus    Tags:HTTPS   点击:(7)  评论:(0)  加入收藏
Nginx是一个高性能的Web服务器,它可以用来进行反向代理和负载均衡。在本文中,我们将深入探讨Nginx反向代理和负载均衡的概念、作用以及实现方式。一、什么是Nginx反向代理?在理...【详细内容】
2023-02-24  Java编程世界  今日头条  Tags:Nginx   点击:(14)  评论:(0)  加入收藏
您的Apache HTTP服务器生成的日志数据是信息的宝库。使用这些信息,您可以判断您服务器的使用情况、找出漏洞所在,并设法改进服务器结构和整体性能。审核您的Apache日志可在以...【详细内容】
2023-02-16  运维有小邓    Tags:Apache   点击:(29)  评论:(0)  加入收藏
作为软件的程序员,一直想搞一台属于自己的服务器用来在业余时间折腾。可能有人会说,为啥不在公有云上申请一个,多简单。那我们就先看看公有云上一台同样配置(笔记本的配置是4C8G...【详细内容】
2023-02-13  星河18实验室  今日头条  Tags:服务器   点击:(26)  评论:(0)  加入收藏
提示如果您刚刚接触Buddy, 推荐先查看 >>快速上手<< 以便轻易了解如何构建、测试与部署您的应用类型。Buddy将部署变得轻而易举,允许您在每次推送到分支时自动更新服务器。...【详细内容】
2023-02-08  東正科技  今日头条  Tags:服务器   点击:(25)  评论:(0)  加入收藏
站内最新
站内热门
站内头条