-
Notifications
You must be signed in to change notification settings - Fork 994
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
resubscribe
logic looks ignoring sharded Pub/Sub (shardChannels
Set of PubSubEndpoint
)
#2940
Comments
(Just related topic) Also Javadoc of
↑ By reading code, this one (routing based on first command key) is the truth and that is why |
Hey @saiya , thanks for the report, I think you are correct and sharded subscriptions are not resubscribed right now. |
Both, to the best of my own understanding:
Does that make sense? |
Thank you for the agile response! I will await for the fix. |
I see; yes indeed that make sense. Now I understand the |
Sharded PubSub subscriptions not recovered after disconnection and re-connection.
…sconnection and re-connection.
…sconnection and re-connection. Backport to 6.4.x branch
…ection and re-connection. (#3026) Backport to 6.4.x branch
…sconnection and re-connection. (redis#3024)
Bug Report
Thank you for adding support for sharded PubSub in the 6.4.0.
Related to that implementation, I would like to confirm about
resubscribe
(subscription recovery after reconnection) behavior.It looks like
resubscribe
handling only non-sharded PubSub subscriptions.Current Behavior
Sharded PubSub subscriptions looks not recovered after disconnection + re-connection, despite Lettuce automatically recovers non-sharded PubSub subscriptions (the recovery behavior is very helpful for applications, and also difficult / error-prone to implement by ourselves).
In the 1457486#diff-73f0c5ac0f7d6d94f8d47e1a75564aa344cbbbd4c91ce786711b5c3673044956,
PubSubEndpoint.shardChannels
(private
) have been added but it looks that variable is private insidePubSubEndpoint
and no any code ofPubSubEndpoint
reading that variable's data. Also implementations ofStatefulRedisPubSubConnectionImpl.resubscribe
andStatefulRedisClusterPubSubConnectionImpl.resubscribe
does not accessingshardChannels
.Input Code
Just make sharded Pub/Sub connection, and wait until some disconnection + re-connection occurs on that environment...
Input Code
Expected behavior/code
As same as non-sharded Pub/Sub, automatically recover sharded Pub/Sub subscriptions when possible to connect to that shard/node.
( May be a bit different logic from non-sharded Pub/Sub needed. Because the SSUBSCRIBE requires living connection to the particular shard's node(s) )
Environment
Possible Solution
(Not tested) Watch the connection's state somehow and manually call
ssubscribe
again by application's logic.Additional context
Because currently I don't have full access to a target environment / Redis cluster, this issue is based on best guess by reading code. I hope this code reading makes some sense...
The text was updated successfully, but these errors were encountered: