Use sync.Map and atomics for lastvalue aggregations#7478
Merged
dmathieu merged 3 commits intoopen-telemetry:mainfrom Dec 16, 2025
Merged
Use sync.Map and atomics for lastvalue aggregations#7478dmathieu merged 3 commits intoopen-telemetry:mainfrom
dmathieu merged 3 commits intoopen-telemetry:mainfrom
Conversation
f6c58df to
27e1482
Compare
Codecov Report✅ All modified and coverable lines are covered by tests. Additional details and impacted files@@ Coverage Diff @@
## main #7478 +/- ##
=====================================
Coverage 86.2% 86.2%
=====================================
Files 302 302
Lines 21971 21985 +14
=====================================
+ Hits 18950 18963 +13
- Misses 2640 2641 +1
Partials 381 381
🚀 New features to boost your workflow:
|
21ba34b to
1d5d6d3
Compare
1d5d6d3 to
081a206
Compare
Contributor
Author
dmathieu
approved these changes
Dec 15, 2025
Contributor
Author
Member
|
Urgh sorry, I missed the lack of second approval. |
Contributor
|
I was about halfway though this. I can take another look and see. |
MrAlias
reviewed
Dec 16, 2025
Contributor
MrAlias
left a comment
There was a problem hiding this comment.
Overall this looks good. Minor feedback on comments and the return value.
| ) int { | ||
| // Ignore if dest is not a metricdata.Gauge. The chance for memory reuse of | ||
| // the DataPoints is missed (better luck next time). | ||
| // the lastValuePoints is missed (better luck next time). |
Contributor
There was a problem hiding this comment.
Suggested change
| // the lastValuePoints is missed (better luck next time). | |
| // the DataPoints is missed (better luck next time). |
This is still referring to the dest field.
| s.hotColdValMap[readIdx].values.Clear() | ||
| *dest = gData | ||
|
|
||
| return n |
Contributor
There was a problem hiding this comment.
Suggested change
| return n | |
| return i |
If range for some reason does not iterate over n values, this will be incorrect.
|
|
||
| func newLastValue[N int64 | float64](limit int, r func(attribute.Set) FilteredExemplarReservoir[N]) *lastValue[N] { | ||
| return &lastValue[N]{ | ||
| // lastValue summarizes a set of measurements as the last one made. |
Contributor
There was a problem hiding this comment.
Suggested change
| // lastValue summarizes a set of measurements as the last one made. | |
| // lastValueMap summarizes a set of measurements as the last one made. |
Contributor
Author
|
@MrAlias are you OK with a follow-up PR? |
Contributor
Yeah 👍 |
Contributor
Author
dashpole
added a commit
that referenced
this pull request
Dec 16, 2025
Addresses #7478 (review), which was left after the PR merged.
dashpole
added a commit
to dashpole/opentelemetry-go
that referenced
this pull request
Dec 17, 2025
Addresses open-telemetry#7478 (review), which was left after the PR merged.
Merged
MrAlias
added a commit
that referenced
this pull request
Feb 2, 2026
### Added - Add `Enabled` method to all synchronous instrument interfaces (`Float64Counter`, `Float64UpDownCounter`, `Float64Histogram`, `Float64Gauge`, `Int64Counter`, `Int64UpDownCounter`, `Int64Histogram`, `Int64Gauge`,) in `go.opentelemetry.io/otel/metric`. This stabilizes the synchronous instrument enabled feature, allowing users to check if an instrument will process measurements before performing computationally expensive operations. (#7763) - Add `AlwaysRecord` sampler in `go.opentelemetry.io/otel/sdk/trace`. (#7724) - Add `go.opentelemetry.io/otel/semconv/v1.39.0` package. The package contains semantic conventions from the `v1.39.0` version of the OpenTelemetry Semantic Conventions. See the [migration documentation](https://github.com/open-telemetry/opentelemetry-go/blob/298cbedf256b7a9ab3c21e41fc5e3e6d6e4e94aa/semconv/v1.39.0/MIGRATION.md) for information on how to upgrade from `go.opentelemetry.io/otel/semconv/v1.38.0.` (#7783, #7789) ### Changed - `Exporter` in `go.opentelemetry.io/otel/exporter/prometheus` ignores metrics with the scope `go.opentelemetry.io/contrib/bridges/prometheus`. This prevents scrape failures when the Prometheus exporter is misconfigured to get data from the Prometheus bridge. (#7688) - Improve performance of concurrent histogram measurements in `go.opentelemetry.io/otel/sdk/metric`. (#7474) - Add experimental observability metrics in `go.opentelemetry.io/otel/exporters/stdout/stdoutmetric`. (#7492) - Improve the concurrent performance of `HistogramReservoir` in `go.opentelemetry.io/otel/sdk/metric/exemplar` by 4x. (#7443) - Improve performance of concurrent synchronous gauge measurements in `go.opentelemetry.io/otel/sdk/metric`. (#7478) - Improve performance of concurrent exponential histogram measurements in `go.opentelemetry.io/otel/sdk/metric`. (#7702) - Improve the concurrent performance of `FixedSizeReservoir` in `go.opentelemetry.io/otel/sdk/metric/exemplar`. (#7447) - The `rpc.grpc.status_code` attribute in the experimental metrics emitted from `go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc` is replaced with the `rpc.response.status_code` attribute to align with the semantic conventions. (#7854) - The `rpc.grpc.status_code` attribute in the experimental metrics emitted from `go.opentelemetry.io/otel/exporters/otlp/otlplog/otlploggrpc` is replaced with the `rpc.response.status_code` attribute to align with the semantic conventions. (#7854) ### Fixed - Fix bad log message when key-value pairs are dropped because of key duplication in `go.opentelemetry.io/otel/sdk/log`. (#7662) - Fix `DroppedAttributes` on `Record` in `go.opentelemetry.io/otel/sdk/log` to not count the non-attribute key-value pairs dropped because of key duplication. (#7662) - Fix `SetAttributes` on `Record` in `go.opentelemetry.io/otel/sdk/log` to not log that attributes are dropped when they are actually not dropped. (#7662) - `WithHostID` detector in `go.opentelemetry.io/otel/sdk/resource` to use full path for `ioreg` command on Darwin (macOS). (#7818) - Fix missing `request.GetBody` in `go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracehttp` to correctly handle HTTP2 GOAWAY frame. (#7794) ### Deprecated - Deprecate `go.opentelemetry.io/otel/exporters/zipkin`. For more information, see the [OTel blog post deprecating the Zipkin exporter](https://opentelemetry.io/blog/2025/deprecating-zipkin-exporters/). (#7670) --------- Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Depends on #7474
This applies similar optimizations as #7427 to the last value aggregation.
Changes for last value are contained in 27e1482.
Parallel benchmarks: