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

feat: Add compatibility with env OTEL_SDK_DISABLED #1773

Open
wants to merge 9 commits into
base: main
Choose a base branch
from

Conversation

pedrofurtado
Copy link

@pedrofurtado pedrofurtado commented Dec 4, 2024

feat: Add compatibility with env OTEL_SDK_DISABLED

Currently, the ruby gem does not have compatibility with env OTEL_SDK_DISABLED defined in Open Telemetry specification.

Specification: https://opentelemetry.io/docs/specs/otel/configuration/sdk-environment-variables/#general-sdk-configuration

This PR adds this integration.

Copy link

linux-foundation-easycla bot commented Dec 4, 2024

CLA Signed

The committers listed above are authorized under a signed CLA.

Copy link
Contributor

@kaylareopelle kaylareopelle left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for this PR, @pedrofurtado!

There is a test helper, OpenTelemetry::TestHelpers.with_env that can be used to help test behavior with environment variables.

For example:

OpenTelemetry::TestHelpers.with_env('a' => 'b') do
_(common_utils.config_opt('a', default: 'bar')).must_equal('b')
end

I started writing this comment before you removed the test. Could you add a test that leverages this helper?

sdk/lib/opentelemetry/sdk.rb Outdated Show resolved Hide resolved
pedrofurtado and others added 3 commits December 5, 2024 07:37
Co-authored-by: Kayla Reopelle <87386821+kaylareopelle@users.noreply.github.com>
@pedrofurtado
Copy link
Author

@arielvalentin @kaylareopelle I've created a test for this.
But the CI is not running, is pending approval. Can you approve the workflow to run? 👍

@pedrofurtado
Copy link
Author

@arielvalentin @kaylareopelle The CI finished, but a rubocop offense was notified. I fixed that, but I need approval again for CI please 😄

@arielvalentin
Copy link
Contributor

@arielvalentin @kaylareopelle The CI finished, but a rubocop offense was notified. I fixed that, but I need approval again for CI please 😄

Thanks for your patience. You'll require approvals to run CI until your first PR is merged.

@pedrofurtado
Copy link
Author

Good news, CI is green ✅

@@ -61,6 +61,11 @@ module SDK
# c.use_all
# end
def configure
if ENV['OTEL_SDK_DISABLED'] == 'true'
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@robertlaurin is this the best place for us to check this?

Does it make sense to check that in the instance method instead? https://github.com/open-telemetry/opentelemetry-ruby/blob/main/sdk/lib/opentelemetry/sdk/configurator.rb#L144

Do we want to support being able to change the envar and re-initialize in a running program?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Here in our applications works like a charm in this place (using monkey patch).

The PR content was based on this comment: #1605 (comment)

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, that was my comment 😄

I reached out to @robertlaurin here since he designed this component and wanted to solicit his input about where this check should happen.

If a user is not using the DSL, they can still create an instance of the Configurator and call the configure method bypassing the envar.

They could also not use the configurator at all and assemble the tracer provider and resources themselves.

I just want to make sure we are hooking this into the appropriate scope, so folks are not surprised that it does not work as anticipated in specific scenarios; or if we are OK with this minimal implementation.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I had similar questions @kaylareopelle to the ones you brought up

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

thank you! missed this! (link to comment)

@kaylareopelle
Copy link
Contributor

The spec for this environment variable feels a little vague to me. Do we know the scope of the OTEL_SDK_DISABLED env var?

The current implementation would skip creating tracer providers through configuration, but someone could still manually create functional tracer providers and tracers. Is that acceptable?

I took a look at Python's implementation, and it seems like they always return no-ops when OTEL_SDK_DISABLED is detected.

However, Java's implementation seems closer to this approach. Configuration is skipped, but I'm not sure if that means you cannot create working tracers, etc.

@pedrofurtado
Copy link
Author

Hi @arielvalentin @kaylareopelle! 👋
Is the PR ok?

@arielvalentin
Copy link
Contributor

I don't know. We don't quite understand how this environment variable is supposed to work per the specification. Right now this PR only works in a specific use case.

If our users initialize the SDK in a different way, I.e. manual configuration, then the envar will not work as expected and we may get a bug report.

That is why we are asking the question about whether or not this check is happening the the correct place.

@kaylareopelle
Copy link
Contributor

I opened an issue in the semantic conventions repo to see if we can get some help clarifying the functionality: open-telemetry/semantic-conventions#1667

Once we understand the spec better, we can move forward. Thanks for your patience, @pedrofurtado!
cc @arielvalentin

@arielvalentin
Copy link
Contributor

@kaylareopelle I think that should be in the spec repo thought right? Not semconv?

@kaylareopelle
Copy link
Contributor

@arielvalentin - Thank you, you're right! 🤦 I'll get that fixed.

@kaylareopelle
Copy link
Contributor

New issue in the right repo! open-telemetry/opentelemetry-specification#4332

Thanks, @arielvalentin!

Copy link
Contributor

github-actions bot commented Jan 9, 2025

👋 This pull request has been marked as stale because it has been open with no activity. You can: comment on the issue or remove the stale label to hold stale off for a while, add the keep label to hold stale off permanently, or do nothing. If you do nothing this pull request will be closed eventually by the stale bot

Copy link
Contributor

@kaylareopelle kaylareopelle left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hi @pedrofurtado! Thanks for your patience. We talked about this during the SIG on Tuesday.

The conversation at open-telemetry/opentelemetry-specification#4332 seemed to conclude that environment variables can have different scopes based on the implementation. Having OTEL_SDK_DISABLED scoped to just the configure method falls within the guidelines. Having it create no-ops outside of auto-configuration also falls within the guidelines.

I think this is a great first step toward getting this functionality into the SDK, and it seems to be fully spec-compliant.

If, in the future, we prefer to have no-ops for all tracers/meters/loggers; we can implement that in a separate PR.

@kaylareopelle
Copy link
Contributor

I think this is a great first step toward getting this functionality into the SDK, and it seems to be fully spec-compliant.

If, in the future, we prefer to have no-ops for all tracers/meters/loggers; we can implement that in a separate PR.

@arielvalentin, are you comfortable with this approach?

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

Successfully merging this pull request may close these issues.

3 participants