-
Notifications
You must be signed in to change notification settings - Fork 1.2k
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
Add multiple reactive keys exist checker #2918
base: main
Are you sure you want to change the base?
Add multiple reactive keys exist checker #2918
Conversation
@@ -164,7 +184,7 @@ void renameShouldAlterKeyNameCorrectly() { | |||
connection.keyCommands().rename(KEY_1_BBUFFER, KEY_2_BBUFFER).as(StepVerifier::create).expectNext(true) | |||
.verifyComplete(); | |||
assertThat(nativeCommands.exists(KEY_2)).isEqualTo(1L); | |||
assertThat(nativeCommands.exists(KEY_1)).isEqualTo(0L); | |||
assertThat(nativeCommands.exists(KEY_1)).isZero(); |
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.
I just changed the command to make better readability according to sonarlint rules.
* @return {@link Mono} emitting {@literal true} if all keys exist. | ||
* @see <a href="https://redis.io/commands/exists">Redis Documentation: EXISTS</a> | ||
*/ | ||
default Mono<Boolean> exists(List<ByteBuffer> keys) { |
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.
I created a validation method which is for checking if parameterized all keys exist in redis cache. If one of them does not exist, it returns false.
@kutlueren , please check if this function is what you meant to use.
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.
Hey @AnneMayor
Awesome to see that you added the function which carries out what I suggested. It is actually more straight forward than I initially thought, maybe I got confused in the codebase but nice! I shall try it out as soon as it gets merged.
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.
This implementation calls EXISTS
for each key issuing a command for each element in the list.
Redis' EXISTS
command accepts multiple arguments and returns how many of the keys exist. Our interface should use the existing functionality instead of putting another layer on top of commands with a worse performance behavior.
The issue we have here is however that exists(Publisher<KeyCommand> keys)
and exists(Publisher<List<KeyCommand>> keys)
or exists(Publisher<MultiKeyCommand>> keys)
erase to the same type and we cannot simply introduce such an override.
I suggest to implement Mono<Long> exists(List<ByteBuffer> keys)
directly instead of using default
methods. Also, ReactiveRedisOperations
should be extended with countExistingKeys(…)
similar to RedisTemplate.countExistingKeys(…)
.
0d0df34
to
78c6c7f
Compare
78c6c7f
to
cf160e7
Compare
Hey @AnneMayor, I just wanted to follow up on the topic :) Is this being planned to be merged soon? |
Hey @kutlueren , |
@mp911de would you mind taking a look at this one when you have time? |
@mp911de , |
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.
I did a review pass and left a comment regarding the design and implementation. Care to have a look?
* @return {@link Mono} emitting {@literal true} if all keys exist. | ||
* @see <a href="https://redis.io/commands/exists">Redis Documentation: EXISTS</a> | ||
*/ | ||
default Mono<Boolean> exists(List<ByteBuffer> keys) { |
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.
This implementation calls EXISTS
for each key issuing a command for each element in the list.
Redis' EXISTS
command accepts multiple arguments and returns how many of the keys exist. Our interface should use the existing functionality instead of putting another layer on top of commands with a worse performance behavior.
The issue we have here is however that exists(Publisher<KeyCommand> keys)
and exists(Publisher<List<KeyCommand>> keys)
or exists(Publisher<MultiKeyCommand>> keys)
erase to the same type and we cannot simply introduce such an override.
I suggest to implement Mono<Long> exists(List<ByteBuffer> keys)
directly instead of using default
methods. Also, ReactiveRedisOperations
should be extended with countExistingKeys(…)
similar to RedisTemplate.countExistingKeys(…)
.
Thanks a lot. I am going to apply your review within this weekend 👍 |
Any luck solving this? I have the same issue. Wanting to check the existence of multiple keys using exists in a single network call, without resorting to Lua, but using Springs own implementation |
My current workaround, since the spring API does not support exists with multiple keys yet.
|
Resolved #2883