Hello! 欢迎来到小浪资源网!


Spring Data Redis Pipeline查询返回空值的原因是什么?


Spring Data Redis Pipeline查询返回空值的原因是什么?

pipeline查询返回空值的原因

spring data redis中使用redistemplate执行pipeline批量查询时,若返回的结果都是空值,可能是由于管道操作的结果处理不当。

第一个示例
原本在doinredis方法中直接处理管道操作的结果是有问题的。正确做法应该是处理由executepipelined方法返回的结果列表,而不是操作内部的结果。

第二个示例
该示例与第一个类似,同样需要在pipeline操作完成后处理结果,而不是在操作内部处理。

正确处理流程
修复后的方法如下:

public <T> List<T> batchGetList(Collection<String> keys) {     if (CollectionUtil.isEmpty(keys)) {         return new ArrayList<>();     }      List<Object> results = redisTemplate.executePipelined((RedisConnection connection) -> {         RedisSerializer<String> keySerializer = (RedisSerializer<String>) redisTemplate.getKeySerializer();         for (String key : keys) {             connection.get(keySerializer.serialize(key));         }         return null;     });      // 在管道执行外部处理结果     return results.stream()                   .map(result -> (T) redisTemplate.getValueSerializer().deserialize((byte[]) result))                   .collect(Collectors.toList()); }

这种方法将所有get命令发送为一个批处理操作,并在操作完成后一次性处理所有结果。这里假设所有键对应的值都使用相同的反序列化器。若不同类型,则需要根据情况进一步处理结果。

相关阅读