Skip to content
This repository has been archived by the owner on Jul 21, 2021. It is now read-only.

break up set-watches on reconnect into multiple packets #167

Merged
merged 1 commit into from
Jul 26, 2017

Conversation

jhump
Copy link
Contributor

@jhump jhump commented Jul 26, 2017

This fixes an issue wherein a client that has a very large number of watches (and/or very long path names that are being watched) could cause a disconnect to be effectively permanent: the client gets stuck in a loop of trying to reconnect but being continually disconnected by the server.

This happens because the client may try to construct a request that is too large for the server to process. A ZK server, by default, limits incoming requests to 1mb. The hard-coded request buffer size in this client is 1.5mb.

It also fixes a related possible bug where the connection is successfully re-established, but watches are silently lost (because the set-watches request is so big it results in ErrShortBuffer when trying to encode the set-watches-request packet).

@jhump
Copy link
Contributor Author

jhump commented Jul 26, 2017

@samuel, this is a serious bug that we are encountering because we have apps that watch a reasonably large sub-tree in ZK and end up needing to re-establish a very large number of watches on reconnect. This changes this Go client to behave just as the Java client does to mitigate this possible problem.

@coveralls
Copy link

Coverage Status

Coverage increased (+0.3%) to 81.456% when pulling bc3c542 on jhump:jh/break-up-set-watches into 1d7be4e on samuel:master.

@jhump jhump force-pushed the jh/break-up-set-watches branch from bc3c542 to ea865e5 Compare July 26, 2017 16:30
@coveralls
Copy link

Coverage Status

Coverage increased (+0.3%) to 81.456% when pulling ea865e5 on jhump:jh/break-up-set-watches into 1d7be4e on samuel:master.

@samuel
Copy link
Owner

samuel commented Jul 26, 2017

Thanks again for the contribution. Seems there's a conflict after merging the other PR, but I'll merge this right away once that's resolved.

@jhump jhump force-pushed the jh/break-up-set-watches branch from ea865e5 to 991e2f5 Compare July 26, 2017 18:07
@coveralls
Copy link

Coverage Status

Coverage increased (+0.3%) to 81.887% when pulling 991e2f5 on jhump:jh/break-up-set-watches into 789e9fa on samuel:master.

@samuel samuel merged commit 6f3354f into samuel:master Jul 26, 2017
@jhump
Copy link
Contributor Author

jhump commented Jul 26, 2017

Thanks for the fast merge @samuel!

@jhump jhump deleted the jh/break-up-set-watches branch July 26, 2017 18:26
jeffbean pushed a commit to jeffbean/go-zookeeper that referenced this pull request Dec 28, 2018
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants