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

Unsupported usage of MetricsLevel #280

Open
mx-psi opened this issue Jan 21, 2025 · 7 comments
Open

Unsupported usage of MetricsLevel #280

mx-psi opened this issue Jan 21, 2025 · 7 comments

Comments

@mx-psi
Copy link
Member

mx-psi commented Jan 21, 2025

👋 I am looking to drop MetricsLevel from component.TelemetrySettings, and replace this with a system with which components can pass to the service a set of views that control this (see open-telemetry/opentelemetry-collector/issues/11754).

otel-arrow is one of the two components that currently use MetricsLevel so I am analyzing how it uses MetricsLevel. There is one usage here:

if c.metricsLevel > configtelemetry.LevelDetailed {
kvs = append(kvs, c.uniqueAttr)
}
that (AFAICT) would not be supported through views: views allow you to filter at the instrument level, but not at the timeseries level.

This would have to be removed or changed for addressing open-telemetry/opentelemetry-collector/issues/11061. To address this issue, I will create views to replicate the current behavior (see open-telemetry/opentelemetry-collector/pull/12143) and set the metrics level to a fixed value on the otelarrow receiver.

@jade-guiton-dd
Copy link

As far as I know, LevelDetailed is the highest possible metricsLevel; doesn't this mean that the conditional is never triggered?

@mx-psi mx-psi self-assigned this Jan 21, 2025
@mx-psi
Copy link
Member Author

mx-psi commented Jan 21, 2025

Good catch, this seems like dead code then

@mx-psi mx-psi removed this from Collector: v1 Jan 21, 2025
@mx-psi mx-psi removed their assignment Jan 21, 2025
@mx-psi
Copy link
Member Author

mx-psi commented Jan 21, 2025

I am going to unassign myself since there is nothing to do here for Collector 1.0

github-merge-queue bot pushed a commit to open-telemetry/opentelemetry-collector that referenced this issue Jan 22, 2025
<!--Ex. Fixing a bug - Describe the bug and how this fixes the issue.
Ex. Adding a feature - Explain what this achieves.-->
#### Description

<!-- Issue number if applicable -->

Drops metrics that depend on the metrics level:
- Batch processor metric
- otelarrow metrics (see open-telemetry/otel-arrow/issues/280 for
limitation).
- internal/otelarrow/netstats metrics. I did not implement
https://github.com/open-telemetry/opentelemetry-collector-contrib/blob/a25f058256e8339e49e4c89ac622a9ef47b52334/internal/otelarrow/netstats/netstats.go#L133-L136
since `LevelNone` drops all metrics.

This attemps to unblock #11601 by hardcoding the metrics here since
there is a small number of them. Once we do #11754 we can move this back
to the individual components

#### Link to tracking issue

Updates #11061
github-merge-queue bot pushed a commit to open-telemetry/opentelemetry-collector that referenced this issue Jan 22, 2025
<!--Ex. Fixing a bug - Describe the bug and how this fixes the issue.
Ex. Adding a feature - Explain what this achieves.-->
#### Description

<!-- Issue number if applicable -->

Drops metrics that depend on the metrics level:
- Batch processor metric
- otelarrow metrics (see open-telemetry/otel-arrow/issues/280 for
limitation).
- internal/otelarrow/netstats metrics. I did not implement
https://github.com/open-telemetry/opentelemetry-collector-contrib/blob/a25f058256e8339e49e4c89ac622a9ef47b52334/internal/otelarrow/netstats/netstats.go#L133-L136
since `LevelNone` drops all metrics.

This attemps to unblock #11601 by hardcoding the metrics here since
there is a small number of them. Once we do #11754 we can move this back
to the individual components

#### Link to tracking issue

Updates #11061
@jmacd
Copy link
Contributor

jmacd commented Jan 22, 2025

Let's remove the code associated with this MetricsLevel.

@drewrelmas
Copy link
Collaborator

I will try and pick this one up and remove the unused code!

jmacd pushed a commit that referenced this issue Jan 24, 2025
Related to issue #280 

Also see
open-telemetry/opentelemetry-collector#11061
and open-telemetry/opentelemetry-collector#12143

There is a movement to remove `MetricsLevel` from the Collector's
`TelemetrySettings`, which is used explicitly in various places in the
otel-arrow project.

In addition to the 'dead code' identified in #280, this PR aims to
remove other instances of reference to `MetricsLevel`.

In one case this is not currently possible because a component in
`opentelemetry-collector-contrib` depends on an `otel-arrow
arrow_record` function signature including `MetricsLevel`, see
[otelarrowreceiver](https://github.com/open-telemetry/opentelemetry-collector-contrib/blob/c4abcb96bb70ab37135217614a96f309ea6c88d9/receiver/otelarrowreceiver/otelarrow.go#L145).
Instead, introduced a temporary
[`WithMeterProviderAlt`](https://github.com/open-telemetry/otel-arrow/pull/283/files#diff-23b4f69113b23c58e3e4bff6345e435dccf86d01ce65c9e49c341b0cdc605cc2)
without that paramater that should become the new default implementation
once the Contrib component is updated accordingly.
@drewrelmas
Copy link
Collaborator

@mx-psi have removed this code snippet. It is a step towards eventual removal of all MetricsLevel usage, but will require a few release cycles to fully remove as mentioned in #283.

@mx-psi
Copy link
Member Author

mx-psi commented Jan 27, 2025

Thank you! :)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants