如何定位线上CPU占用过高的问题

news2024/9/22 21:27:59

系列文章目录


文章目录

  • 系列文章目录
  • 前言
  • 一、定位CPU的流程是什么?
  • 二、实操
    • 1.测试代码样例
    • 2.定位问题实践过程
  • 总结


前言


一、定位CPU的流程是什么?

项目上线,CPU飙高不下,触发报警,如何定位排查问题。有两种办法1、通过堆栈 2、通过火焰图(本文略)
1、top查看进程占用率最高的进程
2、ps -mp pid定位到进程中cpu占用最高的线程
ps -mp 1153 -o THREAD,tid,pid
3、pstack 打印堆栈调用

二、实操

1.测试代码样例

#include <iostread>
#include <thread>

void test1()
{
    while(1){
        sleep(0.1);
    }
}
void test2()
{
    while(1){
        sleep(10);
    }
}

void dbdemo()
{
    std::thread(test1).detach();    
    std::thread(test2).detach(); 
}

int main()
{
	dbdemo();
	return 0;
}

2.定位问题实践过程

1、top查出占用率高的进程DBclient的Pid 5896
在这里插入图片描述
2、ps -mp 5869 -o THREAD,tid,pid 查出DBclient进程中占用率过高的Tid,5900,转为16进制0x170C
在这里插入图片描述
3、pstack 5896,找到对应5900的线程,即可发现调用栈
发现线程4调用关系,test1中sleep函数导致cpu占用过高,
#0 0x00007fa889545626 in sleep () from /lib64/libc.so.6
#1 0x000000000042dd35 in test1() ()

[root@localhost ~]# pstack 5896
Thread 6 (Thread 0x7fa88616e700 (LWP 5897)):
#0  0x00007fa88954585d in nanosleep () from /lib64/libc.so.6
#1  0x00007fa889576134 in usleep () from /lib64/libc.so.6
#2  0x00007fa88ab51422 in bvar::detail::SamplerCollector::run (this=0x16d9b40) at /opt/data/code/vplatform_thirdparty/BRPC-1.0.0-rc02/src/bvar/detail/sampler.cpp:180
#3  0x00007fa88ab51f49 in bvar::detail::SamplerCollector::sampling_thread (arg=<optimized out>) at /opt/data/code/vplatform_thirdparty/BRPC-1.0.0-rc02/src/bvar/detail/sampler.cpp:110
#4  0x00007fa88a075ea5 in start_thread () from /lib64/libpthread.so.0
#5  0x00007fa88957e96d in clone () from /lib64/libc.so.6
Thread 5 (Thread 0x7fa88596d700 (LWP 5898)):
#0  0x00007fa889573c3d in poll () from /lib64/libc.so.6
#1  0x00007fa887a33948 in mongoc_socket_poll () from /home/vagrant/Mycode/DBClient/../libs/gcc_lib/libmongoc-1.0.so.0
#2  0x00007fa887a36627 in _mongoc_stream_socket_poll () from /home/vagrant/Mycode/DBClient/../libs/gcc_lib/libmongoc-1.0.so.0
#3  0x00007fa887a35815 in mongoc_stream_poll () from /home/vagrant/Mycode/DBClient/../libs/gcc_lib/libmongoc-1.0.so.0
#4  0x00007fa887a31cbb in _server_monitor_awaitable_ismaster_recv () from /home/vagrant/Mycode/DBClient/../libs/gcc_lib/libmongoc-1.0.so.0
#5  0x00007fa887a32208 in mongoc_server_monitor_check_server () from /home/vagrant/Mycode/DBClient/../libs/gcc_lib/libmongoc-1.0.so.0
#6  0x00007fa887a32c12 in _server_monitor_thread () from /home/vagrant/Mycode/DBClient/../libs/gcc_lib/libmongoc-1.0.so.0
#7  0x00007fa88a075ea5 in start_thread () from /lib64/libpthread.so.0
#8  0x00007fa88957e96d in clone () from /lib64/libc.so.6
Thread 4 (Thread 0x7fa88516c700 (LWP 5900)):
#0  0x00007fa889545626 in sleep () from /lib64/libc.so.6
#1  0x000000000042dd35 in test1() ()
#2  0x0000000000433e73 in void std::_Bind_simple<void (*())()>::_M_invoke<>(std::_Index_tuple<>) ()
#3  0x0000000000433dcd in std::_Bind_simple<void (*())()>::operator()() ()
#4  0x0000000000433d66 in std::thread::_Impl<std::_Bind_simple<void (*())()> >::_M_run() ()
#5  0x00007fa889e1b330 in ?? () from /lib64/libstdc++.so.6
#6  0x00007fa88a075ea5 in start_thread () from /lib64/libpthread.so.0
#7  0x00007fa88957e96d in clone () from /lib64/libc.so.6
Thread 3 (Thread 0x7fa88496b700 (LWP 5901)):
#0  0x00007fa88954585d in nanosleep () from /lib64/libc.so.6
#1  0x00007fa8895456f4 in sleep () from /lib64/libc.so.6
#2  0x000000000042dd45 in test2() ()
#3  0x0000000000433e73 in void std::_Bind_simple<void (*())()>::_M_invoke<>(std::_Index_tuple<>) ()
#4  0x0000000000433dcd in std::_Bind_simple<void (*())()>::operator()() ()
#5  0x0000000000433d66 in std::thread::_Impl<std::_Bind_simple<void (*())()> >::_M_run() ()
#6  0x00007fa889e1b330 in ?? () from /lib64/libstdc++.so.6
#7  0x00007fa88a075ea5 in start_thread () from /lib64/libpthread.so.0
#8  0x00007fa88957e96d in clone () from /lib64/libc.so.6
Thread 2 (Thread 0x7fa87ffff700 (LWP 5902)):
#0  0x00007fa88a079de2 in pthread_cond_timedwait@@GLIBC_2.3.2 () from /lib64/libpthread.so.0
#1  0x00007fa887a32b69 in mongoc_server_monitor_wait () from /home/vagrant/Mycode/DBClient/../libs/gcc_lib/libmongoc-1.0.so.0
#2  0x00007fa887a32dc2 in _server_monitor_rtt_thread () from /home/vagrant/Mycode/DBClient/../libs/gcc_lib/libmongoc-1.0.so.0
#3  0x00007fa88a075ea5 in start_thread () from /lib64/libpthread.so.0
#4  0x00007fa88957e96d in clone () from /lib64/libc.so.6
Thread 1 (Thread 0x7fa88bd6ab80 (LWP 5896)):
#0  0x00007fa88954585d in nanosleep () from /lib64/libc.so.6
#1  0x00007fa8895456f4 in sleep () from /lib64/libc.so.6
#2  0x000000000042deba in main ()
[root@localhost ~]# 


