一、Jedis的管道Pipe操作
Jedis的管道Pipe操作可以實現高效率的redis操作,通過以下對比,我們可以發現,管道操作的效率是普通操作的8倍
package com.redis.pipe;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.Pipeline;
/**
* \* Created with IntelliJ IDEA.
* \* Author: huyi
* \* Date: 2017/2/16 10:22
* \* Description:
* \
*/
public class JedisTest {
public static void main(String [] args){
int count = 1000;
long start = System.currentTimeMillis();
withOutPipe(count);
long end = System.currentTimeMillis();
System.out.println("withoutPipeline: " + (end-start));
start = System.currentTimeMillis();
withPipe(count);
end = System.currentTimeMillis();
System.out.println("usePipeline: " + (end-start));
}
public static void configSet(int count){
Jedis jedis = new Jedis("192.168.182.129",6379);
jedis.configSet("timeout", "1");
jedis.disconnect();
}
public static void withOutPipe(int count){
Jedis jedis = new Jedis("192.168.182.129",6379);
for(int i =0; i<count; i++){
jedis.incr("testKey1");
}
jedis.disconnect();
}
public static void withPipe(int count){
Jedis jedis = new Jedis("192.168.182.129",6379);
Pipeline pl = jedis.pipelined();
for(int i =0; i<count; i++){
pl.incr("testKey1");
}
pl.sync();
jedis.disconnect();
}
}
Jedis的管道Pipe操作對比
二、Jedis的超時設置
jedis可以設置服務器,和在服務器操作redis-cli命令一樣,拿超時命令舉例
package com.redis.pipe;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.Pipeline;
/**
* \* Created with IntelliJ IDEA.
* \* Author: huyi
* \* Date: 2017/2/16 10:22
* \* Description:
* \
*/
public class JedisTest {
public static void main(String [] args){
int count = 1000;
long start = System.currentTimeMillis();
withOutPipe(count);
long end = System.currentTimeMillis();
System.out.println("withoutPipeline: " + (end-start));
start = System.currentTimeMillis();
withPipe(count);
end = System.currentTimeMillis();
System.out.println("usePipeline: " + (end-start));
}
public static void configSet(int count){
Jedis jedis = new Jedis("192.168.182.129",6379);
jedis.configSet("timeout", "1");
jedis.disconnect();
}
public static void withOutPipe(int count){
Jedis jedis = new Jedis("192.168.182.129",6379);
for(int i =0; i<count; i++){
jedis.incr("testKey1");
}
jedis.disconnect();
}
public static void withPipe(int count){
Jedis jedis = new Jedis("192.168.182.129",6379);
Pipeline pl = jedis.pipelined();
for(int i =0; i<count; i++){
pl.incr("testKey1");
}
pl.sync();
jedis.disconnect();
}
}