华域联盟 .Net .NET必知的EventCounters性能指标监视器详解

.NET必知的EventCounters性能指标监视器详解

.NET必知的EventCounters性能指标监视器详解
 更新时间:2020年11月14日 13:54:24   作者:HueiFeng  

这篇文章主要介绍了.NET必知的EventCounters性能指标监视器,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

在.NET我们对于性能指标监控,其实常见的有两个方法,一个是CLI工具dotnet-counters而另一个是代码级别的EventListener.
使用dotnet-counters
dotnet-counters是一个性能指标监视工具,用于临时运行状态监视和初级性能调查。它可以观察通过 EventCounter API发布的性能计数器值。例如,可以快速监视 CPU 使用情况或 .NET Core 应用程序中引发的异常率,以了解在使用 PerfView 或 dotnet-trace 深入调查更严重的性能问题之前是否有任何可疑操作。
-- 摘自 dotnet-counters
命令
dotnet-counters collect
dotnet-counters list
dotnet-counters monitor
dotnet-counters ps
安装dotnet-counters CLI工具,可通过如下命令:

dotnet tool install --global dotnet-counters

更新命令如下所示:

dotnet tool update dotnet-counters --global

安装完工具之后,我们可以进行查看可监视的进程:

dotnet-counters ps
12268 dotnet C:\\Program Files\\dotnet\\dotnet.exe
16324 dotnet C:\\Program Files\\dotnet\\dotnet.exe

获取到进程ID后,我们可以通过如下命令进行监视:

dotnet-counters monitor -p 12268

监视特定的EventSources,可以提供以一个空格分隔开的EventSources列表,如下所示:

dotnet-counters monitor -p 12268 System.Runtime MyEventSource

在默认的情况下,我们对于EventSource监视时,它捕获的是所有的计数器。如果我们想单独跟踪某几个计数器那么可通过如下方式进行指定:

dotnet-counters monitor -p 12268 System.Runtime[cpu-usage,gc-heap-size]

对于监视器我们可以设置刷新频率,可以通过--refresh-interval参数来设置:

dotnet-counters monitor -p 12268 --refresh-interval 3 System.Runtime[cpu-usage,gc-heap-size]

代码中的EventCounters
EventListener提供了进程内(In-Process)订阅和消费日志事件的方式,EventListener可以接收到来自EventSource分发的日志事件。 这些事件内涵盖了GC、JIT、ThreadPool和interop的行为。
创建EventListener
在下面我们进行重写OnEventSourceCreated方法,该方法会在调用时接收一个EventSource对象,我们可以通过EventSource对象的Name属性去筛选我们感兴趣的日志事件,筛选后我们需要显示的调用EnableEvents方法向感兴趣的日志事件发起订阅。

internal sealed class MyEventListener : EventListener
{
protected override void OnEventSourceCreated(EventSource eventSource)
{
if (eventSource.Name.Equals("Microsoft-Windows-DotNETRuntime"))
{
EnableEvents(eventSource, EventLevel.Verbose, (EventKeywords)(-1));
}
}
}

事件消费
接下来我们需要进行重写OnEventWritten,关于日志事件相关的信息会被封装成一个EventWrittenEventArgs对象,我们不仅可以通过它获取当前日志事件的所有信息,而且我们还可以进行获取到EventSource对象。Payload包含了不同属性的值ReadOnlyCollection<object>, 而PayLoadNames ReadOnlyCollection<object>中包含了不同的属性名称,我们现在可以通过如下方式进行获取这些属性:

protected override void OnEventWritten(EventWrittenEventArgs eventData)
{
Console.WriteLine($"ThreadID = {eventData.OSThreadId} ID = {eventData.EventId} Name = {eventData.EventName}");
for (int i = 0; i < eventData.Payload.Count; i++)
{
string payloadString = eventData.Payload[i]?.ToString() ?? string.Empty;
Console.WriteLine($"\\tName = \\"{eventData.PayloadNames[i]}\\" Value = \\"{payloadString}\\"");
}
Console.WriteLine("\\n");
}

参考
stackoverflow.com/questions/61081063/get-total-number-of-allocations-in-c-sharp
到此这篇关于.NET必知的EventCounters性能指标监视器详解的文章就介绍到这了,更多相关.NET性能指标监视器内容请搜索华域联盟以前的文章或继续浏览下面的相关文章希望大家以后多多支持华域联盟!

.NET
EventCounters
性能指标监视器

相关文章
Asp.net在ashx文件中处理Session问题解决方法Asp.net在ashx文件中处理Session问题解决方法,需要的朋友可以参考一下 2013-05-05
asp.net下结合HttpHandler实现图片防盗链asp.net防图片盗链HttpHandler 2010-07-07
禁止ViewState的3种解决方法默认情况下,ViewState是被启用的,比如提交表单后,表单中输入的值会自动保留。但是如果不需要保留,也可以将其禁用,这样可以节省资源。 2013-03-03
ASP.NET MVC 项目直接预览PDF文件本文主要介绍了ASP.NET MVC项目实现直接预览PDF文件的方法,具有很好的参考价值,下面跟着小编一起来看下吧 2017-02-02
Asp.Net 动态页面转静态页面主要代码关于在Asp.Net中动态页面转静态页面的方法网上比较多。结合实际的需求,我在网上找了一些源代码,并作修改。现在把修改后的代码以及说明写一下。 2009-12-12
asp.net 未能加载文件或程序集“XXX”或它的某一个依赖项。试图加运行asp.net后提示未能加载文件或程序集“XXX”或它的某一个依赖项。试图加载格式不正确的程序。 2011-07-07
几种判断asp.net中session过期方法的比较几种判断asp.net中session过期方法的比较,需要的朋友可以参考一下 2013-04-04
动态指定任意类型的ObjectDataSource对象的查询参数我在使用ObjectDataSource控件在ASP.NET中实现Ajax真分页 一文中详细介绍过如何使用ObjectDataSource和ListView实现数据绑定和分页功能。事实上,采用ObjectDataSource和ListView相结合,可以减少我们很多的开发任务。
2009-11-11
.NET Core2.1如何获取自定义配置文件信息详解这篇文章主要给大家介绍了关于.NET Core2.1如何获取自定义配置文件信息的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧 2018-08-08
ASP.NET中等安全模式的一些经验分享如果你正在开发一个通用型的Web产品,比如BBS、CMS、BLOG这类的,那么,建议你阅读以下本篇文章。 2010-01-01

最新评论

本文由 华域联盟 原创撰写:华域联盟 » .NET必知的EventCounters性能指标监视器详解

转载请保留出处和原文链接:https://www.cnhackhy.com/5024.htm

本文来自网络,不代表华域联盟立场,转载请注明出处。

作者:

发表回复

联系我们

联系我们

2551209778

在线咨询: QQ交谈

邮箱: [email protected]

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部