总结

如果你对线上进程cpu飙高不知道如何定位,可以通过本文尝试一下,希望对你有所帮助。

老铁,如果觉得不错,请点赞收藏。

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

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

相关文章

JVM内存布局及GC原理

“java的内存布局以及GC原理”是java开发人员绕不开的话题&#xff0c;也是面试中常见的高频问题之一。 java发展历史上出现过很多垃圾回收器&#xff0c;各有各的适应场景&#xff0c;很多网上的旧文章已经跟不上最新的变化。本文详细介绍了java的内存布局以及各种垃圾回收器的…

著名运动员刘诗雯从政,迎来人生高光时刻,张继科还般配吗

曾经有这么一句话&#xff1a;中国男足谁都踢不过&#xff0c;中国乒乓球谁都打不过。也间接地说明了国球队伍人才济济。在众多优秀乒乓球队员当中&#xff0c;刘诗雯最近相当耀眼&#xff0c;听说她已经高升当官了&#xff0c;也和张继科拉开了距离。 据悉&#xff0c;公元202…

Java高效率复习-数据类型和运算符[Java]

第一篇关于JavaSE内容的文章 文章的风格比较涣散&#xff0c;但是都是干货&#xff0c;关于Java系列的&#xff0c;还有就是&#xff0c;我认为只有MySQL基础和JavaSE基础是可以做到可操作性和可执行性较强的。 如果像JavaWeb或者SSM框架这些&#xff0c;光看文章你是根本执行…

tensorflow的GPU加速计算

参考 tensorflow的GPU加速计算 - 云社区 - 腾讯云 一、概述 tensorflow程序可以通过tf.device函数来指定运行每一个操作的设备&#xff0c;这个设备可以是本地的CPU或者GPU&#xff0c;也可以是某一台远程的服务器。tensorflow会给每一个可用的设备一个名称&#xff0c;tf.…

PaO2/FiO2在临床中的应用 氧合指数

主任提问:患者呼吸衰竭时的“氧合指数”大约多少?如何计算?_腾讯新闻 (qq.com) 在 ARDS 柏林定义中,诊断低氧血症需要 PaO2/FiO2≤ 300 mmHg,并可以分为轻中重三个等级(下表)。 ARDS 患者的 PaO2/FiO2越低,死亡率越高,其中重度 ARDS 死亡率高达 45%。需要注意这里 …

生产报工管理系统可以帮助企业解决哪些问题?

随着时代的变迁和信息化技术的发展&#xff0c;市场对制造企业在产品价格、质量以及生产成本等方面提出了更高的要求&#xff0c;车间生产也逐渐向着实时化、透明化和可视化方向发展。其中产报工与跟踪是生产管理中重要的环节&#xff0c;自然是不可缺少信息化的。 企业在报工…

Linux基本命令

目录操作 格式&#xff1a;指令 -[参数] [目录] 1. pwd (Print Working Direcotry) 查看当前工作路径 2. cd (Change Direcotry) 改变 shell 工作目录 3. ls (List Files) 列出当前目录下的文件和目录 ls -[参数] [目录] ls的参数均是短命令&#xff0c;可以使用-后添…

经过物联网技术的设备改造有“大脑”,更智能

