orca: fix race at producer startup #6245
Merged
+59
−41
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
With #6236, an existing race was discovered (exposed in some new situations):
orca.RegisterOOBListener
is called for a SubChannel.run
goroutine is started.run()
could start the OOB stream with the server at any moment now, despite no registered listeners.orca.RegisterOOBListener
, the listener is registered.Between 3 and 4, we could start the stream with a request interval of 0. The server's lower bound would apply to protect it from aggressive clients, but this causes at least some tests to fail. (Note that a similar race can theoretically happen between unregistering the final listener in a producer & registering a new one, but that would require the two operations to happen at the same time, which is unusual.)
The solution is to add a channel that is created whenever there are no listeners and closed (and nilled) if it exists when a listener is registered.
RELEASE NOTES: