【Java面试】服务器CPU使用率飙升,如何排查?

简介

如果碰到服务器CPU使用率飙升,居高不下,该如何定位排查问题呢?

本文带大家实践一下,在使用Java时,碰到服务器CPU飙升该如何定位到具体的问题代码!

准备工作

1、代码准备

Main.java

java 复制代码
public class Main {
    public static void main(String[] args) {
        System.out.println("Hello world!");
        circle();
    }

    public static void circle() {
        while (true) {

        }
    }
}

这里写一个circle方法,方法里面是一个while死循环。

2、在服务器上编译运行代码

java 复制代码
javac Main.java
java Main

查看CPU占用进程

bash 复制代码
top

找到异常的进程号

定位异常线程

通过命令

bash 复制代码
top -Hp <pid>

定位异常线程

线程号转为16进制

bash 复制代码
printf %x <tid>

jstack定位异常代码

bash 复制代码
jstack <pid> |grep -A 200 <16进制tid>

根据类名和行号,即可定位到问题代码

相关推荐
Moonbit7 分钟前
月报Vol.03: 新增Bitstring pattern支持,构造器模式匹配增强
后端·算法·github
用户3721574261358 分钟前
Python 实现 HTML 转 Word 和 PDF
java
a587699 分钟前
Java核心概念精讲:TCP与UDP的区别、Java NIO的几个核心组件与HTTP和HTTPS的区别等(46-50)
java·面试·nio
中等生15 分钟前
Pandas 与 NumPy:数据分析中的黄金搭档
后端·python
渣哥27 分钟前
ConcurrentHashMap 的 get 要不要加锁?一次“多此一举”的心路历程
java
用户83562907805127 分钟前
Python查找替换PDF文字:告别手动,拥抱自动化
后端·python
小猪乔治爱打球28 分钟前
[Golang 修仙之路] 分布式专题:分布式锁
后端·面试
似水流年流不尽思念29 分钟前
LBCC和MVCC的区别和优缺点
后端
愿你天黑有灯下雨有伞35 分钟前
一种基于注解与AOP的Spring Boot接口限流防刷方案
java·spring boot·后端
MuMuMu#41 分钟前
JAVA NIO学习笔记基础强化学习总结
java·学习·nio