物联网是通讯网与互联网的拓展应用和网络延伸&#xff0c;通过网络传输互联&#xff0c;进行计算、处理和知识挖掘&#xff0c;实现人与物、物与物的信息交互和无缝链接&#xff0c;达到对物理世界的实时控制、精确管理和科学决策是目的。而物联网设备是一种非标准计算设备&…

【微信小程序】使用npm并引入vant-weapp组件库

0 前言 vant文档与微信小程序文档写得弯弯绕绕&#xff0c;你引用我&#xff0c;我引用你&#xff0c;还给出了多种不同情况下的选项&#xff0c;甚至有步骤缺失&#xff0c;导致踩了一点小坑&#xff0c;浪费了一些没必要的时间&#xff0c;这里给出完整可行的实现方法&#…

Android Studio详细的安装下载教程

一、下载Android Studio 1、进入官网在这个位置&#xff0c;点击左下角下载Android Studio 官网&#xff1a;www.Android.com 中国大陆版网站&#xff1a;&#xff1a;https://developer.android.google.cn/ 2、Android Studio会自带自动下载Android SDK&#xff0c;如果有版本…

SIM8100、SIM8800CE、SIM8800E 车规级模组 特性

1、SIM8100 是一个C-V2X模块&#xff0c;通过PC5接口支持C-V2X功能&#xff0c;实现车对车(V2V)、车对人(V2P)、车对基础设施(V2I)等应用。 SIM8100具有强大的扩展能力和丰富的接口&#xff0c;包括USB, UART, SDIO,I2C,I2S,SPI, GPIO等。 该模块为客户的应用程序提供了很大的灵…

Vue--》动态组件和插槽的使用讲解

目录 动态组件 keep-alive使用 keep-alive的include和exclude属性 插槽 动态组件 动态组件指的是动态切换组件的显示与隐藏&#xff0c;vue提供了一个内置的<component>组件&#xff0c;专门用来实现动态组件的渲染。什么意思呢&#xff1f;接着往下看&#xff1a; …

类和对象之 封装 继承 与 多态

1.进行类继承的前提是我们要有两个类&#xff0c;且已经确定好了这两个类谁为父类谁为子类 2.先创建父类然后再创建子类 3.创建子类的时候我们要使用继承语法&#xff0c;使用的方式是在创建子类时的第一条代码的最后面加上冒号 : 和父类的类名 4.继承的本质就是将父类中的…

[附源码]Python计算机毕业设计Django药品仓库及预警管理系统

项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等等。 环境需要 1.运行环境&#xff1a;最好是python3.7.7&#xff0c;…

【Vue基本功】权限路由(1)

1 初始化项目 1.1 安装 yarn create vite … yarn 依赖&#xff1a; yarn add axios yarn add vuexnext vue-router4 -D yarn add typesvue-router -D vuex有ts支持&#xff0c;所以不需要安装类型文件 1.2 配置 1.2.1 别名 引入path时&#xff0c;发现有警告&#x…

Spring MVC 高级框架的核心

目录 1. 什么是 Spring MVC 1.1 如何理解 MVC 1.2 Spring MVC 和 MVC 的关系 2. 如何学习 Spring MVC 2.1 将浏览器和服务器连接起来 2.1.1 RequestMapping, GetMapping, PostMapping 三个注解的区别 2.2 在程序中获取前端传递过来的参数 2.2.1 传递单个参数 2.2.2 传…

CSS 实现音频loding动画

前言 &#x1f44f;实现一个音频loading动画还蛮有趣的&#xff0c;速速来Get吧~ &#x1f947;文末分享源代码。记得点赞关注收藏&#xff01; 1.实现效果 2.实现步骤 定义css变量&#xff1a;父容器高度为–h&#xff0c;可以动态设置loading的高度 :root {--h: 80px;}父…

遗传算法在机器人路径规划中的应用研究(Matlab代码实现)

目录 &#x1f4a5;1 概述 &#x1f4da;2 运行结果 &#x1f389;3 参考文献 &#x1f468;‍&#x1f4bb;4 Matlab代码 &#x1f4a5;1 概述 机器人运动规划是移动机器人导航的核心技术之一。40多年来,运动规划技术发展迅速,涌现出了许多规划算法,但因为环境描述方式差异…

JavaScript -- 数组及对象解构赋值方法总结

文章目录1 数组解构赋值1.1 保留默认值1.2 接受剩余的所有参数1.3 对函数执行结果解构1.4 交换两个变量的值1.5 二维数组结构2 对象的解构2.1 声明对象同时解构对象2.2 先声明再解构2.3 解构不存在的属性2.4 设置解构别名2.5 设置解构默认值1 数组解构赋值 案例&#xff1a;将…

红队隧道应用篇之Netsh端口转发

简介 netsh是从Windows 2000开始就有的一个用于配置网络设备的命令行工具 其中netsh interface portproxy是一个配置网络代理的命令, 可以配置ipv4或ipv6的端口转发代理以及双向端口转发代理 学习隧道应用前必须了解的知识:https://blog.csdn.net/xf555er/article/details/1…