-
Notifications
You must be signed in to change notification settings - Fork 896
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
Change Span specification to focus more on capabilities. #184
Conversation
|
||
API MUST also provide an overload that accepts a [`Link` interface](#link). This | ||
overload allows instrumentation to supply a lazily calculated `Link`. | ||
#### Set Status |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is the span status supposed to be any custom user-defined string, or will an enum or constants be defined?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I did not get to the Status API. I will clarify in the followup PR.
Co-Authored-By: Armin Ruech <armin.ruech@gmail.com>
Co-Authored-By: Armin Ruech <armin.ruech@gmail.com>
Co-Authored-By: Armin Ruech <armin.ruech@gmail.com>
Co-Authored-By: Armin Ruech <armin.ruech@gmail.com>
Co-Authored-By: Armin Ruech <armin.ruech@gmail.com>
Co-Authored-By: Armin Ruech <armin.ruech@gmail.com>
Co-Authored-By: Armin Ruech <armin.ruech@gmail.com>
Co-Authored-By: Armin Ruech <armin.ruech@gmail.com>
Co-Authored-By: Armin Ruech <armin.ruech@gmail.com>
Co-Authored-By: Armin Ruech <armin.ruech@gmail.com>
Co-Authored-By: Armin Ruech <armin.ruech@gmail.com>
specification/tracing-api.md
Outdated
|
||
Retrieve the `Span`s `SpanContext` | ||
A `Span` MUST have the ability to return the `SpanContext` associated with it. | ||
The returned value MUST be the same for the entire Span lifetime. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Isn't sampled flag a part of span context? In some implementations it could change during the lifetime of a span. What is the actual requirement here?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think the current PR does not change the behavior. I do understand your requirement but we should have a separate discussion about this. Filed #189 to track this separately.
specification/tracing-api.md
Outdated
- An API to record lazy initialized links. This can be implemented by providing | ||
a `Link` interface or a concrete `Link` definition and a `LinkFormatter`. If | ||
the language supports overloads then this SHOULD be called `AddLink` otherwise | ||
`AddLazyLink` may be consider. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
is there a ticket describing the use case for "lazy links"?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is mostly for the attributes, for example the values may be lazily formatted.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
This reads much better :). I was writing up a whole thing about how in Erlang, with immutable variables, SpanContext maps fine to how the API is defined but the Span's themselves don't. The actual spans are stored in a mutable table keyed on the spancontext. so calls like |
Co-Authored-By: Chris Kleinknecht <libc@google.com>
Co-Authored-By: Chris Kleinknecht <libc@google.com>
Waiting for other approves before I will merge. |
I will wait until tomorrow to merge this, if no comments :) |
…try#184) * Change Span specification to focus more on capabilities. * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Chris Kleinknecht <libc@google.com> * Update specification/tracing-api.md Co-Authored-By: Chris Kleinknecht <libc@google.com> * Fix comments from review. * Clarify that only one attribute,event,link is recorded.
…try#184) * Change Span specification to focus more on capabilities. * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Armin Ruech <armin.ruech@gmail.com> * Update specification/tracing-api.md Co-Authored-By: Chris Kleinknecht <libc@google.com> * Update specification/tracing-api.md Co-Authored-By: Chris Kleinknecht <libc@google.com> * Fix comments from review. * Clarify that only one attribute,event,link is recorded.
This PR changes a subset of the Span API to the agreed model in #165. The rest of the changes will be added in a different PR, trying to keep this PR small so feedback can be addressed faster.
Updates #165