-
Notifications
You must be signed in to change notification settings - Fork 897
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
Declare OTLP/JSON Stable #2930
Declare OTLP/JSON Stable #2930
Conversation
We need a lot of eyes on this before we merge this. |
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.
Would like to clarify the behavior for invalid (all 0) trace/span IDs. In other words we have 3 cases for trace/logs/metrics exemplar:
- "traceId" key is not present
- "traceId" key is present and has an empty value
- "traceId" key is present and value is all 0s
Can we consider these 3 cases the same? Is there a difference between them, if yes, what is the semantic?
I asked @bogdandrutu because I didn't understand immediately how #2930 (review) was supposed to block stabilizing OTLP/JSON. There are more cases than the three listed above. We expect that TraceIDs should be exactly 32 hex digits and SpanIDs should be exactly 16 hex digits. This follows from the conditions for a "valid" TraceID and SpanID here: https://github.com/open-telemetry/opentelemetry-specification/blob/main/specification/trace/api.md#spancontext We already have language about rejecting invalid data, which makes me think no more specification is needed. We should reject IDs with all zeros, whether it is because they are empty or missing, because valid identifiers require at least one non-zero byte. |
This is true for Spans but not for LogRecords, where traceid/spanid are optional fields. |
Bogdan's remark was clear about presence and absence, though #2930 (review). If the "traceId" is absent, then the field is absent, and if the "traceId" is present then the field is present. We only expect valid data when a field is present. |
This PR was marked stale due to lack of activity. It will be closed in 7 days. |
Does that mean absent is equivalent with present and invalid? |
If the field is required, then I would say yes. If the field is not required, then no. |
This PR was marked stale due to lack of activity. It will be closed in 7 days. |
Hey @tigrannajaryan Adding a small note after (briefly) discussing this: the question regarding As discussed: we should at least mention some of the mentioned cases (missing/empty |
I can not read the spec. I need to read examples, but there are no examples as long as open-telemetry/opentelemetry-proto#462 is open. |
Another concern is that spec doesn't cover how to deal with incomplete and missing spans, which should occur quite often in case of errors and exceptions. Basically in cases where the proper trace would be most useful. |
Here is a PR to clarify this: open-telemetry/opentelemetry-proto#442 |
This PR was marked stale due to lack of activity. It will be closed in 7 days. |
Not stale. Blocked by open-telemetry/opentelemetry-proto#442 |
@tigrannajaryan the last blocking issue has been resolved - I think it's time to merge it (and release it as part of the February release). |
This is ready to be merged after 1.18 release. |
IWithout making end of span optional you will have to break the stable implementation, or people will resort to hacks for debugging spans in real-time. |
@abitrolly Probably a comment for a different PR/issue? Please follow up otherwise with a new issue ;) |
Merging as 1.18.0 was released. |
Is there any roadblock in front of marking the whole OTLP spec stable (right now it is mixed but its components are stable)? |
Since OTLP/JSON was declared stable, all the parts of the OTLP spec is stable so the whole spec should be declared as such See open-telemetrygh-2930 Signed-off-by: Jonatan Ivanov <[email protected]>
Since OTLP/JSON was declared stable, all the parts of the OTLP spec is stable so the whole spec should be declared as such See open-telemetrygh-2930 Signed-off-by: Jonatan Ivanov <[email protected]>
Since OTLP/JSON was declared stable, all the parts of the OTLP spec is stable so the whole spec should be declared as such See open-telemetrygh-2930 Signed-off-by: Jonatan Ivanov <[email protected]>
Since OTLP/JSON was declared stable, all the parts of the OTLP spec is stable so the whole spec should be declared as such See open-telemetrygh-2930 Signed-off-by: Jonatan Ivanov <[email protected]>
See also open-telemetry/opentelemetry-proto#436 Co-authored-by: Carlos Alberto Cortez <[email protected]>
See also open-telemetry/opentelemetry-proto#436