蛙蛙推荐:创建自己的性能计数器及压力测试入门

发表于:2008-09-25来源:作者:点击数: 标签:性能推荐压力计数器入门
做服务端的程序,经常要监控服务的 性能 ,比如某个方法每秒执行了多少次了呀?某个方法同一时间有多少个并发方法啦?某个对象在内存里有多少个实例啦?执行某个操作的平均操作时间啦等等。 .net 提供了创建自定义性能计数器的API来让我们方便的实现这些 需求
做服务端的程序,经常要监控服务的性能,比如某个方法每秒执行了多少次了呀?某个方法同一时间有多少个并发方法啦?某个对象在内存里有多少个实例啦?执行某个操作的平均操作时间啦等等。.net提供了创建自定义性能计数器的API来让我们方便的实现这些需求,我改造了一下《.net企业应用高级编程》里的WEO框架的计数器部分,让大家方便的创建自己的计数器,原来是.net 1.0的,用的反射,我移植到了.net 2.0,改用的泛型,性能会好一些。先来看看大概思路。
单击显示全图,Ctrl+滚轮缩放图片

要想创建自定义的计数器,先得实现IPerfCounterProvider接口,CreateCounters方法声明要创建的计数器,CountersCreated方法把创建的计数器赋值给本类的成员,PerformanceObjectName返回要创建自定义计数器的分类名。

PerfCounterFactory主要用来创建一个IPerfCounterProvider的实例,它有个GetCounters的泛型方法用来创建一个IPerfCounterProvider的实例,CreateCounters方法用来实际的创建性能计数器,另两个AddPerfCounter方法和Find方法是让IPerfCounterProvider的两个方法用的,下面的例子里会有。

PerfCounter是一个实体类,保存每个计数器的名称,帮助,类型。

好,我们要监控一个web服务的性能,这个Web服务提供相乘和相加的服务,我们要知道这个Web服务的总请求数,每秒调用次数,并发调用数,每个web方法每秒的调用次数,创建计数器如下,关于计数器的类型,及性能计数器的相关内容,请查看MSDN,计数器类型有总量计数器,平均计数器,速率计数器,并发计数器等,分别适用于不同的需求。
复制  保存
public class MathServicePerfCounter : IPerfCounterProvider
{
    static MathServicePerfCounter _instance =
        PerfCounterFactory.GetCounters<MathServicePerfCounter>();
    public static MathServicePerfCounter Instance
    {
        get { return _instance; }
    }

    public PerformanceCounter TotalOfRequest;
    public PerformanceCounter RateOfRequest;
    public PerformanceCounter RateOfAddition;
    public PerformanceCounter RateOfMultiplication;
    public PerformanceCounter CountOfCurrentRequest;

    const string TotalOfRequestStr = "Total # req";
    const string RateOfRequestStr = "req/sec";
    const string RateOfAdditionStr = "Addition/sec";
    const string RateOfMultiplicationStr = "Multiplication/sec";
    const string CountOfCurrentRequestStr = "current # req";
    #region IPerfCounterProvider 成员

    public void CreateCounters()
    {
        PerfCounterFactory.AddPerfCounter(new PerfCounter(TotalOfRequestStr, "请求总数",
            PerformanceCounterType.NumberOfItems64));
        PerfCounterFactory.AddPerfCounter(new PerfCounter(RateOfRequestStr, "每秒请求的数量",
            PerformanceCounterType.RateOfCountsPerSecond64));
        PerfCounterFactory.AddPerfCounter(new PerfCounter(RateOfAdditionStr, "每秒相加请求的数量",
            PerformanceCounterType.RateOfCountsPerSecond64));
        PerfCounterFactory.AddPerfCounter(new PerfCounter(RateOfMultiplicationStr, "每秒相成的数量",
            PerformanceCounterType.RateOfCountsPerSecond64));
        PerfCounterFactory.AddPerfCounter(new PerfCounter(CountOfCurrentRequestStr, "当前并发请求量",
            PerformanceCounterType.RateOfCountsPerSecond64));
    }

    public void CountersCreated()
    {
        TotalOfRequest = PerfCounterFactory.Find(TotalOfRequestStr);
        RateOfRequest = PerfCounterFactory.Find(RateOfRequestStr);
        RateOfAddition = PerfCounterFactory.Find(RateOfAdditionStr);
        RateOfMultiplication = PerfCounterFactory.Find(RateOfMultiplicationStr);
        CountOfCurrentRequest = PerfCounterFactory.Find(CountOfCurrentRequestStr);
    }

    public string PerformanceObjectName()
    {
        return "MathServicePerfCounter";
    }

    #endregion
}

原文转自:http://www.ltesting.net