面试问题---JAVA程序CPU占用过高怎么定位

简介:

面试问题---JAVA程序CPU占用过高怎么定位

今天一个电话面试问了这个问题。回来查了下答案,自己也顺带操作一遍,做个记录。之前只知道jstack工具可以查看线程状态这些。比如死锁这些,主要是之前不知道top -H -p pid这个命令的使用,这命令可以看到进程下面线程信息,拿到线程ID,然后再结合jstack命令使用就可以解决这个问题了。下面记录一下具体的操作步骤:

1.打个jar包丢到机器上运行

package com.nijunyang.test;

public class TestApplication {

public static void main(String[] args) {
    for (int i = 0; i < 50; i++) {
        new Thread(()->test()).start();
    }

}

public static void test() {
    while (true) {
        int a = 1  + 6;
        System.out.println(a);
    }
}

}

使用这个maven插件 打包jar

        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-assembly-plugin</artifactId>
            <configuration>
                <archive>
                    <manifest>
                        <mainClass>com.nijunyang.test.TestApplication</mainClass>
                    </manifest>
                </archive>
                <descriptorRefs>
                    <descriptorRef>jar-with-dependencies</descriptorRef>
                </descriptorRefs>
            </configuration>
            <executions>
                <execution>
                    <id>make-assembly</id>
                    <phase>package</phase>
                    <goals>
                        <goal>single</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>
  1. java -jar test-0.0.1-SNAPSHOT-jar-with-dependencies.jar  运行程序

一直在输出

3.top |grep java  或者 jps指令找到java进程的pid(6167)

4. top -H -p pid   以线程的形式查看该进程 top -H -p 6167

因为我们程序是起了50个线程 所以这里就会展示这个进程中的所有线程呢

5.前面的线程ID是10进制的,,需要转换成16进制,,因为等下在jstack命令取出来的线程ID是16进制的:这里就随便选一个线程ID 去转换了,真实环境肯定是选择CPU占用率最高的那个线程,echo "obase=16;6219" | bc

6.jstack 6167 >threadInfo.txt   信息输出到文件 然后查看。也可以直接在命令里面查看

7.文件中查找184b的线程ID信息,就可以找到是哪个线程导致的内存占用过高,同时也能看到具体的代码位置

原文地址https://www.cnblogs.com/nijunyang/p/13040511.html

相关文章
|
10天前
|
缓存 C语言 计算机视觉
程序与技术分享:CPU0处理器的架构及应用
程序与技术分享:CPU0处理器的架构及应用
|
5天前
|
监控 负载均衡 Java
如何设计高可用性的Java Web应用程序
如何设计高可用性的Java Web应用程序
|
9天前
|
SQL 存储 前端开发
程序技术好文:面试知识点六:JavaWeb
程序技术好文:面试知识点六:JavaWeb
10 1
|
2天前
|
Java 调度 Windows
Java面试之程序、进程、线程、管程和并发、并行的概念
Java面试之程序、进程、线程、管程和并发、并行的概念
8 0
|
6天前
|
Java
【Java】程序练习1(数组)
【Java】程序练习1(数组)
|
10天前
|
Java UED 开发者
JVM逃逸分析原理解析:优化Java程序性能和内存利用效率
JVM逃逸分析原理解析:优化Java程序性能和内存利用效率
|
10天前
|
机器学习/深度学习 并行计算 搜索推荐
程序技术好文:桶排序算法及其Java实现
程序技术好文:桶排序算法及其Java实现
|
11天前
|
机器学习/深度学习 Java 程序员
Java递归函数:穿越程序世界的神奇之门
Java递归函数:穿越程序世界的神奇之门
|
12天前
|
人工智能 Java BI
Java程序代码实现的实例总结
Java程序代码实现的实例总结
15 0
|
13天前
|
人工智能 算法 搜索推荐
Java算法编程详解和程序实例
Java算法编程详解和程序实例
15 0