RedisTemplate Pipeline批量查询结果为空:问题出在哪儿?

redistemplate使用pipeline批量查询结果为空的原因

在使用spring data redis的redistemplate进行批量查询时,如果结果为空,通常是因为对管道操作的结果处理不当。

首先,pipeline的目的是缓存命令并批量发送给服务器,而不是立即返回结果。因此,直接在管道操作内部处理结果是不合适的。

例1中,在管道操作内处理结果导致错误。正确的做法是在executepipelined之后处理结果:

public  List batchGetList(Collection keys) {
    ...
    List results = redisTemplate.executePipelined(redisConnection -> {
        ...
        // 缓存所有GET命令
        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());
}

例2中,使用sessioncallback正确处理结果,但在管道操作内获取值导致错误。

总结:

  • 在管道操作外部处理executepipelined返回的结果列表。
  • 批量获取所有键,然后一次性反序列化结果。
  • 确保所有键对应值可以使用相同的反序列化器反序列化。

关于我们

奈瑶·映南科技互联网学院是多元化综合资讯平台,提供网络资讯、运营推广经验、营销引流方法、网站技术、文学艺术范文及好站推荐等内容,覆盖多重需求,助力用户学习提升、便捷查阅,打造实用优质的内容服务平台。

搜索Search

搜索一下,你就知道。