导读
CZGL.ProcessMetrics 是一个 Metrics 库,能够将程序的 GC、CPU、内存、机器网络、磁盘空间等信息记录下来,使用 Prometheus 采集信息,然后使用 Grafana 显示。
效果图预览:
2.0 和 .NET Core 3.1,但是在 .NET Standard 2.0 中,因为缺少部分 Core API,所以有部分信息是无法获取的,这部分信息如下:
| 标识 | .NET Core API | 说明 |
|---|---|---|
| gc_memory_info | GC.GetGCMemoryInfo() | 获取 GC 内存信息 |
| total_allocated_bytes | GC.GetTotalAllocatedBytes() | 总分配量 |
| dotnet_lock_contention_total | Monitor.LockContentionCount | 线程池竞争数量 |
新建一个应用, Nuget 中搜索 CZGL.ProcessMetrics 直接引用即可。
Nuget 地址:https://www.nuget.org/packages/CZGL.ProcessMetrics
有两种方式使用 Metrics,第一种是使用内置的 HttpListener,不需要放到 Web 中即可独立提供 URL 访问,适合 winform、wpf 或纯 控制台等应用。但是使用 HttpListener,需要使用管理员方式启动应用才能正常运行。
使用方法:
using CZGL.ProcessMetrics;... ...MetricsServer metricsServer = new MetricsServer("http://*:1234/metrics/");metricsServer.Start();另外一种是使用 ASP.NET Core,Metrics 作为中间件加入到 Web 应用中,此时使用的是 kestrel 。
在 Nuget 中,搜索 CZGL.ProcessMetrics.ASPNETCore 包,然后使用中间件生成 Metrics 端点。
app.UseEndpoints(endpoints => { endpoints.MapControllers(); endpoints.ProcessMetrices("/metrics"); });但是目前无论哪种,都必须让暴露端口出去,让 Prometheus 能够访问到 API。后期会增加支持不需要暴露 API 、提供 Web 服务,即可直接推送监控信息到 Prometheus 的功能。
访问相应的 URL,可以看到有很多信息输出,这些都是 Prometheus 数据的格式。
http://127.0.0.1:1234/metrics
/lib/grafana grafana/grafana
打开 9090 端口,在菜单栏中打开 Status-Targets,可以看到有相关记录。

接着,访问 3000 端口,打开 Grafana,初始账号密码都是 admin 。
配置 Grafana
首先我们要为 Grafana 获取 Prometheus 中的监控数据,我们要添加一个数据源。

选择 Prometheus,按照提示,填写好 HTTP-URL 即可。

接着,下载笔者定制好的 jsom Model,文件名为 CZGL.ProcessMetrics.json。
下载地址:
https://github.com/whuanle/CZGL.SystemInfo/releases/tag/v1.0
然后导入模型文件。


即可看到监控界面。

到此这篇关于CZGL.ProcessMetrics监控.NET应用的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持我们。








