我的编程空间,编程开发者的网络收藏夹
学习永远不晚

生成和查看dump文件

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

生成和查看dump文件

在日常开发中,即使代码写得有多谨慎,免不了还是会发生各种意外的事件,比如服务器内存突然飙高,又或者发生内存溢出(OOM)。当发生这种情况时,我们怎么去排查,怎么去分析原因呢?

1. 什么是dump文件?

dump文件是一个进程或者系统在某一个给定的时间的快照。
dump文件是用来给驱动程序编写人员调试驱动程序用的,这种文件必须用专用工具软件打开。
dump文件中包含了程序运行的模块信息、线程信息、堆栈调用信息、异常信息等数据。
在服务器运行我们的Java程序时,是无法跟踪代码的,所以当发生线上事故时,dump文件就成了一个很关键的分析点。

2. 如何生成dump文件?

这里介绍两种方式:

一种是主动的一种是被动的

方式一
主动生成dump文件。首先要查找运行的Java程序的pid。
使用top命令:
在这里插入图片描述

然后使用jmap命令生成dump文件。file后面是保存的文件名称,1246则是java程序的PID。

jmap -dump:format=b,file=/Users/zhangjiguo/dump.hprof 1246

命令中的1246是需要dump文件的java进程的pid(括号及括号中的内容要记得删掉),可以通过top命令进行获取

方式二
其实在很多时候我们是不知道何时会发生OOM,所以需要在发生OOM时自动生成dump文件。
其实很简单,只需要在启动时加上如下参数即可。HeapDumpPath表示生成dump文件保存的目录。
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\tmp
我们还需要模拟出OOM错误,以此触发产生dump文件,首先写个接口:

private static Map<String, String> map = new HashMap<>();@RequestMapping("/oom")public String oom() throws Exception {    for (int i = 0; i < 100000; i++) {        map.put("key" + i, "value" + i);    }    return "oom";}

然后在启动时设置堆内存大小为32M。
-Xms32M -Xmx32M
因为要后台启动,并且输出日志,所以最后启动命令就是这样:

 java -Xms32M -Xmx32M -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/Users/zhangjiguo/dump.hprof  -jar auth-client-api-1.0.0.RELEASE.jar

然后请求oom的接口,查看日志,果然发生了OOM错误。
查看保存dump的目录,果然生成了对应的dump文件。

3. 如何查看dump文件?

这里我介绍使用Jprofiler,有可视化界面,功能也比较完善。

使用JProfiler打开
打开比较久,需耐心等待,千万不要点skip
在这里插入图片描述

查看Classes
在这里插入图片描述

查看Reference
5.1 选择一个class或者biggest object
在这里插入图片描述

2 Use Slected Objects
在这里插入图片描述

3 Incoming references
在这里插入图片描述

  • incoming references 显示这个对象被谁引用
  • outcoming references 显示这个对象引用的其他对象

查看
在这里插入图片描述

查看Graph
在这里插入图片描述

查看代码
在这里插入图片描述

该方法主要用来导出数据报表,可以看出,当list数量太大时,就会导致OOM

来源地址:https://blog.csdn.net/u014365523/article/details/129265620

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

生成和查看dump文件

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

生成和查看dump文件

在日常开发中,即使代码写得有多谨慎,免不了还是会发生各种意外的事件,比如服务器内存突然飙高,又或者发生内存溢出(OOM)。当发生这种情况时,我们怎么去排查,怎么去分析原因呢? 1. 什么是dump文件? dump文件是一个进程或者系统在某一
2023-08-20

windows下C++生成Dump调试文件与分析

dump文件是C++程序发生异常时,保存当时程序运行状态的文件,是调试异常程序重要的方法,所以程序崩溃时,除了日志文件,dump文件便成了我们查找错误的最后一根救命的稻草,这篇文章主要介绍了windows下C++生成Dump调试文件与分析,需要的朋友可以参考下
2023-05-15

Linux中如何生成Core Dump系统异常信息记录文件

小编给大家分享一下Linux中如何生成Core Dump系统异常信息记录文件,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1 什么是 Core DumpCore
2023-06-13

Python中查看文件名和文件路径

查看文件名和文件路径>>> import os >>> url = 'http://images.cnitblog.com/i/311516/201403/020013141657112.png' >>> filename = os.pat
2022-06-04

python中解析和生成pdf文件

python中可以对pdf文件进行解析和生成,分别需要安装pdfminer/pdfminer3k和reportlab文件库。一、pdf文件的解析pdfminer安装文件路径,分别使用于python2.0/3.0版本:https://py
2023-01-31

Linux下怎么查看文件和文件夹大小

本篇内容主要讲解“Linux下怎么查看文件和文件夹大小”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linux下怎么查看文件和文件夹大小”吧!df可以查看一级文件夹大小、使用比例、档案系统及其挂
2023-06-13

Win10如何查看隐藏的文件和文件夹

这篇文章主要介绍“Win10如何查看隐藏的文件和文件夹”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Win10如何查看隐藏的文件和文件夹”文章能帮助大家解决问题。查看方法:1.首先,打开【此电脑】2
2023-06-27

在Windows中查看隐藏的文件和文件夹

要在Windows中查看隐藏的文件和文件夹,可以按照以下步骤操作:1. 打开“文件资源管理器”(也可以按下Win + E快捷键)。2. 点击“查看”选项卡。3. 在“显示/隐藏”部分,勾选“隐藏项目”复选框。4. 然后将隐藏的文件和文件夹显
2023-09-13

Ubuntu中怎么查看隐藏文件和文件夹

本篇内容主要讲解“Ubuntu中怎么查看隐藏文件和文件夹”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Ubuntu中怎么查看隐藏文件和文件夹”吧!Ubuntu文件浏览器在默认情况下仅显示用户有权
2023-06-28

如何查看和编辑SQL文件

SQL文件是一种文本文件,通常包含了一系列的SQL语句。要打开SQL文件,可以使用文本编辑器或者专门的SQL开发工具。使用文本编辑器打开SQL文件最简单的方法是使用文本编辑器,例如Windows中的记事本、Notepad++,或者Mac中
如何查看和编辑SQL文件
2024-02-26

Linux怎么查看目录和文件

在Linux系统中,可以使用以下命令来查看目录和文件:查看当前目录下的文件和子目录:ls查看特定目录下的文件和子目录:ls /path/to/directory查看隐藏文件和目录(以.开头的文件或目录):ls -a查看文件和目录的详细
Linux怎么查看目录和文件
2024-04-08

Python 生成 GIF 文件

使用 Python 合成 gif 动态图,程序如下:原图片需具有相同大小import imageioimport osimport os.pathdef create_gif(gif_name, path, duration = 0.3):
2023-01-31

Jbuider生成EXE文件

倘若说看到标题后,以为jb真的提供了一种把java应用程序打包成exe文件的主流方法的话,你会失望的,下面的一个小技巧只是一个技巧而已。      这个是borland不公开的使用技巧,能够通过jbuilder来制作exe文件来启动java
2023-06-03

C# 查看EF生成的SQL语句

用sqlsever追踪最后的sql语句。返回IQueryable类型, 里面封装的就是生成的SQL脚本,设置断点queryable = DataContext.Set().Where(whereLambda).AsQueryable(); queryable 
C# 查看EF生成的SQL语句
2019-12-28

ns3生成trace文件

相关函数有EableAscii()和EnableAsciiAll(),支持这两个函数的有 ns3::YansWifiPhyHelper  PointToPoint  InternetStackHelper  EmuHelper  CsmaH
2023-01-31

ns3生成.pcap文件

相关函数有EnablePcap()和EnalePcapAll(),    支持第一个函数的类有ns3::YansWifiPhyHelper  PointToPoint  EmuHelper  CsmaHelper    支持第二个函数的类有
2023-01-31

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录