通过jmap、jstack分析问题,以及分析方法

news/2024/5/15 7:21:45/文章来源:https://blog.csdn.net/moneywenxue/article/details/127436108

一、问题

        多批次导入任务,会出现异步线程停止工作的情况,后续无论导入多少任务,异步线程都不会执行,只有重启能解决。

二、工具使用

进入jdk的bin目录:

cd /beeb/ap/uip/jdk1.8.0_231/bin

2.1 拉取jstack日志:

./jstack -l 28406 >./sp-dbms.jstack.log

其中28406是服务进程号。

2.2 通过jmap分析:

./jmap -dump:live,format=b,file=/beeb/ap/uip/agent/udp-logs/sp-dbms/appLogs/sp-dbms-heap.bin 28406

2.2.1 使用jhat工具:

1.启动jhat:

jhat xxx.dump

实战图:

 jhat命令后面跟的是文件名,这个文件名的后缀可以是.dump,也可以是.bin,具体要看你到出的文件后缀。

2.启动后,就可以访问:http://127.0.0.1:7000/

jhat工具页面截图

 通过分析堆内存没看出有什么异常,于是我掉头又去查看了sp-dbms.jstack.log日志。

三、分析jstack日志

3.1 查看jstack日志

        可以看的下图中,对应的线程信息,async-import-16(就是我用到的线程池)线程属于WAITING状态,并且parking to wait for (CountDownLatch),那么我可以猜测,是不是因为CountDownLatch这个共享锁因为某些原因没有释放出来?

 3.2 查看代码

        查看代码,捕获异常后更新数据,插入失败状态以及失败原因,这里有可能出现数据库连接等异常,导致下面的latch.countDown()未执行,继而出现线程一直在等待的问题:

 

 3.3 解决方法

在第一个红框出的update...方法处try...catch一下就行了。

四、java visualVM使用步骤

解决这个问题没有用到java visualVM工具,但我也记录一下它的使用步骤:

4.1 找到jdk的bin路径

 打开jvisualvm.exe。

4.2 加载我们之前jmap拉下来的xx-heap.dump或xx-heap.bin文件

 

 

4.3 接下来就可以分析了

具体分析方法以后再阐述。 

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

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

相关文章

setContentView源码解析

一、引言 本文将解析activity加载布局文件的setContentView源码,由于会涉及到部分activity的启动流程,这里附上一张activity启动流程图: 关于 setContentView 源码分两种情况,因为我们的 activity 有两个: 一种是继…

halcon脚本-边缘及骨架的识别【附源码】

文章目录前言一、原图1.边缘图2.骨架图二、实现思路1.边缘图2.骨架图三、halcon脚本实现1.边缘图2.骨架图四、实现效果1.边缘图2.骨架图前言 本文实现基于图像进行边缘或者骨架的识别,可实现让机器人画画 一、原图 1.边缘图 2.骨架图 二、实现思路 1.边缘图 提取…

【阅读】一周翻过《构建之法》,笔记整理

文章目录🚩 前言🥦 阅读笔记🌾 结语🚩 前言 我的阅读方式 我拿到这本书挺久了,之前已经零散地看过一部分,最近一周集中地花了一些时间,将整本书看过了一遍。看得比较粗略,正如“好读…

怎么管理员工混工时的现象?

如果员工存在混工时,这表明公司的管理存在漏洞。让懒散的员工认为自己可以混日子,让没有绩效考核的员工默认可以混日子,同时让对公司感到失望的员工可以完全躺平等待被公司解雇。 工时管理一直是企业需求与痛点。特别是在疫情时期&#xff0c…

华为云数据库GaussDB 为企业核心数据运行提供优质保障

华为云数据库GaussDB 为企业核心数据运行提供优质保障 在网络信息科学技术不断发展的今天,海量存储信息数据中大量的存储资源被浪费?你有没有遇见信息数据备份恢复很慢的情况?让人特别的烦躁,特别是企业遇见了这些情况&#xff0c…

JDBC工具类和JDBC登录案例

