C#.Net Mvc运营监控,计算方法/接口/action/页面执行时间
2016-08-22 09:10
746 查看
1、建立一个TimingActionFilter过滤器
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是因为每次重新生成项目,所以第一次会这么慢,这种不管它就是了:)
本文来自:http://www.itdos.com/Mvc/20150324/0126300.html 转载请保留此链接,谢谢!
相关文章推荐
- 【C#编程】遍历List并删除指定元素的正确方式
- 第2章 C#编程概述
- 让某个软件无法被操作员最小化(C#演示)
- C#更接近于人的思维习惯
- 【C#】Dictionary和List泛型比较
- C#之MessageBox
- C# 利用反射根据类名创建类的实例对象
- C#基础知识(十一)——泛型集合、文件管理、多态、接口
- 【项目学习】——C#自动生成错误日志
- C#中的运算符
- C# 参考之方法参数关键字:参数数组params、引用参数ref及输出参数out
- C#控件开发学习问题一:安全透明方法……尝试访问安全关键方法……错误
- C#读取并保存导出Resource资源文件
- C#柱状图
- C# winform 中MessageBox用法大全(附效果图)
- C#高级编程 - 小鸟系列之反射的用法
- C#生成不同随机数
- C#中的listview选中整行是什么属性?
- U3D开发学习之路--C#基础
- C#中的WebBrowser控件,如何做到点击页面中的链接保持在应用程序内打开而不是用IE打开