pipeline查询返回空值的原因

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

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

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

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

public  List batchGetList(Collection keys) {
    if (CollectionUtil.isEmpty(keys)) {
        return new ArrayList<>();
    }

    List<Object> results = redisTemplate.executePipelined((RedisConnection connection) -> {
        RedisSerializer keySerializer = (RedisSerializer) 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命令发送为一个批处理操作,并在操作完成后一次性处理所有结果。这里假设所有键对应的值都使用相同的反序列化器。若不同类型,则需要根据情况进一步处理结果。

以上就是Spring Data Redis Pipeline查询返回空值的原因是什么?的详细内容,更多请关注慧达安全导航其它相关文章!

点赞(0)

评论列表 共有 0 条评论

暂无评论
立即
投稿
发表
评论
返回
顶部