asp.net-mvc – 测量时间调用ASP.NET MVC控制器操作

前端之家收集整理的这篇文章主要介绍了asp.net-mvc – 测量时间调用ASP.NET MVC控制器操作前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
一些MVC 4应用程序的用户正在经历零星的缓慢.大概不是每个用户每次发生这种情况都会报告这个问题.

我的想法是测量每个控制器操作中花费的时间,并记录超过规定时间的操作调用详细信息,以便于进一步分析(统治或排除服务器/代码问题).

有没有方便的方法来进行这样的测量,以便我可以避免在每个操作中添加仪器代码?我目前没有使用IOC进行这个项目,并会毫不犹豫地介绍它来解决这个问题.

有更好的方法解决这种类型的问题吗?

解决方法

你能创建一个全局的动作过滤器吗?这样的事情
public class PerformanceTestFilter : IActionFilter
{
    private Stopwatch stopWatch = new Stopwatch();

    public void OnActionExecuting(ActionExecutingContext filterContext)
    {
        stopWatch.Reset();
        stopWatch.Start();
    }

    public void OnActionExecuted(ActionExecutedContext filterContext)
    {
        stopWatch.Stop();
        var executionTime = stopWatch.ElapsedMilliseconds;
        // Do something with the executionTime
    }
}

然后将其添加到“Application_Start()”中的GlobalFilters集合中

GlobalFilters.Filters.Add(new PerformanceTestFilter());

您可以从filterContext参数获取有关正在测试的控制器的详细信息.

UPDATE

直接将过滤器添加到GlobalFilters集合将为所有操作创建一个过滤器的单个实例.这当然不会用于定时并发请求.要为每个操作创建一个新的实例,请创建一个过滤器提供程序:

public class PerformanceTestFilterProvider : IFilterProvider
{
    public IEnumerable<Filter> GetFilters(ControllerContext controllerContext,ActionDescriptor actionDescriptor)
    {
        return new[] {new Filter(new PerformanceTestFilter(),FilterScope.Global,0)};
    }
}

而不是直接添加过滤器,而是在Application_Start()中添加过滤器提供程序:

FilterProviders.Providers.Add(new PerformanceTestFilterProvider());

猜你在找的asp.Net相关文章