利用工具JStack排查:死锁问题和CPU100%问题

        无论是再面试过程中还是再实际项目开发当中我们都有可能遇到这两个问题。我之前有同学面试这两个问题都有问道过。哈哈哈。所以我绝对把他们了解下并利用博客记录。

1、工具JStack是什么?

        JStack可以显示Java应用程序中每个线程的堆栈跟踪,帮助开发人员诊断线程相关的问题,比如死锁和性能问题。通过使用JStack,开发人员可以查看线程的状态、锁定信息以及线程调用堆栈,从而更好地理解应用程序的运行状况。

命令介绍:

  1. jstack [-l] <pid>:这个命令会生成指定Java进程的线程转储。-l选项会同时显示关于锁的附加信息。
  2. jstack -F [-m] [-l] <pid>:这个命令会在Java进程响应时生成线程转储。-m选项会同时显示Java和本地堆栈信息。

  3. jstack -m [-l] <pid>:这个命令会同时显示Java和本地堆栈信息。

  4. jstack -h:这个命令会显示帮助信息,列出所有可用的选项。

再其中有两个名词java堆栈、本地堆栈,可能有些不太理解:

  1. Java堆栈信息:显示了每个线程在Java虚拟机中的调用堆栈。这些信息包括了线程当前执行的方法、类名等。

  2. 本地堆栈信息:显示了每个线程在本地方法中的调用堆栈。本地方法是使用本地语言(如C或C++)编写的方法,通常用于与操作系统或硬件交互。

2、解决死锁问题

解决死锁问题我们最先就要定位到哪里发生了死锁。我先准备一段一定发生死锁的程序,然后让他再服务器运行,然后我们来利用工具JStack来定位死锁。

