加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读