Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Filter support for ASP.NET Core metrics #1765

Open
vishweshbankwar opened this issue Oct 23, 2023 · 14 comments
Open

Filter support for ASP.NET Core metrics #1765

vishweshbankwar opened this issue Oct 23, 2023 · 14 comments
Labels
comp:extensions.enrichment.aspnetcore Things related to OpenTelemetry.Extensions.Enrichment.AspNetCore enhancement New feature or request

Comments

@vishweshbankwar
Copy link
Member

vishweshbankwar commented Oct 23, 2023

Some pre-release versions of Metrics instrumentation provided support for filtering out measurements for http.server.request.duration. This option is removed in open-telemetry/opentelemetry-dotnet#4981 and is not available in any of the supported .NET versions.

Please share your feedback here in case you are affected by this change. Explain your scenario in detail as to why this feature is needed.

@ZRich97
Copy link
Contributor

ZRich97 commented Nov 10, 2023

Adding comment from discussion on #1426:

The main use case in my mind is filtering out unused metrics (noise). Some of our supported services don't need to collect metrics for every route in the application (and they currently don't in their non-OTel monitoring solutions). This filtering could also be done at the alerting/monitoring stage (metrics we don't care about could be identified by the dimensions collected/enriched by this instrumentation and filtered out of any dashboards/alerts), but why not avoid collecting unused metrics altogether?

Metric-level filters seem like the best way to reduce possible noise and collect metrics only for the routes/requests service owners are most interested in. Is there another OTel construct or tool aside from the Instrumentation packages that would fill the same role in its absence? Is there any downside to having filter options available?

Our team is starting to move towards OTel across our .NET services. If there is a better approach we'd be interested in trying it out as well. Thanks!

@cd21h
Copy link

cd21h commented Nov 24, 2023

Please bring filtering back. As it was mentioned above, one use case is to reduce noise caused by healthchecks

@akoken
Copy link
Contributor

akoken commented Jan 4, 2024

I really don't understand the reason behind removing already implemented features. Performance or allocation? Even if so, that's a tradeoff which should be considered by the consumer. IMHO, Enrich and Filter should be de facto for all instrumentations.

We operate many microservices, each with multiple instances, within the Kubernetes environment. As you may know, it's best practice to use liveness and readiness probes for health check in K8s. However, it's worth noting that they contribute to increased metric noise.

// Should be filtered
/health/live
/health/ready
/metrics

@EraYaN
Copy link

EraYaN commented Jan 12, 2024

We filter out a lot of health checks, version checks and a couple of internal controllers that are already kept track of in another way. Or for requests that result is very high cardinality. This reduces the total amount of noise in our metrics systems. And the additional load is negligible for us at least, our requests are quite heavy.

@vchirikov
Copy link

We also exclude k8s health checks or favicon.ico, robots.txt etc, it's very useful feature.

@joebeernink
Copy link

Adding my vote here for filtering out routes for health checks.

  1. Since metrics are created in the AppMetrics table in LogAnalytics, adding all of these unnecessary routes increases our Azure costs
  2. Filtering these calls out on the query side of metrics means a lot of manual updating of queries when calculating overall Availability of the service for customer facing queries and for calculating service latencies. Since these calls are made very frequently, a service that gets relatively few calls from the customer could show wrong customer facing stats without the filters.

Basically, lack of this feature drives up cost of operations for the system, and the consumer should be able to choose which costs are bearable and which are not.

@WeihanLi
Copy link
Contributor

WeihanLi commented Jan 29, 2024

Also hoping to see the feature, while think it may be better to support from the .NET API so that the metrics we do not care would not be produced

also link to an issue in dotnet/aspnetcore dotnet/aspnetcore#50654

@bakgaard
Copy link

We are looking forward to this coming back. There's a lot of extra in our exposed metrics right now (/metrics, /healthz/*)

@Elter71
Copy link

Elter71 commented Mar 11, 2024

Any update on this issue?

@xkursatx
Copy link

xkursatx commented Apr 8, 2024

by adding OpenTelemetry.Instrumentation.AspNetCore
and

builder.Services.AddOpenTelemetry()
    .WithMetrics(builder =>
    {
        builder
            .AddPrometheusExporter()
            .AddMeter("Microsoft.AspNetCore.Hosting", "Microsoft.AspNetCore.Server.Kestrel");

    })
    .WithTracing(builder =>
    {
        builder
            .AddAspNetCoreInstrumentation((options) => options.Filter = httpContext =>
            {
                if (httpContext.Request.Path.Value == "/metrics")
                {
                    return false;
                }
                return true;
            });
    });

i think this will resolve my problem. not tested yet but seems bright enough

@vishweshbankwar
Copy link
Member Author

Thanks everyone for the feedback - The feature is requested for .NET9.0. Please track dotnet/aspnetcore#50654 for updates.

@vishweshbankwar vishweshbankwar transferred this issue from open-telemetry/opentelemetry-dotnet May 14, 2024
@Kielek Kielek added the comp:extensions.enrichment.aspnetcore Things related to OpenTelemetry.Extensions.Enrichment.AspNetCore label May 17, 2024
@akoken
Copy link
Contributor

akoken commented Jun 6, 2024

It appears we need to wait for this fundamental feature until the .NET 9 release. Most of our customers only upgrade to LTS versions, which means we likely have to wait until .NET 10 or 11. Splendid!

@riezebosch
Copy link

by adding OpenTelemetry.Instrumentation.AspNetCore and

builder.Services.AddOpenTelemetry()
    .WithMetrics(builder =>
    {
        builder
            .AddPrometheusExporter()
            .AddMeter("Microsoft.AspNetCore.Hosting", "Microsoft.AspNetCore.Server.Kestrel");

    })
    .WithTracing(builder =>
    {
        builder
            .AddAspNetCoreInstrumentation((options) => options.Filter = httpContext =>
            {
                if (httpContext.Request.Path.Value == "/metrics")
                {
                    return false;
                }
                return true;
            });
    });

i think this will resolve my problem. not tested yet but seems bright enough

I solved this in my otel collector configuration using the filter processor:

  filter/ottl:
    error_mode: ignore
    traces:
      span:
        - attributes["url.path"] == "/metrics"

remark that I updated my configuration to match your example, not sure about the real url path.

@6030831
Copy link

6030831 commented Dec 4, 2024

I have Blazor Server app which also has some API implemented, and for some unrelated reasons I had to switch the Blazor transport to LongPolling (instead of WebSocket). The LongPolling transport is generating an heavy http traffic, that is literarily polluting the metrics. So without filtering capability, there is no other option than switching off the metric collection for ASP.NET queries.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
comp:extensions.enrichment.aspnetcore Things related to OpenTelemetry.Extensions.Enrichment.AspNetCore enhancement New feature or request
Projects
None yet
Development

No branches or pull requests