【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>

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

相关推荐
乌萨奇也要立志学C++12 小时前
【Linux】线程同步 条件变量精讲 + 生产者消费者模型完整实现
java·linux·运维
澄澈青空~12 小时前
病毒木马侵入系统内核的底层运作机理
java·linux·服务器
superman超哥12 小时前
Rust 异步性能的黑盒与透视:Tokio 监控与调优实战
开发语言·后端·rust·编程语言·rust异步性能·rust黑盒与透视·tokio监控与调优
lkbhua莱克瓦2412 小时前
进阶-存储对象2-存储过程上
java·开发语言·数据库·sql·mysql
杨杨杨大侠12 小时前
深入理解 LLVM:从编译器原理到 JIT 实战
java·jvm·编译器
Mr -老鬼12 小时前
Rust 知识图谱 -进阶部分
开发语言·后端·rust
qq_3363139313 小时前
java基础-IO流(随机点名器)
java·开发语言·python
guchen6613 小时前
CircularBuffer 优化历程:从数组越界到线程安全的完美实现
后端
古城小栈13 小时前
Cargo.toml
开发语言·后端·rust
brave_zhao13 小时前
launch4j亲测打包java的jar转为exe执行文件
java