linux下cpu飙高原因排查过程详解

 更新时间:2021年11月30日 11:04:43   作者:负债程序猿  
大家好,本篇文章主要讲的是linux下cpu飙高原因排查过程详解,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下哦

前言

cpu飙高是很常见的线上问题,这都不会的话,属实有点拉跨

在这里插入图片描述

兄弟萌不用慌,来我教你一套连招

开始

先来个项目,整个api,到时候我们请求/cpu/{count}就能手动拉高cpu,机智鬼~

    @GetMapping("/cpu/{count}")
    public long cpuTest(@PathVariable("count") long count) {
        long number = 0;
        for (int i = 0; i < count; i++) {
            number++;
        }
        return number;
    }

打包、上传、启动

在这里插入图片描述

跑起来了,记住这个进程号 14849

我们先top看看正常情况下的cpu使用率

在这里插入图片描述

很合理

模拟线上cpu飙高

我们请求/cpu/{100000000000}接口,把cpu拉起来,同时top观察cpu使用率

在这里插入图片描述

直接干到98%,很nice

ok入戏,我们现在线上出问题了,cpu一直很高,老大叫你找找原因,开始支棱起来

其实我们现在已经知道是谁把cpu拉高了,但还不够细,只知道哪个项目出的问题远远不够,我们应该找到罪魁祸首,到底是哪个方法的多少行导致的问题,这才能让老大直呼内行

步骤

jps+top 定位应用进程

pidtop -Hp {pid}找到线程tid

将 tid 转换成十六进制 printf “%x\n” {tid}

打印堆栈信息 jstack

过滤出我们想要的

排查

进程id已经确定是 14849,下一步我们要找到是哪个线程搞的鬼

top -Hp 14849

在这里插入图片描述

很明显是这个14908搞的鬼

转十六进制

在这里插入图片描述

打印堆栈

在这里插入图片描述

堆栈信息显示是TestController里面的第20行出的幺蛾子,我们进入代码验证

在这里插入图片描述

问题不大

破案

撒花

到此这篇关于linux下cpu飙高原因排查过程详解的文章就介绍到这了,更多相关linux cpu飙高原因排查内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 详解阿里云CentOS Linux服务器上用postfix搭建邮件服务器

    详解阿里云CentOS Linux服务器上用postfix搭建邮件服务器

    本篇文章主要介绍了详解阿里云CentOS Linux服务器上用postfix搭建邮件服务器,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2016-12-12
  • Ubuntu18.04安装Nvidia显卡驱动教程(图文)

    Ubuntu18.04安装Nvidia显卡驱动教程(图文)

    这篇文章主要介绍了Ubuntu18.04安装Nvidia显卡驱动教程(图文),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • 浅谈互斥锁为什么还要和条件变量配合使用

    浅谈互斥锁为什么还要和条件变量配合使用

    下面小编就为大家带来一篇浅谈互斥锁为什么还要和条件变量配合使用。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01
  • CentOS 7安装Mysql并设置开机自启动的方法

    CentOS 7安装Mysql并设置开机自启动的方法

    本篇文章主要介绍了CentOS 7安装Mysql并设置开机自启动的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-02-02
  • Centos7.2 系统上yum安装lamp环境

    Centos7.2 系统上yum安装lamp环境

    这篇文章主要介绍了centos7.2 系统上yum安装lamp环境的相关资料,非常不错具有参考借鉴价值,需要的朋友可以参考下
    2016-11-11
  • CentOS7 修改网卡名称为eth0&在VMWare中添加多网卡配置

    CentOS7 修改网卡名称为eth0&在VMWare中添加多网卡配置

    这篇文章主要介绍了CentOS7 修改网卡名称为eth0&在VMWare中添加多网卡配置,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2017-03-03
  • CentOS7设置ssh服务以及端口修改方式

    CentOS7设置ssh服务以及端口修改方式

    这篇文章主要介绍了CentOS7设置ssh服务以及端口修改方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • 详解Lamp环境搭建Linux CentOS6.5编译安装mysql5.6

    详解Lamp环境搭建Linux CentOS6.5编译安装mysql5.6

    这篇文章主要介绍了详解Lamp环境搭建Linux CentOS6.5编译安装mysql5.6,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • centos系统修改创建文件夹目录的显示颜色

    centos系统修改创建文件夹目录的显示颜色

    大家应该都知道在Linux系统中ls文件夹的痛苦我就不说了,为了不伤眼睛,一般ssh终端背景都用的黑色,文件夹又是深蓝色,每次看文件夹都要探头仔细去看。这篇文章给大家介绍如何修改改创建文件夹目录的显示颜色,有需要的朋友们可以参考借鉴,下面来一起看看吧。
    2016-11-11
  • 利用Linux防火墙隔离本地欺骗地址的方法详解

    利用Linux防火墙隔离本地欺骗地址的方法详解

    防火墙,其实说白了讲,就是用于实现Linux下访问控制的功能的,它分为硬件的或者软件的防火墙两种。下面这篇文章主要给大家介绍了关于如何利用Linux防火墙隔离本地欺骗地址的相关资料,文中介绍的非常详细,需要的朋友可以参考下
    2018-05-05

最新评论