C#.Net Mvc运营监控,计算方法/接口/action/页面执行时间
2017-03-05 23:02
465 查看
1、建立一个TimingActionFilter过滤器
2、代码如下:
其中LogHelper.WriteLog是我的写日志文件通用类,修改成你自己的即可。
3、给controller或action加上特性
4、执行时间或渲染时间大于100ms会被记录下来
我这里有好几次执行时间7、800ms是因为每次重新生成项目,所以第一次会这么慢,这种不管它就是了:)
2、代码如下:
public class TimingActionFilter : ActionFilterAttribute { public override void OnActionExecuting(ActionExecutingContext filterContext) { GetTimer(filterContext, "action").Start(); base.OnActionExecuting(filterContext); } public override void OnActionExecuted(ActionExecutedContext filterContext) { GetTimer(filterContext, "action").Stop(); base.OnActionExecuted(filterContext); } public override void OnResultExecuted(ResultExecutedContext filterContext) { var renderTimer = GetTimer(filterContext, "render"); renderTimer.Stop(); var actionTimer = GetTimer(filterContext, "action"); if (actionTimer.ElapsedMilliseconds >= 100 || renderTimer.ElapsedMilliseconds >= 100) { LogHelper.WriteLog("运营监控(" + filterContext.RouteData.Values["controller"] + ")", String.Format( "【{0}】-【{1}】,执行:{2}ms,渲染:{3}ms", filterContext.RouteData.Values["controller"], filterContext.RouteData.Values["action"], actionTimer.ElapsedMilliseconds, renderTimer.ElapsedMilliseconds )); } base.OnResultExecuted(filterContext); } public override void OnResultExecuting(ResultExecutingContext filterContext) { GetTimer(filterContext, "render").Start(); base.OnResultExecuting(filterContext); } private Stopwatch GetTimer(ControllerContext context, string name) { string key = "__timer__" + name; if (context.HttpContext.Items.Contains(key)) { return (Stopwatch)context.HttpContext.Items[key]; } var result = new Stopwatch(); context.HttpContext.Items[key] = result; return result; } }
其中LogHelper.WriteLog是我的写日志文件通用类,修改成你自己的即可。
3、给controller或action加上特性
4、执行时间或渲染时间大于100ms会被记录下来
我这里有好几次执行时间7、800ms是因为每次重新生成项目,所以第一次会这么慢,这种不管它就是了:)
相关文章推荐
- C#.Net Mvc运营监控,计算方法/接口/action/页面执行时间
- C#.Net Mvc运营监控,计算方法/接口/action/页面执行时间
- asp.net计算每个页面执行时间的方法
- C#计算代码执行时间的方法
- asp.net计算每个页面执行时间的方法
- C#计算代码执行时间的方法
- 计算页面执行时间的两种方法
- java 方法的执行时间监控 设置超时(Future 接口)
- 计算页面执行时间的两种方法
- c# 统计方法执行时间,计算缓存读取数据方法的命中率
- [导入]c# 统计方法执行时间,计算缓存读取数据方法的命中率
- C# 计算方法执行需要的时间
- C#计算程序执行过程花费时间的方法
- C#接口性能测试--计算执行时间
- 三行代码实现.NET MVC统计显示页面的执行时间 超简单的实现方法 分析页面执行效率
- C# TimeSpan类计算程序执行的时间及此类的其他常用方法
- c# 计算程序执行时间方法
- C#与SQL中计算时间差的方法
- ASP怎么计算页面执行时间
- JSP中计算页面执行(处理)时间