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