public class Demo {
 static Lock lock1 = new ReentrantLock();
 static Lock lock2 = new ReentrantLock();
 public static void deathLock() {
            Thread t1 = new Thread() {
                @Override
                public void run() {
                    try {
                        lock1.lock();
                        System.out.println(Thread.currentThread().getName() + " get the lock1");
                        Thread.sleep(1000);
                        lock2.lock();
                        System.out.println(Thread.currentThread().getName() + " get the lock2");
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            };
            Thread t2 = new Thread() {
                @Override
                public void run() {
                    try {
                        lock2.lock();
                        System.out.println(Thread.currentThread().getName() + " get the lock2");
                        Thread.sleep(1000);
                        lock1.lock();
                        System.out.println(Thread.currentThread().getName() + " get the lock1");
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            };
            //设置线程名字,方便分析堆栈信息
            t1.setName("mythread-jay");
            t2.setName("mythread-tianluo");
            t1.start();
            t2.start();
        }
public static void main(String[] args) {

        deathLock();
    }
}

再代码中线程“mythread-jay”持有锁lock1等待lock2,"mythread-tianluo"线程持有lock2等待lock1 。那么这两个线程就会尝试死锁。互相等待。

此时我们通过jps命令查看这个进程的进程号:

那么此时我们得知了进程号就可以 使用JStack工具了。

那么我们就得到了一大串的字符描述进程执行情况,那么我们去找关于这两个线程的信息,由下面两张图我们可以看出两个线程都处于Wait状态,造成了死锁的情况,这个工具原原本本的给我们展示出来了,那我们也就知道了原因,就可以着手解决了:

3、解决CPU100%问题

        造成CPU100%问题的原因有很多种,无限循环、过多的线程、大量的计算等都有可能,那么我们这次通过无限循环来达到CPU100%效果。

那么我们看到CPU百分百,我们可以使用top命令查看哪个进程占用CPU过高。

top,   我们看到进程号为10413的java进程CPU利用率高达96.7%

那么得知是这个进程出的问题,那么我们就进一步深入的去看是这个进程中哪些线程导致的问题了。 使用命令top -Hp <PID>,一看是线程号为10548的线程搞得鬼,那么我们就可以使用JStack工具对这个线程进行检查了。

 使用 jstack 10548 命令 得到这个线程的信息,我们可以观察得到这个线程是为数不多处于RUNNABLE状态的线程,他正在执行Demo1Applocation类的第27行,那么这个第27行也正是无限循环所在。那么这个罪魁祸首也找到了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/236299.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux系统中的信号

文章目录 01. 学习目标02. 信号的概述信号的概念信号的特点 03. 信号的编号(了解)04. 信号四要素05. 信号的状态1) 产生2) 未决状态&#xff1a;没有被处理3) 递达状态&#xff1a;信号被处理了 06. 阻塞信号集和未决信号集6.1 阻塞信号集(信号屏蔽字)6.2 未决信号集 07. 信号产…

Win10操作系统安装Python

1 Python解释器下载 1.1 安装环境 Windows 10 专业工作站版22H2 python-3.9.6-amd64.exe 1.2 下载地址 Python官网&#xff1a;Welcome to Python.org Python镜像&#xff1a;CNPM Binaries Mirror 2 Python解释器安装 2.1 Install Python 3.9.6 (64-bit)界面 双击运行下…

【FAQ】推送前台应用的通知处理功能没生效,如何进行排查?

一、前台应用的通知处理简介 在调用推送接口时可以设置“foreground_show”字段控制前台应用的通知栏消息是否通过NC展示。“foreground_show”默认值为“true”&#xff0c;应用在前台时由NC展示通知栏消息&#xff1b;当设置为“false”时&#xff0c;应用在前台时&#xff…

骁龙8 Gen 3 vs A17 Pro

骁龙8 Gen 3 vs A17 Pro——谁会更胜一筹&#xff1f; Geekbench、AnTuTu 和 3DMark 等基准测试在智能手机领域发挥着至关重要的作用。它们为制造商和手机爱好者提供了设备性能的客观衡量标准。这些测试有助于评估难以测量的无形方面。然而&#xff0c;值得注意的是&#xff0c…

2024年江苏省职业院校技能大赛信息安全管理与评估 理论题(样卷)

2024年江苏省职业院校技能大赛信息安全管理与评估 理论题&#xff08;样卷&#xff09; 理论技能与职业素养&#xff08;100分&#xff09; 2024年江苏省职业院校技能大赛&#xff08;高职学生组&#xff09; 模块三“信息安全管理与评估”理论技能 【注意事项】 Geek极安云…

分布式锁实现方案 - Lock4j 使用

一、Lock4j 分布式锁工具 你是不是在使用分布式锁的时候&#xff0c;还在自己用 AOP 封装框架&#xff1f;那么 Lock4j 你可以考虑一下。 Lock4j 是一个分布式锁组件&#xff0c;其提供了多种不同的支持以满足不同性能和环境的需求。 立志打造一个简单但富有内涵的分布式锁组…

java web系统的常见安全问题

一、背景 java开发的系统在发布到互联网后都需要进行安全扫描&#xff0c;本文主要总结开发web系统需要注意的与系统安全相关的问题。因为在做需求开发时&#xff0c;很少产品会将系统安全的因素考虑在内&#xff0c;总觉得实现个需求很简单&#xff0c;就是一些页面&#xff0…

Linux 文件权限

背景 因为在做一个任务的时候&#xff0c;调接口要到某个路径下的文件下记录log&#xff0c;但是调接口总是报一个错误&#xff1a; SEVERE: Local file cretaion error! I/O exception! File: /xxx/xxx/xxx/xx.log发现是一个创建文件的错误&#xff0c;根据提示&#xff0c;…

PC端视频网站系统源码 系统自带采集功能 附带完整的搭建教程

近年来&#xff0c;视频内容已成为人们日常生活中不可或缺的一部分。下面罗峰给大家分享一款PC端视频网站系统源码&#xff0c;该系统具有强大的采集功能&#xff0c;可轻松实现视频内容的自动更新和丰富。并附带完整的搭建教程&#xff0c;帮助您快速构建属于自己的视频网站。…

做校园外卖平台需要多少人?高校点外卖难题能否快速解决?

众所周知&#xff0c;大学生喜欢订外卖。到饭点前提前下单&#xff0c;下课后不用挤食堂&#xff0c;这种“懒人经济”在校园商圈非常流行&#xff0c;学生对外卖和跑腿等服务的依赖越来越深&#xff0c;外卖需求也在不断增加。但毕竟是在学校&#xff0c;环境因素会影响外卖的…

Java(使用注解的方式)连接数据库增删改查-MyBatis

准备工作&#xff1a; 1.创建一个springboot项目&#xff0c;并添加四个依赖 分别是&#xff0c;MyBatis的启动依赖和安装依赖&#xff0c;SQL的依赖&#xff0c;测试依赖&#xff0c;如下&#xff1a; 2.然后创建一张至少两条数据的表 &#xff08;表可以用各种图形化工具创…

【开源】基于Vue+SpringBoot的免税店商城管理系统

文末获取源码&#xff0c;项目编号&#xff1a; S 069 。 \color{red}{文末获取源码&#xff0c;项目编号&#xff1a;S069。} 文末获取源码&#xff0c;项目编号&#xff1a;S069。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、系统设计2.1 功能模块设计2.2 研究方法 三、系统…

UE4/UE5 修改/还原场景所有Actor的材质

使用蓝图方法&#xff1a; 1.修改场景所有Actor 材质&#xff1a; Wirframe&#xff1a;一个材质类 MatList&#xff1a;获取到的所有模型的全部材质 的列表 TempAllClass&#xff1a;场景中所有获取的 Actor 的列表 功能方法如下&#xff1a; 蓝图代码可复制在&#xff1a…

基于SpringBoot+Vue会员制医疗预约服务管理信息系统(Java毕业设计)

点击咨询源码 大家好&#xff0c;我是DeBug&#xff0c;很高兴你能来阅读&#xff01;作为一名热爱编程的程序员&#xff0c;我希望通过这些教学笔记与大家分享我的编程经验和知识。在这里&#xff0c;我将会结合实际项目经验&#xff0c;分享编程技巧、最佳实践以及解决问题的…

TensorBoard使用和问题解决

一、什么是TensorBoard? TensorBoard 是一组用于数据可视化的工具&#xff0c;它包含在流行的开源机器学习库 Tensorflow 中。TensorBoard 的主要功能包括&#xff1a; 可视化模型的网络架构跟踪模型指标&#xff0c;如损失和准确性等检查机器学习工作流程中权重、偏差和其他…

ABAP - Function ALV 02 简单开发一个Function ALV

了解Function ALV&#xff1a; https://blog.csdn.net/HeathlX/article/details/134879766?spm1001.2014.3001.5501程序开发步骤&#xff1a;① TCODE:SE38创建程序 ② 编写程序 DATA gt_spfli TYPE TABLE OF spfli.** Layout 变量定义 (固定使用 直接粘贴复制即可) DATA gs…

我的acer电脑U盘装系统前BIOS设置及装系统过程中的操作

1、开机长按F2进入BIOS设置 2、使能F12 3、调整boot顺序&#xff0c;使USB启动的优先级最高 4、按F10保存退出 5、插入U盘开机&#xff0c;boot选择界面无需操作&#xff0c;等待几秒&#xff0c;默认进入U盘系统 由于既使能了F12&#xff0c;又将U盘的优先级进调整到了最高&…

springboot集成knife4j详细教程

使用原生的swagger作为接口文档&#xff0c;功能不够强大&#xff0c;并且默认的ui比较简陋&#xff0c;不符合大众审美。所以实际开发中推荐使用knife4j对swagger进行增强。knife4j的地址&#xff1a;https://gitee.com/xiaoym/knife4j 基本使用 想要使用knife4j非常简单&…

Android获取Wifi网关

公司有这样一个应用场景&#xff1a;有一台球机设备&#xff0c;是Android系统的&#xff0c;它不像手机&#xff0c;它没有触摸屏幕&#xff0c;所以我们对球机的操作很不方便&#xff0c;于是我们搞这样一个设置&#xff1a;点击球机电源键5次分享出一个热点&#xff0c;然后…

UnoCSS 原子化开发初体验

UnoCSS 是一个即时的原子化 CSS 引擎&#xff0c;旨在灵活和可扩展。核心是不拘一格的&#xff0c;所有的 CSS 工具类都是通过预设提供的。再也不用为了取一个 classname 类名而烦恼了。 一、UnoCSS 特点 完全可定制&#xff1a;无核心工具&#xff0c;所有功能都通过预设提供…