📄
src/Api/OpenTelemetryExtensions.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Hosting; using Microsoft.Extensions.Logging; using OpenTelemetry; using OpenTelemetry.Metrics; using OpenTelemetry.Trace; using Slopper.Infrastructure.Ffmpeg; namespace Slopper.Api; public static class OpenTelemetryExtensions { extension<TBuilder>(TBuilder builder) where TBuilder : IHostApplicationBuilder { public TBuilder ConfigureOpenTelemetry() { builder.Logging.AddOpenTelemetry(logging => { logging.IncludeFormattedMessage = true; logging.IncludeScopes = true; }); builder .Services.AddOpenTelemetry() .WithMetrics(metrics => { metrics .AddHttpClientInstrumentation() .AddRuntimeInstrumentation() .AddAspNetCoreInstrumentation() .AddMeter("Experimental.Microsoft.Extensions.AI"); }) .WithTracing(tracing => { tracing .AddSource(builder.Environment.ApplicationName) .AddHttpClientInstrumentation() .AddEntityFrameworkCoreInstrumentation() .AddAspNetCoreInstrumentation() .AddFfmpegInstrumentation() .AddQuartzInstrumentation() .AddSource("Experimental.Microsoft.Extensions.AI"); }); builder.AddOpenTelemetryExporters(); return builder; } private TBuilder AddOpenTelemetryExporters() { var useOtlpExporter = !string.IsNullOrWhiteSpace(builder.Configuration["OTEL_EXPORTER_OTLP_ENDPOINT"]); if (useOtlpExporter) { builder.Services.AddOpenTelemetry().UseOtlpExporter(); } return builder; } } }