Skip to content

fix: client.close() should wait until the channels are terminated before shutting down the executor#916

Merged
igorbernstein2 merged 2 commits intogoogleapis:masterfrom
igorbernstein2:fix-close
Jul 19, 2021
Merged

fix: client.close() should wait until the channels are terminated before shutting down the executor#916
igorbernstein2 merged 2 commits intogoogleapis:masterfrom
igorbernstein2:fix-close

Conversation

@igorbernstein2
Copy link
Contributor

Previously the client.close() would simply shutdown the channel pool and the executor immediately after. Unfortunately this leads to RPCs that would hang forever because an outstanding RPC didnt have an executor to notify of its completion. This PR ensures that the channels are drained before shutting down the executor

…ore shutting down the executor

Previously the client.close() would simply shutdown the channel pool and the executor immediately after. Unfortunately this leads to RPCs that would hang forever because an outstanding RPC didnt have an executor to notify of its completion. This PR ensures that the channels are drained before shutting down the executor
@igorbernstein2 igorbernstein2 requested a review from mutianf July 16, 2021 22:58
@igorbernstein2 igorbernstein2 requested a review from a team as a code owner July 16, 2021 22:58
@product-auto-label product-auto-label bot added the api: bigtable Issues related to the googleapis/java-bigtable API. label Jul 16, 2021
@google-cla google-cla bot added the cla: yes This human has signed the Contributor License Agreement. label Jul 16, 2021
@igorbernstein2 igorbernstein2 merged commit 914f0cc into googleapis:master Jul 19, 2021
@igorbernstein2 igorbernstein2 deleted the fix-close branch July 19, 2021 15:14
kolea2 pushed a commit to kolea2/java-bigtable that referenced this pull request Sep 9, 2021
…ore shutting down the executor (googleapis#916)

* fix: client.close() should wait until the channels are terminated before shutting down the executor

Previously the client.close() would simply shutdown the channel pool and the executor immediately after. Unfortunately this leads to RPCs that would hang forever because an outstanding RPC didnt have an executor to notify of its completion. This PR ensures that the channels are drained before shutting down the executor

* copyright

(cherry picked from commit 914f0cc)
kolea2 added a commit that referenced this pull request Sep 10, 2021
…ore shutting down the executor (#916) (#1000)

* fix: client.close() should wait until the channels are terminated before shutting down the executor

Previously the client.close() would simply shutdown the channel pool and the executor immediately after. Unfortunately this leads to RPCs that would hang forever because an outstanding RPC didnt have an executor to notify of its completion. This PR ensures that the channels are drained before shutting down the executor

* copyright

(cherry picked from commit 914f0cc)

Co-authored-by: Igor Bernstein <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

api: bigtable Issues related to the googleapis/java-bigtable API. cla: yes This human has signed the Contributor License Agreement.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants