-
Notifications
You must be signed in to change notification settings - Fork 992
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
Send the CLIENT SETINFO command in a fire-and-forget way #2823
Conversation
@@ -281,6 +270,25 @@ private CompletableFuture<Void> applyPostHandshake(Channel channel, String redis | |||
return dispatch(channel, postHandshake); | |||
} | |||
|
|||
private CompletableFuture<Void> applyFireAndForget(Channel channel) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
to be fair, the method name doesn't reflect what is happening here as lenient error handling happens in the calling code.
Looking at the code, it might make sense to introduce stronger guards to avoid ArrayList
creation if neither library name nor library version are set and so avoid also the call to dispatch
.
Just a couple of thoughts.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fair assessment :) Was a bit hasty with the change, will update with your suggestions. Thanks!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That being said, @mp911de , would you say that we can also move the client name part to the more-lenient second post handshake too?
if (metadata.getClientName() != null && negotiatedProtocolVersion == ProtocolVersion.RESP2) {
postHandshake.add(new AsyncCommand<>(this.commandBuilder.clientSetname(connectionState.getClientName())));
}
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
TBH, I'm not sure about fire+forget.
There are quite some commands being invoked on startup and any failures can go unnoticed. Someone relying on the client name who has renamed the command doesn't find out about a failure until they investigate the client name on their own.
If someone encounters failures because of these commands, then they should not set the client name, library version, ….
What is the rationale to ignore errors?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could you give me an example where this metadata is critical to the operation of the client?
So far I assumed this is mostly tracing information. Are there flows where one client expects to find another one based on the name the other client provided? How would they handle this in older versions in Redis? I would be very hesitant to endorse the usage of these fields in this way
Even so I think the same rationale does not exist for lib-name and lib-version - these are definitely tracing information that is secondary to the operation of the driver.
Here is an excerpt from the documentation for the CLIENT SETINFO:
Client libraries are expected to pipeline this command after authentication on all connections and ignore failures since they could be connected to an older version that doesn't support them.
As I mentioned different flavors of the Redis server handle this in different versions and to embed a support matrix in the client would be counterproductive when the operation can simply fail. #2817 is a testament to this issue.
Would you consider it an improvement if we log the issue?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@mp911de I am just adding my 2 cents here. Command renaming is seldom used nowadays because Redis provides more efficient ways to secure the connection, etc.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Probably logging at the debug level is a good common ground. That being said, CLIENT SETNAME
belongs into the same category.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fair, let me prepare another change. Thanks for considering this!
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@mp911de what about this version?
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## main #2823 +/- ##
============================================
- Coverage 78.71% 77.73% -0.98%
- Complexity 6786 7241 +455
============================================
Files 508 539 +31
Lines 22765 24491 +1726
Branches 2446 2607 +161
============================================
+ Hits 17919 19039 +1120
- Misses 3717 4255 +538
- Partials 1129 1197 +68 ☔ View full report in Codecov by Sentry. |
Closes #2817
This solution aims to bring consistency between the Lettuce driver and most other drivers maintained by the Redis team.
The current approach is - instead of probing for the version of the remote server and deciding based on that wether or not to send the CLIENT SETINFO command - to always send it and ignore the server response. There are two main reasons behind this: different flavors of the Redis server handle this in different versions and also the information sent is not critical to the operation of the driver, so failures should not necessary terminate the connection.
lib-name
andlib-ver
are set properly.Make sure that: