抓dump文件,经常是解决众多疑难杂症的不二手段。但是很多时候,我们没办法抓。比如说

  • 几秒内的线程数暴涨200个,然后迅速回落
  • 程序跑了两天,内存涨到某个数字就自己OOM了

原因不外乎都是时间短,没有办法人肉来一直看着,而且,即使盯着,你敲回车让adplus把cdb调出来,至少也要几秒钟,那时候dump很容易就抓的不准确了。怎么办?实际上,我们可以配合伟大的perfmon来抓这种dump。

创建Alert

首先打开perfmon,方式是WIN+R,输入perfmon回车即可。然后右键点击user defined

,创建一个新的dataset,比如取名叫做createDump,选择手动创建

选择下面的Alert,而不是counter log,如下图

到关键的地方了!选择你要监控的perf counter。比如我要监控某个.NET进程的managed heap,如果大于2GB,我就创建一个dump出来。

那么,选择#bytes in all heaps,如下图:

OK之后,回到上一个界面,采样时间间隔,设置为15秒。

一直按Ok,知道结束这个wizard。

定义任务

重新回到perfmon界面,点击左侧树上我们创建好的createDump,在右侧的listview中,右键选择属性

选择Alert Task,输入task的名字以及arguments。其中前者,可以手工输入。第一次提示,这个名字就是你在计划任务里面的任务名字!不是随便写的!!!第二行的参数,点击右面的大于号,选择你要处理的参数

然后,修改参数为下图:

注意,参数修改为了双引号的格式,然后用空格分开。

创建windows计划任务

按住WIN+R,输入taskschd.msc /s,启动windows计划任务

进入计划任务,点击左侧Library节点,在右侧空白处,点击右键,创建new task,注意不要选择basic task

在新建task窗口中,首先输入任务的名字。请鼠标向上滚,看前面我写的那个粗体字部分。这个名字,就是你在上面alert的task中输入的名字,两者必须要一致!否则不会被调用的。

同时要注意,一般我们要选择:Run whether use is logged on or not,而不是默认的logged on only

然后切换到Actoin这个tab上

点击new,创建一个新的action。注意下面的optional的arguments,这里是第二个坑!务必要写$(Arg0),否则你的程序接受不到参数!

请看这段:

If the task to run is a script, you must set the task arguments in the Task Scheduler to $(Arg0); otherwise, the arguments that you specify with this property will not be passed to the script.

原文出处,请戳这里

写你自己的createDumpTask程序

这里写了一个简单的例子:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.IO;

namespace CreateDumpTask
{
    class Program
    {
        static void Main(string[] args)
        {
                        using(StreamWriter sw = new StreamWriter("c:\\work\\1.txt",true))
            {
                sw.WriteLine("Triggered at {0}", DateTime.Now);
                sw.WriteLine("Length of arguments:{0}", args.Length);

StringBuilder sb = new StringBuilder();
                foreach (string arg in args)
                {
                    sb.Append(arg).Append(",");
                }

sw.WriteLine("Args:{0}", sb.ToString());
            }
        }
    }
}

而实际上,你要增加自己的逻辑,比如,持续三分钟内,触发了三次,那么可以抓一个dump出来。而抓dump的方式,最简单的就是复制一个别的server上安装好的windbg到你指定目录下,比如c:\windbg目录下。

然后代码中,用Process.Start来调用adplus.exe或者adplus_old.vbs来抓dump文件。

当然,复杂一点,你也可以用dbgeng.dll,然后PInvoke来做。但是没必要……

妙用perfmon Alert抓dump的更多相关文章

  1. 高通平台如何使用QPST抓DUMP

    一 :确认手机状态 手机系统死机白屏后,使用USB线 连接手机和计算机.打开计算机设备管理器 ,当其中与手机相关的端口只有DIAG 口 项(9006端口)时,表明手机处于DUMP 模式,可以抓DUMP ...

  2. .NET程序崩溃了怎么抓 Dump ? 我总结了三种方案

    一:背景 1. 讲故事 最近几天接到了几个crash的求助,可能这几个朋友没玩过怎么去生成dump,只能手把手教,感觉也不是一个办法,所以有必要总结一下,后续再有朋友咨询的话,我就可以把这篇文章丢过去 ...

  3. WinDbug抓取进程dump

    安装WinDbug(包含在 Windows Kits-debugger 中)后,运行如下命令将会在 explorer.exe进程发生崩溃后抓取相应的内存数据到D盘根目录下的一个文件夹中 adplus. ...

  4. WinDbg抓取程序报错dump文件的方法

    程序崩溃的两种主要现象: a. 程序在运行中的时候,突然弹出错误窗口,然后点错误窗口的确定时,程序直接关闭 例如: “应用程序错误” “C++错误之类的窗口” “程序无响应” “假死”等 此种崩溃特点 ...

  5. 抓取Dump文件的方法和工具介绍

    一.Windows系统的任务管理器里抓dump 启动任务管理器,选中某个进程,右键,弹出菜单"创建转储文件" 注意事项: 当你在64位Windows系统上抓32位进程的dmup文件 ...

  6. windows下捕获dump之Google breakpad_client的理解

    breakpad是Google开源的一套跨平台工具,用于dump的处理.很全的一套东西,我这里只简单涉及breakpad客户端,不涉及纯文本符号生成,不涉及dump解析. 一.使用 最简单的是使用进程 ...

  7. windows下捕获dump

         一般要捕获异常只需要两个函数:SetUnhandledExceptionFilter截获异常:MiniDumpWriteDump写dump文件.但是由于CRT函数可能会在内部调用SetUnh ...

  8. Dump Checking

    Dump Checking Debug相关的一些小技巧 摘要: 1. 如何Debug一个进程的子进程? 答: 使用WinDBG attach到父进程, 然后输入命令".childdbg 1& ...

  9. 妙味课堂:JavaScript初级--第11课:字符串、查找高亮显示

    1.数字字母 Unicode 编码 <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content- ...

随机推荐

  1. Java命令学习系列(7):Javap(转)

    原文出处: Hollis(@Hollis_Chuang) javap是jdk自带的一个工具,可以对代码反编译,也可以查看java编译器生成的字节码. 一般情况下,很少有人使用javap对class文件 ...

  2. malloc一次性最大能申请多大内存空间

    受用户态内存地址空间的限制.64 位系统下分配几个 T 不成问题. 著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处.作者:zz matrix链接:http://www.zhihu. ...

  3. Codeforces Round #277.5 (Div. 2)---B. BerSU Ball (贪心)

    BerSU Ball time limit per test 1 second memory limit per test 256 megabytes input standard input out ...

  4. 设计模式之迭代器模式(Iterator)摘录

    23种GOF设计模式一般分为三大类:创建型模式.结构型模式.行为模式. 创建型模式抽象了实例化过程,它们帮助一个系统独立于怎样创建.组合和表示它的那些对象.一个类创建型模式使用继承改变被实例化的类,而 ...

  5. I深搜

    <span style="color:#330099;">/* I - 深搜 基础 Time Limit:1000MS Memory Limit:10000KB 64b ...

  6. hihocoder第41周 骨牌覆盖(矩阵快速幂)

    由于棋盘只有两行,所以如果第i列的骨牌竖着放,那么就转移为第1列到第i-1列骨牌有多少种摆法 如果第一行第i列骨牌横着放,那么第二行第i列也要横着放,那么就转移为了第1列到第i-2列骨牌有多少种方法 ...

  7. SQL Server中的查询

          本博文简介一下SQL Server中经常使用的几类查询及相关使用的方法.       一.ExecuteScalar方法获取单一值       ExecuteScalar方法是SqlCom ...

  8. C++第11周(春)项目1 - 存储班长信息的学生类

    课程首页在:http://blog.csdn.net/sxhelijian/article/details/11890759,内有完整教学方案及资源链接 [项目1 - 存储班长信息的学生类] clas ...

  9. C语言static 具体分析

    google在最后三页C语言static内容,可找到的资料非常少.无论是长篇大论不知所云的话,在关键位置或跳过,习的人来说參考性不是非常大.所以.我这篇博文博採众家之长,把互联网上的资料整合归类,并亲 ...

  10. wpa/wpa2破解系统(CDlinux)U盘启动傻瓜教程

    CDlinux是破解无线wifi信号的很好用的系统.它就像一个PE,不过它是基于Linux内核的微型系统.里面的破解工具很齐全,既有传统的抓包工具,也有最新的PIN码破解软件,而且针对windows用 ...