asp.net-mvc – 测量时间调用ASP.NET MVC控制器操作
发布时间:2020-12-15 20:09:01 所属栏目:asp.Net 来源:网络整理
导读:一些MVC 4应用程序的用户正在经历零星的缓慢.大概不是每个用户每次发生这种情况都会报告这个问题. 我的想法是测量每个控制器操作中花费的时间,并记录超过规定时间的操作调用详细信息,以便于进一步分析(统治或排除服务器/代码问题). 有没有方便的方法来进行这
一些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 – 如何在EnableSessionState =“False”的请求中获
- js_jquery_创建cookie有效期问题_时区问题
- 是否可以优化ASP.NET WebForms以便像ASP.NET MVC一样快速执
- .net-core – VS 2017如何构建和测试包含.Net Core的混合解
- asp.net-mvc – 允许操作和视图和模型的高度变化
- asp.net-mvc-3 – ASP.NET MVC3 Razor:没有@if或@foreach可
- asp.net – 如何序列化LINQ-to-SQL惰性列表
- 获取会话在ASP.NET中优雅地过期
- asp.net – SQLDataReader:处理空值
- asp.net-mvc – ASP.NET MVC 3应用程序,BCrypt.CheckPasswo
推荐文章
站长推荐
- asp.net-mvc – 将List参数传递到ASP.NET MVC3中
- asp.net – 使用“DataType.Upload”属性为属性生
- asp.net-mvc – 编辑GridModel中的链接(MVCContr
- asp.net – Firefox 4.0总是刷新Silverlight XAP
- asp.net – 作为MVC路径参数的文件路径
- asp.net-mvc-3 – 型号型号无法更新mvc
- asp-classic – 如何在asp经典中触发异步调用并忽
- asp.net – Team Build 2010和web.config转换的问
- 适用于ASP.NET Core 2的MultipartFormDataStream
- asp.net – jQuery的ajax正在导致FireFox的全页刷
热点阅读