Consistent application of exporter customizers when otel.{signal}.exporter=none #7017
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.
While working on something else, I noticed a discrepancy between how autoconfigure handles exporter customization via SPI when
otel.metrics.exporter=none
, compared tootel.traces.exporter=none
andotel.logs.exporter=none
.For traces and logs, when exporter is set to
none
, we still invoke any respective exporter customizers registered viaAutoConfigurationCustomizer#addSpanExporterCustomizer
,AutoConfigurationCustomizer#addLogRecordExporterCustomizer
. For metrics, we do not apply such aAutoConfigurationCustomizer#addMetricExporterCustomizer
when exporter is set tonone
.This PR standardizes on the the metrics approach of not applying exporter customizers when exporter is set to
none
.While you can make arguments for either approach, the metrics approach is more correct / defensible since its less surprising. I don't think many people would intuit that exporter customizers have a chance to intervene when the user intends to set the exporter to none.