-
Notifications
You must be signed in to change notification settings - Fork 1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Implement #watch and #multi specially for cluster-client
This PR makes watch & multi work more or less the same way for clustering as they do for normal redis. Since it's supposed to be valid to perform your multi call on the original redis object, like this: ``` redis.watch('key') do redis.multi do |tx| # tx is performed on the same connection as the watch end end ``` we need to keeps some state in an ivar @active_watcher so we know to call MULTI on the same actual connection as WATCH (and appropriately fail if the keys got redirected or the node went down). This is technically threadsafe, because the watch/multi implementation is wrapped in the `synchronize` monitor; however, for good performance in multithreaded environments, you will most likely want to use a connection pool of Redis::Cluster instances.
- Loading branch information
KJ Tsanaktsidis
committed
Feb 21, 2024
1 parent
7cc45e5
commit 5bdb9e8
Showing
4 changed files
with
131 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters