需要使用WinDbg工具来分析windows系统产生的dump文件,此工具属于Windows SDK的一个组件,在微软官方网站可以下载(链接)。...使用WindDbg分析dump文件的详细方法可以参考官方文档(链接),以下是简单分析dump文件的步骤: 1)打开WinDbg工具,通过菜单“File”->“Open Crash Dump”打开dmp...文件。...2)文件打开后,会列出产生dump文件的设备的系统版本和运行时间等相关信息: 3)点击”!analyze -v”链接,或者在下面的命令窗口中输入“!...analyze -v”命令,工具就对dump文件进行分析,然后输出导致系统崩溃的起因等相关信息。 其他可能有用的调试命令: 命令 描述 !memusage 显示有关物理内存使用的摘要统计信息。
dump文件传输到本地进行分析, 常常需要大量的等待时间。 使用IBM的eclipse的MAT工具可以直接在服务器上进行快速DUMP分析。...文件大小来的,如果dump文件是5GB那么 这里最好配>5GB 否则会报MAT内存不足的异常 ## 修改MemoryAnalyzer.ini 的 -Xmx6024m vi MemoryAnalyzer.ini...jmap dump整个堆 jmap -dump:format=b,file=jmap.info PID MAT分析 dump ....结果会生产如下三个zip文件,很小可以直接拷贝到本机 jmap_Leak_Suspects.zip jmap_System_Overview.zip jmap_Top_Components.zip 查看报告结果...就可以选择加载dump文件了 转自: http://www.moheqionglin.com/site/blogs/84/detail.html 经常使用, 故记录于此 版权声明:本文内容由互联网用户自发贡献
mysqldump 备份原理是通过协议连接到 MySQL 数据库,将需要备份的数据查询出来,将查询出的数据转换成对应的insert 语句,当我们需要还原这些数据时,只要执行这些 insert 语句,即可将对应的数据还原...; 备份命令 mysqldump [选项] 数据库名 [表名] > 脚本名 mysqldump [选项] --数据库名 [选项 表名] > 脚本名 mysqldump [选项] --all-databases...-uroot -p test > /backup/mysqldump/test.db 备份指定数据库指定表(多个表以空格间隔):mysqldump -uroot -p mysql db event >...; mysqladmin -uroot -p createdb_name; mysql -uroot -p db_name < /backup/mysqldump/db_name.db; soure 方法...:mysql > use db_name ;mysql > source /backup/mysqldump/db_name.db
所有代码如下: #ifndef __DUMP_H__ #define __DUMP_H__ #include #include #include <ostream...MINIDUMP_CALLBACK_INFORMATION mci; mci.CallbackRoutine = (MINIDUMP_CALLBACK_ROUTINE)MiniDumpCallback; mci.CallbackParam = 0; //dump...&mdei : 0, NULL, &mci); //普通dump,小 CloseHandle(hFile); } } std::ostream& operator<<(std::ostream& os
于是就需要保存崩溃时的dump信息了。 下面是关于如何生成dmp文件的代码。...头文件 #pragma once #include #include #include #include #pragma...DisableSetUnhandledExceptionFilter();// 此函数一旦成功调用,之后对 SetUnhandledExceptionFilter 的调用将无效 void InitMinDump(); } 源文件...FrameworkMiniDump::InitMinDump(); ...... } 调用一下InitMinDump就可以了,这里面会注册一个回调,崩溃时会保存的dmp文件。...保存下来的dmp文件,需要结合pdb文件和源代码才能定位到哪里崩溃了。具体的我也不懂。
select heap.findObject("0x6d1029358") 点开可以看到我们静态的属性 更多的使用方法,建议还是参考官网或其他现成使用案例; 最后 通过OQL方式来查询dump...文件中内存里面的对象或属性,通过该方式可以快速查询,需要将文件下载到本地来进行分析的场景是比较常用,部分JVM分析工具,图形化界面也是通过基于该语法进行集成。
JAVA Thread Dump 文件分析 Thread Dump介绍 Thread Dump是非常有用的诊断Java应用问题的工具。...文件分为2个部分来理解 拿我们的例子来说: //头部信息 包含 当前时间 jvm信息 2021-01-14 17:00:51 Full thread dump Java HotSpot(TM) 64...runnable 一般指该线程正在执行状态中,该线程占用了资源,正在处理某个操作,如通过SQL语句查询数据库、对某个文件进行写入等。...根据案例症状分析解决方案 1 CPU占用率不高,但响应很慢 在整个请求的过程中多次执行Thread Dump然后进行对比,取得 BLOCKED状态的线程列表,通常是因为线程停在了I/O、数据库连接或网络连接的地方...2 CPU飙高,load高,响应很慢 一个请求过程中多次dump;对比多次dump文件的runnable线程,如果执行的方法有比较大变化,说明比较正常。
JAVA Thread Dump 文件分析 Thread Dump介绍 Thread Dump是非常有用的诊断Java应用问题的工具。...image 日志字段分析 我们把Thread dump文件分为2个部分来理解 拿我们的例子来说: //头部信息 包含 当前时间 jvm信息 2021-01-14 17:00:51 Full thread...runnable 一般指该线程正在执行状态中,该线程占用了资源,正在处理某个操作,如通过SQL语句查询数据库、对某个文件进行写入等。...根据案例症状分析解决方案 1 CPU占用率不高,但响应很慢 在整个请求的过程中多次执行Thread Dump然后进行对比,取得 BLOCKED状态的线程列表,通常是因为线程停在了I/O、数据库连接或网络连接的地方...2 CPU飙高,load高,响应很慢 一个请求过程中多次dump;对比多次dump文件的runnable线程,如果执行的方法有比较大变化,说明比较正常。
获取JVM的dump文件的两种方式 1....JVM启动时增加两个参数: #出现 OOME 时生成堆 dump: -XX:+HeapDumpOnOutOfMemoryError #生成堆文件地址: -XX:HeapDumpPath=/home/liuke...发现程序异常前通过执行指令,直接生成当前JVM的dmp文件,6214是指JVM的进程号 jmap -dump:format=b,file=serviceDump.dat 6214 由于第一种方式是一种事后方式...,需要等待当前JVM出现问题后才能生成dmp文件,实时性不高,第二种方式在执行时,JVM是暂停服务的,所以对线上的运行会产生影响。
今天刚好手边有一个系统蓝屏的dump文件,下面一步一步来找到出错的地方。 1.用windbg打开dump文件,设置好符号路径等。 已经基本确定了是哪个驱动引起的问题。 2.执行!
Widows 分析dump文件的工具太多了,而且都是傻瓜式的点点就好了。...但是生产上分析dump文件的话,还是linux工具比较方便,因为生产上的dump文件一般都至少是GB级别的,这么大的文件拷贝到本机要耗费很长时间,特别是遇到生产事故的时候,时间=金钱。...那么linux有什么好的解析dump工具呢? 如何解析 java dump的文件? 这里比较推荐IBM的eclipse的MAT工具。...文件大小来的,如果dump文件是5GB那么 这里最好配>5GB 否则会报MAT内存不足的异常 ## 修改MemoryAnalyzer.ini 的 -Xmx6024m vi MemoryAnalyzer.ini...就可以选择加载dump文件了
3 dump 文件分析 3.1 dump 生成 JProfiler 在线 当JProfiler连接到JVM之后选择Heap Walker,选择Take snapshot图标,然后等待即可 ?...HPROF snapshot 弹出下拉框保存即可,这时候生成的文件就可以一直保存在文件上 jmap jmap -dump:format=b,file=文件名 pid windows下不用[],路径要加引号...jmap -dump:format=b,file="D:\a.dump" 8632 命令中文件名就是要保存的dump文件路径, pid就是当前jvm进程的id JVM启动参数 在发生outofmemory...启动参数可以在发生内存outofmemory的时候自动生成dump文件,但是正式环境使用的时候不要加这个参数,不然在内存快满的时候总是会生成dump而导致jvm卡半天,需要调试的时候才需要加这个参数 注意...:通过WAS生成的PHD文件dump不能分析出出问题的模板,因为PHD文件不包含对象的值内容,无法根据PHD文件找到出问题的模板,所以PHD文件没有太大的参考价值 3.2 dump文件分析 dump文件生成后
文章目录 1.命令简介 2.命令格式 3.选项说明 4.格式 4.1 格式字符串 4.2 转换字符串 5.常用示例 参考文献 1.命令简介 hexdump 以 ASCII、十进制、十六进制或八进制显示文件内容...-f 指定包含一个或多个换行分隔格式字符串的文件。内容使用 # 号开头表示注释。 -n 只解释输入的指定长度个字节。 -o 两字节八进制显示。..._a[dox] 标记下一个输出字节的偏移量,在输入文件中累积。d、o、x 分别以十进制、八进制和十六进制显示。 _A[dox] 与 _a 转换字符串相同,只是在处理所有输入数据后只执行一次。...(1)不指定选项缺省以十六进制显示指定文件的内容。
平常需要恢复数据的时候会发现大点儿的文件都要几个小时 实在是太慢了 我们可以通过修改MySQL的参数来提高数据的恢复速度 查看现在参数情况 #先查看现在参数情况 mysql> show variables...-------------+-------+ | sync_binlog | 0 | +---------------+-------+ 1 row in set (0.00 sec) mysql...(0.00 sec) 修改参数 #临时修改 set global sync_binlog = 2000; set global innodb_flush_log_at_trx_commit = 2; MySQL...dump恢复数据 方法一: 在linux命令行使用MySQL dump命令进行恢复 mysqldump -uroot -pxxxxx database < database.sql 方法二:...在MySQL命令行进行恢复 mysql> source /root/databse.sql; 恢复数据 数据导入完毕,你会发现导入的速度大大提高 进行恢复参数设置 set global sync_binlog
弹出下拉框保存即可,这时候生成的文件就可以一直保存在文件上 jmap jmap -dump:format=b,file=文件名 pid windows下不用[],路径要加引号 jmap -dump...:format=b,file="D:\a.dump" 8632 命令中文件名就是要保存的dump文件路径, pid就是当前jvm进程的id JVM启动参数 在发生outofmemory的时候自动生成dump...outofmemory的时候自动生成dump文件,但是正式环境使用的时候不要加这个参数,不然在内存快满的时候总是会生成dump而导致jvm卡半天,需要调试的时候才需要加这个参数 注意:通过WAS生成的PHD...文件dump不能分析出出问题的模板,因为PHD文件不包含对象的值内容,无法根据PHD文件找到出问题的模板,所以PHD文件没有太大的参考价值 3.2 dump文件分析 dump文件生成后,将dump压缩传输到本地...,不管当前dump的后缀名是什么,直接改成*.hprof,就可以直接用jprofiler打开了 打开的过程时间可能会很长,主要是要对dump进行预处理,计算什么的,注意 这个过程不能点skip,否则就不太好定位大文件
分析: 1,patch 作者写了一个patch,方便把kmsg信息保存到文件中,下次启动可以查看: 修改linux-4.4/kernel/panic.c文件,增加函数: #ifdef CONFIG_PRINTK...void dump_kmsg_to_file(void) { struct file *fkmsg = NULL; struct file *ffile = NULL; loff_t...PAGE_SIZE; size_t ret = 0; const char __user *p; mm_segment_t old_fs; pr_emerg("trigger dump...== NULL) { pr_emerg("vmalloc fail\n"); goto close_ffile; } pr_emerg("start dump...return; } #endif /*#ifdef CONFIG_PRINTK*/ 在pr_emerg("Kernel panic - not syncing: %s\n", buf);函数后面调用dump_kmsg_to_file
https://pan.baidu.com/s/1X-fe16KQdIFuzE9Z0h910w 提取码:syjv 解压后如下: 双击打开 界面如下 file->open heap dump...选择文件,如果之前没有,可以使用命令生成 命令如下: jmap -dump:live,format=b,file=heades.bin pid 注意:pid是运行的系统进程号 点击finish...出现的页面有问题分析 对比两个文件过程如下: 再使用命令jmap -dump:live,format=b,file=heades.bin pid生成文件,两个文件名不同 打开文件后点击...overview 点击下面的histogram 然后开始对比,点击对比按钮 弹出如下界面时需要打开第二个文件 已打开的直接选择要对比的文件 结果如下:
.dmp是损坏的或者创建.dmp失败,这些都有可能发生crash的类型比较多,有些类型的crash,crash过程观察到了,但是最终并不一定会产生.dmp文件比如下面这个图片可以用微软的蓝屏工具去模拟,...sysinternals/downloads/notmyfault我分别选了High IRQL (Kernel-mode)和High IRQL (User-mode)触发crash,发现前者生成了2个.dmp文件
Message reprinted in 后面尝试使用一个MySQL测试用户登录数据库,还是报错: [root@typecodes ~]# mysql -u TypeCodes_test -p [02:...而mysql得数据文件正好存放在mydata分区中,悲剧! 接着进入到/mydata分区,使用命令du -sh查看当前目录下各个子目录所占用的空间大小。...结果太出乎意料了,竟然是存放Core Dump文件的corefile目录占用了16G的空间!...这才想起在《CentOS开启coredump转储并生成core文件的配置》文中,设置了Core Dump文件大小为unlimited。日积月累,终于把MySQL搞挂掉了!...4 解决 先删掉corefile目录下面的大部分Core Dump文件,然后使用命令ulimit -c 10240设置coredump file-size为10M。
由于服务器限制下载文件大小为50M,dump出来的文件一般都比较大。就算能下载,传输几十G文件效率比较慢。...所以使用Linux MAT工具先将文件分析完生成html文件,只有几百K,然后下载到本地用浏览器打开分析。 dump堆 首先使用下面命令找到服务的pid: jps -l 然后dump出此服务的堆。...jmap -dump:format=b,file=hummer.dump PID format=b,表示以字节的形式。文件名为hummer.dump。...出来的文件大小 vi MemoryAnalyzer.ini MAT分析 dump ....把这三个文件下载到本地用浏览器打开,这三个文件很小,只有几百K。
领取专属 10元无门槛券
手把手带您无忧上云