线上服务器CPU占用过高,简单7步给你搞定
一. 前言
在Java开发岗位的面试中,时不时会出现一些运维类的题目,其实这也反映了后端面试的一种趋势。现在企业对后端开发的要求越来越全面,不仅要求我们会写代码,还要我们能够进行部署和运维。
今天九哥就结合一个真实的项目案例,来给大家讲解一道关于运维类的真实面试题。题目如下:有一个SpringBoot项目上线后,发现其部署所在的Linux服务器CPU占用过高,该如何排查解决?
这是一道比较常见的线上排错问题,接下来就让我们我们来分析一下这个问题的解决过程吧。
二. 解决过程
问题要点
该问题包含如下两个要点:
- 如何观察Linux服务器CPU占比;
- 如何定位到产生问题的Java代码所在线程,判断出当前问题线程到底在执行什么方法。
排查过程
2.1 通过top命令找到CPU消耗过高的进程id
如上图,我们发现CPU占用高的进程pid为71288。
2.2 通过jps输出,配合上面的pid定位到出现问题的具体应用
2.3 执行top -p pid 单独监控该进程
2.4 监控界面输入H,获取当前进程下所有的线程信息,找到CPU消耗特别高的线程编号
由于Java是多线程程序,如果我们只知道进程id还不足以找到出现问题的线程。因此这里需要借助top命令的H交互模式,找到真正CPU占用过高的线程。本案例中的pid是71289,那么接下来距离找出出问题 的方法已经不远了。
2.5 jstack输出线程信息
这一步也是定位问题的关键。jstack命令能够打印出当前所有java栈中的线程信息,其中必然包括出问题的线程。剩下我们要做的就是根据线程的id,找到这个线程正在执行的方法即可。这里71289是十进制整数,而jstack日志中的线程id是十六进制,因此需要做以下转换。
2.6 打开刚刚生成的jstack日志文件,查找关键字 11679
2.7 根据日志,发现出问题的代码在 FmmallApp类的 第14行。
至此,我们就把问题定位完成了,接下来就可以去源代码中进行核对了。
三. 相关命令总结
本文中,我们所使用的Linux服务器端操作命令如下:
以后如果你再遇到线上服务器出现故障,知道该怎么解决了吗?如果你还有其他问题,可以在评论区留言哦。
欢迎咨询千锋教育在线老师。千锋教育拥有多年IT培训服务经验,采用全程面授高品质、高体验培养模式,拥有国内一体化教学管理及学员服务,助力更多学员实现高薪梦想。
相关推荐HOT
更多>>如何添加Java环境变量?
要添加Java环境变量,可以按照以下步骤:并安装Java开发工具包(JDK)、找到Java安装路径、设置JAVA_HOME环境变量、添加Java可执行文件路径到PATH...详情>>
2023-05-04 11:00:56从零开始学Java之String字符串的编码
对很多小白来说,可能不明白什么是字符编码,也不知道为什么要有字符编码,所以先来给大家简要地介绍一下字符编码。详情>>
2023-05-04 10:21:02新手速来!几步带你掌握MyBatis Plus
Mybatis-Plus(简称MP)是一款Mybatis的增强工具,它是在Mybatis的基础上实现的简化开发工具。Mybatis-Plus给我们提供了开箱即用的CRUD操作、自动...详情>>
2023-04-28 10:57:09学习java需要什么基础?基础知识有哪些?
网络编程:了解基本的网络编程概念和协议,熟悉 Java 网络编程 API。建议在学习 Java 之前,先学习一些基础的编程语言,如 C 或 Python 等,这...详情>>
2023-04-28 10:41:14