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

Store resource in tracer SDK #352

Closed

Conversation

pavolloffay
Copy link
Member

Updates #281

Signed-off-by: Pavol Loffay [email protected]

Signed-off-by: Pavol Loffay <[email protected]>
@codecov-io
Copy link

Codecov Report

Merging #352 into master will decrease coverage by 0.05%.
The diff coverage is 0%.

Impacted file tree graph

@@             Coverage Diff              @@
##             master     #352      +/-   ##
============================================
- Coverage     63.38%   63.33%   -0.06%     
  Complexity      320      320              
============================================
  Files            56       56              
  Lines          1251     1252       +1     
  Branches        112      112              
============================================
  Hits            793      793              
- Misses          419      420       +1     
  Partials         39       39
Impacted Files Coverage Δ Complexity Δ
...ain/java/io/opentelemetry/sdk/trace/TracerSdk.java 45% <0%> (-2.37%) 3 <0> (ø)

Continue to review full report at Codecov.

Legend - Click here to learn more
Δ = absolute <relative> (impact), ø = not affected, ? = missing data
Powered by Codecov. Last update ade08cd...d7ba692. Read the comment docs.

public void setResource(Resource resource) {}
public void setResource(Resource resource) {
this.resource = resource;
}

@Override
public Resource getResource() {
Copy link
Member

Choose a reason for hiding this comment

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

is there a comment on API to not cache this value? We need to clearly state that the object returned by this API can be replaced in runtime at any moment

Copy link
Member

Choose a reason for hiding this comment

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

Some questions:

  1. I am not sure why do we need a get on this?
  2. Also not sure we need a set, I think we can just offer the ability to set the initial resource during initialization time of the TracerSdk.

Copy link
Member Author

Choose a reason for hiding this comment

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

I did this PR to move forward with the impl. Setter and getter on the resource seem not required in my opinion. I thought that this has been discussed as it is in the API.

I think that setting a resource belongs to initialization. Getter seems also redundant.

Copy link
Member

Choose a reason for hiding this comment

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

@pavolloffay I am sorry that I kind of moved the discussion a bit here and that it happen in your PR. You did a good job on this PR, but want to make sure we do the best of the project.

I think we are on the same opinion about what is needed here.

Copy link
Member Author

Choose a reason for hiding this comment

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

So do we remove these methods completely fro the tracer API?

Copy link
Member

Choose a reason for hiding this comment

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

That's what I am proposing, waiting for @SergeyKanzhelev and @carlosalberto to see what do they think?

Copy link
Contributor

Choose a reason for hiding this comment

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

Oh, I remember we talking about this some time ago ;) Yeah, it makes sense to have this as part of the Tracer initialization only - leaving the get() part would be fine, but probably we don't really need to expose it in the main API.

Copy link
Member

Choose a reason for hiding this comment

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

One reason to expose it is to allow to inject this resource information in outgoing requests and response headers. There are systems that exchange this information.

Copy link
Member

Choose a reason for hiding this comment

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

Adding an API is backwards compatible, until we have a clear case can we remove the API for the moment and add it later if needed.

Copy link
Contributor

Choose a reason for hiding this comment

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

Yeah, I'd propose go with the 'safe' route now and remove it for the moment, and add it if/when actually needed.

@bogdandrutu
Copy link
Member

@SergeyKanzhelev are you approving to remove these or the current PR?

@SergeyKanzhelev
Copy link
Member

oh, I didn't realize get for resource already was there. I glanced over and though that getter was removed so we only have set.

@bogdandrutu
Copy link
Member

So, we agreed to remove the getter from Tracer. What about set, do we need an explicit set or we want only the SDK to allow that (not the API)?

I see no reason for an instrumentation plugin to set the resources globally, at most we need what we discussed in the components issue, to add more data about the instrumented component and merge these into the default tracer Resource.

@carlosalberto
Copy link
Contributor

So, we agreed to remove the getter from Tracer. What about set, do we need an explicit set or we want only the SDK to allow that (not the API)?

So I feel like we should set this only a ctor time (at least for the time being).

@SergeyKanzhelev
Copy link
Member

So I feel like we should set this only a ctor time (at least for the time being).

If Resoruce information is obtained from metadata REST call in AWS and Azure, would you require for the process to hold on on doing anything before that call will complete? Setter would allow to update Resource information later in the process.

@bogdandrutu
Copy link
Member

@SergeyKanzhelev I think this is very specific to every implementation. I agree with you that a proper implementation should not necessary hold the start of the process for this. I think SDK can have a way to set this later.

@bogdandrutu
Copy link
Member

@SergeyKanzhelev also that is one of the reason we want to default read the Resource from env variables to ensure we don't block the process to much.

@SergeyKanzhelev
Copy link
Member

so resource auto-discovery modules would depend on SDK? I'm fine with it, just want to make sure it's understood.

Will there be any mention of Resource on API than? Only for SpanData?

@bogdandrutu
Copy link
Member

I think we want people to add more labels, as discussed in open-telemetry/opentelemetry-specification#10. These "resources" will be merged with the auto-detected by the SDK.

@SergeyKanzhelev
Copy link
Member

@bogdandrutu than it probably should be merge, not set. Should we have neither get nor set for now and discuss what we want to do later as a feedback?

@pavolloffay
Copy link
Member Author

done in #387

@pavolloffay pavolloffay closed this Jun 7, 2019
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.

6 participants