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

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

相关推荐
多则惑少则明几秒前
AI大模型实用(五)Java快速实现智能体整理(LangChain4j构建Java AI智能体)
java·ai大模型
uup4 分钟前
字符串比较的经典坑:== vs equals
java
资源站shanxueit或com8 分钟前
Python入门教程:从零到实战的保姆级指南(避坑大全) 原创
后端
悟能不能悟8 分钟前
Java 中将 List 中对象的某一列转换为 Set
java·开发语言·list
越千年10 分钟前
工作中常用到的二进制运算
后端·go
转转技术团队13 分钟前
转转大数据与AI——数据治理安全打标实践
大数据·人工智能·后端
利刃大大17 分钟前
【SpringBoot】SpringMVC && 请求注解详解 && 响应注解详解 && Lombok
java·spring boot·后端
BBB努力学习程序设计21 分钟前
Java注解(Annotation)深度解析:从元编程到框架设计
java
梨子同志23 分钟前
Java 介绍与开发环境安装
后端
2501_9167665427 分钟前
【SpringMVC】实现文件上传
java·spring