JDBC工具类: 抽取JDBC工具类:JDBCUtils 目的:简化书写 分析∶ 1.注册驱动也抽取 2.抽取一个方法获取连接对象 3.抽取一个方法释放资源 代码实现:/*** JDBC工具类*/ public class JDBCUtils {private static String url;private static String user;private static Strin…

Cadence Allegro PCB设计88问解析(十一) 之 Allegro中文件自动保存时间设置

一个学习信号完整性的layout工程师 大家在设计图纸或者编辑文档时,最常点击的应该就是保存图标了。谁也不想因为软件闪退、电脑断电等情况,我们的劳动成果就白白的消失了。在我们用Allegro进行PCB设计,就会有一个自动保存的功能,每…

数字化转型大潮下,企业如何做好绩效管理?

久其EPM白皮书的正式发布,为企业财务的数字化转型实践提供了极具价值的参考。企业绩效管理(EPM)成为行业热点对于一家企业来说,做好绩效管理究竟有多重要?对于这个问题,全球商界传奇人物、GE前CEO杰克韦尔奇…

事件对象的介绍

● 什么是事件对象?就是当你触发一个事件以后,对该事件的一些描述信息 ● 例如: ○ 你触发一个点击事件时,你点了哪个位置,坐标多少,都在事件对象的属性中体现 ○ 你触发一个键盘事件时,你按下…

探索增强型灰狼优化算法

文章目录一、理论基础1、灰狼优化算法2、探索增强型灰狼优化算法(1)改进的位置更新公式(2)非线性控制参数策略(3)EEGWO算法伪代码二、仿真实验与结果分析三、参考文献一、理论基础 1、灰狼优化算法 请参考…

计算机科学与技术是信息文明时代的入口,是数字世界的基石,是人们必须掌握的基本技能之一

从人类科技发展史的角度看,软件工程(计算机编程)是刚刚开始的信息文明巨大的趋势中的一部份。人类至今经历过三次工业革命。第一次工业革命的代表是蒸汽机,使得人类拥有了强大的动力。第二次工业革命的代表是电力和石油&#xff0…

高数_第6章无穷级数_幂级数之__阿贝尔定理

阿贝尔定理&#xff1a; 如果幂级数 在 点 x x₀(x₀≠0)处收敛&#xff0c; 则对于适合不等式 |x| < |x₀|的一切x, 都有幂级数 在点 x 处绝对收敛&#xff1b; 反之&#xff0c;如果幂级数 在点 x x₀ (x₀≠0)处发散&#xff0c; 则对于适合不等式 |x| >…

使用Code Chart绘制流程图

Code Chart介绍 Code Chart是一个基于 Javascript 的图表和图表工具&#xff0c;它基于 markdown 语法来简化和加速生成流程图的过程&#xff0c;也不止于生成流程图。 工具地址&#xff1a;https://www.iodraw.com/codechart 图形 头部用graph 或flowchart 关键字来声明流程…

Anaconda安装

文章目录1. Anaconda3简介2. Anaconda3下载3. Anaconda3安装1. Anaconda3简介 Anaconda3 是一个用于 Python 科学计算和机器学习的开源工具&#xff0c;它是 Python 的一个科学计算发行版&#xff0c;支持 Linux、macOS 和 Windows 系统&#xff0c;包含 conda 等众多工具包和…

python抓取Prometheus的数据(使用prometheus-api-client库)

python抓取Prometheus的数据(使用prometheus-api-client库) 0、写在前面 我们要想抓取Prometheus的数据,一般想到的就是requests请求,爬虫的方式来抓取,这是可行的,当然,还有一个第三方库直接封装好了,直接用就行,代码也比较少,源码点进去就能看明白,这个库叫promet…

多链世界的“高速公路”:一文读懂跨链协议演进与未来

当我们发现自己正处于另一个“加密货币寒冬”之中——这在很大程度上是由一系列项目破产、监管打击和宏观看跌推动的——但重要的是&#xff0c;我们不要忽视促成下一次牛市的技术突破和将权力下放的精神重新引入大众。 上一个周期的主题之一仍然是行业参与者讨论的最前沿的主…

无网络机器上,win下vscode客户端通过ssh连接linux服务器

目录 参考文献 前言 下载安装VSCode 下载 安装 下载和安装必要的VSCode插件 下载 安装 客户端通过ssh远程连接linux服务器 下载并安装ssh 远程连接linux服务器 参考文献 Windows使用VSCode远程Linux&#xff08;ConteOS&#xff09;开发/调试C/C&#xff08;超详细…

是真是假,AI可根据声音检测是否感染新冠 准确率达89%

据媒体报道&#xff0c;近日&#xff0c;在西班牙巴塞罗那举行的欧洲呼吸学会国际会议上公布的一项研究显示&#xff0c;AI可通过手机应用程序从人们声音中检测出新冠肺炎感染&#xff0c;其准确率达到89%。 新冠肺炎感染通常会影响上呼吸道和声带&#xff0c;导致一个人的声音…

No6.从零搭建spring-cloud-alibaba微服务框架,实现fegin、gateway、springevent等(一)

代码地址与接口看总目录&#xff1a;【学习笔记】记录冷冷-pig项目的学习过程&#xff0c;大概包括Authorization Server、springcloud、Mybatis Plus~~~_清晨敲代码的博客-CSDN博客 之前只零碎的学习过spring-cloud-alibaba&#xff0c;并没有全面了解过&#xff0c;这次学习p…

React+fetch 发送post请求 处理请求头参数配置

观看本文前 你要对fetch有一些了解 如果不了解可以先查看我的文章 React之初识fetch 通过fetch发送一个简单GET请求 然后我们来看 pust基本语法 fetch("请求地址",{method: post,headers: {Content-Type: application/json,"Authorization": "Bearer…