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

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

相关推荐
qqacj12 小时前
Spring Security 官网文档学习
java·学习·spring
Rsun0455112 小时前
10、Java 桥接模式从入门到实战
java·开发语言·桥接模式
金銀銅鐵12 小时前
[Java] 从 class 文件看 cglib 对 MethodInterceptor 的处理 (下)
java·后端
lee_curry12 小时前
Java中关于“锁”的那些事
java·线程·并发·juc
pearlthriving12 小时前
c++当中的泛型思想以及c++11部分新特性
java·开发语言·c++
Walter先生13 小时前
WebSocket 连接池生产级实现:实时行情高可用与负载均衡
后端·websocket·架构
梦魇星虹13 小时前
idea Cannot find declaration to go to
java·ide·intellij-idea
小雅痞13 小时前
[Java][Leetcode hard] 42. 接雨水
java·开发语言·leetcode
xfcoding13 小时前
关于代码注释的思考
java
虹梦未来13 小时前
【开发心得】在SpringBoot体系中正确使用redisConfig
java·spring boot·spring