Drain pending requests to the coordinator before initiating group rejoin (#798)

This commit is contained in:
Dana Powers
2016-08-04 20:09:13 -07:00
committed by GitHub
parent d3d3ad8b74
commit f6d216856f

View File

@@ -242,6 +242,14 @@ class BaseCoordinator(object):
while self.need_rejoin():
self.ensure_coordinator_known()
# ensure that there are no pending requests to the coordinator.
# This is important in particular to avoid resending a pending
# JoinGroup request.
if self._client.in_flight_request_count(self.coordinator_id):
while self._client.in_flight_request_count(self.coordinator_id):
self._client.poll()
continue
future = self._send_join_group_request()
self._client.poll(future=future)