-
Notifications
You must be signed in to change notification settings - Fork 268
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
Rename InstrumentationLibrary to InstrumentationScope #362
Rename InstrumentationLibrary to InstrumentationScope #362
Conversation
This applies changes described in spec PR open-telemetry/opentelemetry-specification#2276 This is not a breaking change for OTLP. The wire format does not change. It is a breaking change of the names of the generated code, which is acceptable since we are still on 0.x version of this repository.
Naming changes are hard. They should be considered as breaking changes for any developers (as an end-user). We should be treating what we call "stable" as "stable". Going forward, can we treat the names of fields and types are unbreakable (i.e. stable). We need to stabilize message, fields, enum names. Imo, having a name change as in this PR should not be happening at this stage of the project. Re: https://github.com/open-telemetry/opentelemetry-proto/blob/main/README.md Let's discuss in the spec SIG tomorrow. |
I agree. We do not call names "stable" though. They are clearly and explicitly specified to be unstable.
I agree and I think we are very close to achieving this. Logs proto are about to be declared stable, races and metrics already are. With all 3 signals stable we should be more confident to say that we are done making breaking changes, including the names, etc. |
Adding comment from the Spec SIG. And I agree with @alolita comment
|
We discussed this in the spec SIG and we believe that stability guarantees need to be extended to cover the JSON format and the Protobuf message and field names. This will require an examination of the current names and JSON format to make sure everything is named as we want it to be and then we can extend the guarantees. This can be done after the batch of changes proposed by this PR is done (and this PR may be re-worked to make the transition more graceful). |
Versioning like that is extremely undesirable because it means breaking interoperability between versions. We will not do that. We promised wire compatibility for binary Protobuf format and in the past we publicly recognized that breaking interoperability between network nodes is one of the most painful form of causing user trouble, we should avoid that, even at the high cost of pains to us, developers. Versioning like that may be the last resort, which is not the case right now, we have more graceful options.
I agree it is not undesirable, so going forward we need to rethink our guarantees. |
All, I made changes to the PR to make the transition more graceful. Please read the comments here and let me know what you think. |
The compromise seems acceptable to me. So JSON senders should send only the new name by default but offer an old collector compatibility option which sends both? |
Yes, that's what I was aiming for, but open for alternate suggestions. In the Collector we will also implement gracefully accepting either the old or the new name, so it should work fine with old or new senders. Essentially we are ensuring interoperability from both sides. If at least one of the sides correctly implements the new recommendations it should be able to work with an old peer. |
@MadVikingGod @Aneurysm9 what do you think? |
I think this is a good way to transition. Do we also need to do the same for |
For reference, I suspect we probably wouldn't update the Java JSON exporter to send both old and new as JSON export from Java should be unpopular enough that gating users on updating their collector is fine IMO. If we were to send both in JSON, we would send both in binary too though as deciding the behavior for one or the other would complicate our export code quite a bit. |
Yes, I will add that if we are happy with this approach. |
I think this is OK. The proposed approach exceeds the formal guarantees that we have to follow and is not an absolute requirement (I deliberately used "SHOULD" clauses instead of "MUST"). If the particular SIG feels JSON is not an important case for them then they just need to follow the formal requirements of the "Alpha" stability, which says "you can break it anytime". For the record: Collector doesn't even have an implementation of OTLP/JSON exporter, so nothing to do there. The Collector has an OTLP/JSON receiver, which we should be able to modify to accept both old and new formats gracefully. |
c05cd7d
to
b49b880
Compare
Done now for metrics and logs too. |
@open-telemetry/specs-approvers please review. |
9562084
to
6a30b68
Compare
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.
For me this looks good.
@open-telemetry/specs-trace-approvers please review. |
@open-telemetry/specs-logs-approvers please review. |
We have enough approvals. @dyladan @MadVikingGod @Aneurysm9 I will merge unless you object. |
I have not had a chance to actually confirm that this won't be a breaking change. That said I do think that this should work. I don't want to hold this up any further. |
This applies changes described in spec PR open-telemetry/opentelemetry-specification#2276
This is not a breaking change for OTLP. The wire format does not change.
The change is done in a way that the transition can be handled gracefully for OTLP/JSON and for the generated code. See the comments for explanation on how to do it in the senders and receivers.