Redis 管道操作
因为在操作Redis的时候,执行一个命令需要先发送请求到Redis服务器,这个过程需要经历网络的延迟,Redis还需要给客户端一个相应
如果我需要一次性执行很多个命令,上述的方式效率很低,可以通过Redis的管道,先将命令放到客户短的一个Pipeline中,之后一次性的将全部命令都发送到Redis服务,Redis服务一次性的将全部的返回结果相应给客户端。
对比:前:未使用管道(376211毫秒),后:管道操作(339毫秒)
@Test
void notPipeline() {
// 未使用Redis 管道
// 1.创建连接池
JedisPool jedisPool = new JedisPool(new GenericObjectPoolConfig(), "101.21.114.44", 6379, 10000, "root");
long l = System.currentTimeMillis(); // 当前时间
// 2.获取jedis对象
Jedis jedis = jedisPool.getResource();
// 3.执行incr 10000次
for (int i = 0; i < 10000; i++) {
jedis.incr("pp");
}
// 4.释放资源
jedis.close();
// 使用时间(毫秒):376211
System.out.println(System.currentTimeMillis() - l);
}
@Test
void pipeline(){
// 1.创建连接池
JedisPool jedisPool = new JedisPool(new GenericObjectPoolConfig(), "101.21.114.44", 6379, 10000, "root");
long l = System.currentTimeMillis(); // 当前时间
// 2.获取jedis对象
Jedis jedis = jedisPool.getResource();
// 3.创建管道
Pipeline pipelined = jedis.pipelined();
// 4.执行incr 10000次
for (int i = 0; i < 10000; i++) {
// 放入管道
pipelined.incr("qq");
}
// 传输管道,进行执行
pipelined.syncAndReturnAll();
// 5.释放资源
jedis.close();
// 使用时间(毫秒):339
System.out.println(System.currentTimeMillis() - l);
}