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

Clarification on OTEL_SDK_DISABLED scope #4332

Open
kaylareopelle opened this issue Dec 10, 2024 · 10 comments
Open

Clarification on OTEL_SDK_DISABLED scope #4332

kaylareopelle opened this issue Dec 10, 2024 · 10 comments
Labels
spec:miscellaneous For issues that don't match any other spec label triage:deciding:community-feedback Open to community discussion. If the community can provide sufficient reasoning, it may be accepted triage:followup Needs follow up during triage

Comments

@kaylareopelle
Copy link

What are you trying to achieve?

Ruby received a PR to implement the OTEL_SDK_DISABLED environment variable, but we're not sure how far the functionality needs to go. The PR as it stands would skip creating providers through configuration, but someone could still manually create functional providers and tracers/meters/loggers. Is that acceptable?

Additional context.

Here's the description:

Boolean value. If “true”, a no-op SDK implementation will be used for all telemetry signals. Any other value or absence of the variable will have no effect and the SDK will remain enabled. This setting has no effect on propagators configured through the OTEL_PROPAGATORS variable.

I took a look at open-telemetry/opentelemetry-python#3648, and it seems like they always return no-ops when OTEL_SDK_DISABLED is true.

However, Java's implementation seems closer to the Ruby PR. Configuration is skipped, but I don't know enough about Java to know if that means you cannot create working tracers, etc.

@MrAlias
Copy link
Contributor

MrAlias commented Dec 10, 2024

cc @open-telemetry/python-approvers @open-telemetry/java-approvers

@trask
Copy link
Member

trask commented Dec 10, 2024

However, Java's implementation seems closer to the Ruby PR. Configuration is skipped, but I don't know enough about Java to know if that means you cannot create working tracers, etc.

If you are using the Java autoconfigure module and set OTEL_SDK_DISABLED=true then none of the autoconfigure callbacks to customize the OpenTelemetry SDK are called, and so there's no way to add your own tracers etc.

@trask trask added the triage:deciding:community-feedback Open to community discussion. If the community can provide sufficient reasoning, it may be accepted label Dec 10, 2024
@kaylareopelle
Copy link
Author

If you are using the Java autoconfigure module and set OTEL_SDK_DISABLED=true then none of the autoconfigure callbacks to customize the OpenTelemetry SDK are called, and so there's no way to add your own tracers etc.

Thanks for clarifying, @trask. Is there a way for to use the Java SDK without the autoconfigure module? If so, does OTEL_SDK_DISABLED have any impact on that path?

@trask
Copy link
Member

trask commented Dec 11, 2024

ya, you can use the Java SDK without the autoconfigure module, in which case OTEL_SDK_DISABLED has no effect

@kaylareopelle
Copy link
Author

Thanks, @trask!

@open-telemetry/python-approvers - Am I reading your code correctly, will OTEL_SDK_DISABLED create no-ops for all attempts at creating tracer providers, etc.?

@github-actions github-actions bot added the triage:followup Needs follow up during triage label Dec 25, 2024
@danielgblanco
Copy link
Contributor

@trask thinking about your response, and reading the spec, should OTEL_SDK_DISABLED also have effect with custom SDK config (i.e. without autoconfigure)?

The way I read it

a no-op SDK implementation will be used for all telemetry signals

I understand that if I pass OTEL_SDK_DISABLED then a no-op SDK would override any other config?

@danielgblanco danielgblanco removed the triage:followup Needs follow up during triage label Jan 6, 2025
@trask
Copy link
Member

trask commented Jan 6, 2025

@trask thinking about your response, and reading the spec, should OTEL_SDK_DISABLED also have effect with custom SDK config (i.e. without autoconfigure)?

I think this falls under (emphasis added) https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/configuration/sdk-environment-variables.md#implementation-guidelines:

Environment variables MAY be handled (implemented) directly by a component, in the SDK, or in a separate component (e.g. environment-based autoconfiguration component).

@github-actions github-actions bot added the triage:followup Needs follow up during triage label Jan 7, 2025
@xrmx
Copy link

xrmx commented Jan 7, 2025

Thanks, @trask!

@open-telemetry/python-approvers - Am I reading your code correctly, will OTEL_SDK_DISABLED create no-ops for all attempts at creating tracer providers, etc.?

It return no-ops when calling get_logger, get_tracer and get_meter of the sdk signals providers, so it's not a no-op tracer provider but a no-op tracer.

@trask trask removed the triage:followup Needs follow up during triage label Jan 7, 2025
@kaylareopelle
Copy link
Author

I think this falls under (emphasis added) https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/configuration/sdk-environment-variables.md#implementation-guidelines:

Environment variables MAY be handled (implemented) directly by a component, in the SDK, or in a separate component (e.g. environment-based autoconfiguration component).

@trask - I'm not sure I understand how this answers @danielgblanco's question. Does this mean an implementation can choose to apply an environment variable configuration only in an autoconfiguration component and have no impact on lower-level ways to access the SDK?

@github-actions github-actions bot added the triage:followup Needs follow up during triage label Jan 11, 2025
@trask
Copy link
Member

trask commented Jan 12, 2025

Does this mean an implementation can choose to apply an environment variable configuration only in an autoconfiguration component and have no impact on lower-level ways to access the SDK?

yeah, this is how Java SDK works. the SDK itself has no knowledge of env vars. you have to use a separate autoconfigure module in order to create an instance of the SDK based on env vars

there are definitely pros and cons of this approach, I'd probably look at a couple of other language implementations and consider what would be best specifically for Ruby

also keep in mind that future otel configuration will be built on top of declarative config in case that has any affect on your thinking

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
spec:miscellaneous For issues that don't match any other spec label triage:deciding:community-feedback Open to community discussion. If the community can provide sufficient reasoning, it may be accepted triage:followup Needs follow up during triage
Projects
None yet
Development

No branches or pull requests

5 participants