使用 .NET Core 中的 EventCounters 衡量性能

开发 后端
对于每隔几毫秒发生的事件,最好使每个事件的开销较低(小于一毫秒)。 否则,对性能的影响将很大。 记录事件意味着你将向磁盘写入内容。 如果磁盘不够快,你将丢失事件。 你需要一个解决方案,而不是记录事件本身。

背景

对于每隔几毫秒发生的事件,最好使每个事件的开销较低(小于一毫秒)。 否则,对性能的影响将很大。 记录事件意味着你将向磁盘写入内容。 如果磁盘不够快,你将丢失事件。 你需要一个解决方案,而不是记录事件本身。

在处理大量事件时,了解每个事件的度量值也无济于事。 大多数时候,你只需要一些统计信息。 因此,你可以在进程本身中获取统计信息,然后偶尔编写一个事件来报告统计信息,这是 EventCounter 将执行的操作。

代码实现

下面是有关如何实现 System.Diagnostics.Tracing.EventSource 的示例。 创建名为 MinimalEventCounterSource.cs 的新文件

  1. using System; 
  2. using System.Collections.Generic; 
  3. using System.Linq; 
  4. using System.Threading.Tasks; 
  5. using System.Diagnostics.Tracing; 
  6.  
  7. namespace WebApplication42 
  8.     [EventSource(Name = "Sample.EventCounter.Minimal")] 
  9.     public sealed class MinimalEventCounterSource : EventSource 
  10.     { 
  11.         public static readonly MinimalEventCounterSource Log = new MinimalEventCounterSource(); 
  12.  
  13.         private EventCounter _requestCounter; 
  14.  
  15.         private MinimalEventCounterSource() => 
  16.             _requestCounter = new EventCounter("request-time", this) 
  17.             { 
  18.                 DisplayName = "Request Processing Time"
  19.                 DisplayUnits = "ms" 
  20.             }; 
  21.  
  22.         public void Request(string url, float elapsedMilliseconds) 
  23.         { 
  24.             Console.WriteLine("url:" + url + "  elapsedMilliseconds:" + elapsedMilliseconds); 
  25.             WriteEvent(1, url, elapsedMilliseconds); 
  26.             _requestCounter?.WriteMetric(elapsedMilliseconds); 
  27.         } 
  28.  
  29.         protected override void Dispose(bool disposing) 
  30.         { 
  31.             _requestCounter?.Dispose(); 
  32.             _requestCounter = null
  33.  
  34.             base.Dispose(disposing); 
  35.         } 
  36.     } 

添加操作筛选器,创建名为 LogRequestTimeFilterAttribute.cs 的新文件,并使用以下代码:

  1. using Microsoft.AspNetCore.Http.Extensions; 
  2. using Microsoft.AspNetCore.Mvc.Filters; 
  3. using System; 
  4. using System.Collections.Generic; 
  5. using System.Diagnostics; 
  6. using System.Linq; 
  7. using System.Threading.Tasks; 
  8.  
  9. namespace WebApplication42 
  10.     public class LogRequestTimeFilterAttribute : ActionFilterAttribute 
  11.     { 
  12.         private readonly Stopwatch _stopwatch = new Stopwatch(); 
  13.  
  14.         public override void OnActionExecuting(ActionExecutingContext context) => _stopwatch.Start(); 
  15.  
  16.         public override void OnActionExecuted(ActionExecutedContext context) 
  17.         { 
  18.             _stopwatch.Stop(); 
  19.  
  20.             MinimalEventCounterSource.Log.Request( 
  21.                 context.HttpContext.Request.GetDisplayUrl(), _stopwatch.ElapsedMilliseconds); 
  22.         } 
  23.     } 

操作筛选器在请求开始时启动 Stopwatch,并在其完成后停止,捕获运行时间。 总毫秒数记录到 MinimalEventCounterSource 单一实例。 为了应用此筛选器,需要将其添加到筛选器集合。 在 Startup.cs 文件中,更新包含此筛选器的 ConfigureServices 方法。

  1. // This method gets called by the runtime. Use this method to add services to the container. 
  2.         public void ConfigureServices(IServiceCollection services) 
  3.         { 
  4.             services.AddControllers(options => options.Filters.Add<LogRequestTimeFilterAttribute>()); 
  5.             services.AddSwaggerGen(c => 
  6.             { 
  7.                 c.SwaggerDoc("v1", new OpenApiInfo { Title = "WebApplication42", Version = "v1" }); 
  8.             }); 
  9.         } 

 

  1. url:https://localhost:5008/WeatherForecast elapsedMilliseconds:70 
  2.  
  3. url:https://localhost:5008/WeatherForecast elapsedMilliseconds:19 
  4.  
  5. url:https://localhost:5008/WeatherForecast elapsedMilliseconds:18 
  6.  
  7. url:https://localhost:5008/WeatherForecast elapsedMilliseconds:19 
  8.  
  9. url:https://localhost:5008/WeatherForecast elapsedMilliseconds:22 
  10.  
  11. url:https://localhost:5008/WeatherForecast elapsedMilliseconds:17 
  12.  
  13. url:https://localhost:5008/WeatherForecast elapsedMilliseconds:17 

 

责任编辑:武晓燕 来源: UP技术控
相关推荐

2024-03-14 11:57:53

.NET Core反射开发

2021-11-11 16:46:02

CPU使用率 .NET

2019-08-12 08:00:00

ASP.NetASP.Net Cor编程语言

2021-02-19 06:54:33

配置系统ASP.NET Cor

2019-11-08 08:00:00

ASP .NETASP .NET Cocookie

2017-10-10 12:17:55

HTTPGo.NET Core

2023-11-16 08:34:23

.NETORM框架

2024-03-22 08:11:20

.NETJSON数据序列化

2015-08-21 10:36:32

.NETRedis

2019-01-21 09:55:25

LinuxNET Core SD命令

2021-06-30 08:00:00

代码DI开发

2017-12-14 14:32:30

.Net内存代码

2021-01-31 22:56:50

FromServiceASP

2021-03-10 09:40:43

LamarASP容器

2021-01-07 07:39:07

工具接口 Swagger

2021-02-03 13:35:25

ASPweb程序

2021-03-03 22:37:16

MediatR中介者模式

2021-01-28 22:39:35

LoggerMessa开源框架

2021-02-28 20:56:37

NCache缓存框架

2021-03-17 09:45:31

LazyCacheWindows
点赞
收藏

51CTO技术栈公众号