一些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());