asp.net core接入prometheus2-自定义指标

前提

了解一下asp.net core接入prometheus快速入门
https://blog.csdn.net/qq_36437991/article/details/139064138

新建.net 8空web项目

安装下面三个包

xml 复制代码
<PackageReference Include="OpenTelemetry.Exporter.Prometheus.AspNetCore" Version="1.8.0-rc.1" />
<PackageReference Include="OpenTelemetry.Extensions.Hosting" Version="1.8.1" />
<PackageReference Include="System.Diagnostics.DiagnosticSource" Version="8.0.1" />

创建指标

HatCoMetrics.cs

cs 复制代码
using System.Diagnostics.Metrics;

namespace PrometheusStu03;

/// <summary>
/// 红帽子指标
/// </summary>
public class HatCoMetrics
{
    private readonly Counter<int> _hatsSold;

    public HatCoMetrics(IMeterFactory meterFactory)
    {
        //红帽子商店
        var meter = meterFactory.Create("HatCo.Store");
        //冲帽子商店销量
        _hatsSold = meter.CreateCounter<int>("hatco.store.hats_sold",unit:"{hats}",description:"我们商店出售的帽子数量");
    }

    /// <summary>
    /// 增加数量
    /// </summary>
    /// <param name="quantity"></param>
    public void HatsSold(int quantity)
    {
        _hatsSold.Add(quantity);
    }
}

指标收集

修改Program.cs

cs 复制代码
using OpenTelemetry.Metrics;

namespace PrometheusStu03;

public class Program
{
    public static void Main(string[] args)
    {
        var builder = WebApplication.CreateBuilder(args);
        builder.Services.AddSingleton<HatCoMetrics>();
        var app = builder.Build();
        app.UseOpenTelemetryPrometheusScrapingEndpoint();
        app.MapGet("/", (HatCoMetrics metrics) =>
        {
            //可以将销量存放到数据库中
            metrics.HatsSold(1);
            return "销售数量加1";
        });
        app.Run();
    }
}

这样访问就能增加帽子的销量了

指标展示

修改Program.cs

cs 复制代码
using OpenTelemetry.Metrics;

namespace PrometheusStu03;

public class Program
{
    public static void Main(string[] args)
    {
        var builder = WebApplication.CreateBuilder(args);
        builder.Services.AddSingleton<HatCoMetrics>();
        builder.Services.AddOpenTelemetry()
            .WithMetrics(builder2 =>
            {
                builder2.AddPrometheusExporter();
                builder2.AddMeter("HatCo.Store");
            });
        var app = builder.Build();
        app.UseOpenTelemetryPrometheusScrapingEndpoint();
        app.MapGet("/", (HatCoMetrics metrics) =>
        {
            //可以将销量存放到数据库中
            metrics.HatsSold(1);
            return "销售数量加1";
        });
        app.Run();
    }
}

展示内置指标

cs 复制代码
builder.Services.AddOpenTelemetry()
  .WithMetrics(builder2 =>
  {
      builder2.AddPrometheusExporter();
      builder2.AddMeter("Microsoft.AspNetCore.Hosting",
           "Microsoft.AspNetCore.Server.Kestrel","HatCo.Store");
  });

参考

创建指标
.net中的内置指标
asp.net core中的指标
.net中的常见指标
.net core指标收集

相关推荐
子春一12 小时前
Flutter for OpenHarmony: 从颜色模型到可访问性:一个 Flutter 高对比度 UI 的完整实践
flutter·ui
雨季66614 小时前
Flutter 三端应用实战:OpenHarmony 简易数字累加器开发指南
开发语言·flutter·ui·ecmascript
●VON14 小时前
Flutter for OpenHarmony:基于 SharedPreferences 的本地化笔记应用架构与实现
笔记·学习·flutter·ui·架构·openharmony·von
ujainu15 小时前
Flutter + OpenHarmony实现高保真闹钟 App:从 UI 设计到实时触发机制全解析
flutter·ui
晚霞的不甘16 小时前
Flutter for OpenHarmony《智慧字典》 App 底部导航栏深度解析:构建多页面应用的核心骨架
前端·经验分享·flutter·ui·前端框架·知识图谱
子春一16 小时前
Flutter for OpenHarmony:构建一个交互式 Flutter RGB 颜色选择器,深入解析状态驱动 UI、HEX 转换与无障碍色彩对比
flutter·ui
雨季66616 小时前
Flutter 三端应用实战:OpenHarmony 简易文本首字母提取器开发指南
flutter·ui·dart
集成显卡1 天前
Lucide Icons:一套现代、轻量且可定制的 SVG 图标库
前端·ui·图标库·lucide
子春一1 天前
Flutter for OpenHarmony:构建一个高精度 Flutter 计时器:深入解析 Timer、状态同步与 UI 响应式设计
flutter·ui
雨季6661 天前
构建 OpenHarmony 简易文字行数统计器:用字符串分割实现纯文本结构感知
开发语言·前端·javascript·flutter·ui·dart