public class JedisPipeline {
private static JedisPool pool = new JedisPool(new JedisPoolConfig(), "127.0.0.1", 6379);
public static void main(String args[]){
Jedis jedis = pool.getResource();
Pipeline pipeline = jedis.pipelined();
pipeline.multi();
//pipeline.hmset("Id", new HashMap<String,String>() );
for(int i=0; i < 1000 ; i++){
pipeline.hincrBy("Id", i+"", i);
}
pipeline.exec();
pool.returnResource(jedis);
//pool.destroy();
//pool = new JedisPool(new JedisPoolConfig(), "127.0.0.1", 6379);
jedis = pool.getResource();
Map<String,String> map1 = jedis.hgetAll("Id");
System.out.println("map1------->"+map1);
pool.returnResource(jedis);
//pool.destroy();
}
}
我在上面的代码中有问题。它抛出一个 ClassCastException,就好像我破坏了池并创建了一个新的池对象,它可以正常工作。我是否正确使用了 Pipeline API?谁能帮我 ?我正在使用 Jedis 2.1.0
Exception in thread "main" java.lang.ClassCastException: [B cannot be cast to java.util.List
at redis.clients.jedis.Connection.getBinaryMultiBulkReply(Connection.java:189)
at redis.clients.jedis.Jedis.hgetAll(Jedis.java:861)
at com.work.jedisex.JedisFactory.main(JedisFactory.java:59)
修改代码以获取抛出异常的 Map
Response<Map<String,String>> map1 = pipeline.hgetAll("Id");
pipeline.exec();
pipeline.sync();
pool.returnResource(jedis);
Map<String,String> map2 = map1.get();