Redis笔记(四)Jedis管道Pipe操作

一、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();
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1 Redis介绍1.1 什么是NoSql为了解决高并发、高可扩展、高可用、大数据存储问题而产生的数据库解决方...
    克鲁德李阅读 10,794评论 0 36
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,477评论 19 139
  • 1.1 资料 ,最好的入门小册子,可以先于一切文档之前看,免费。 作者Antirez的博客,Antirez维护的R...
    JefferyLcm阅读 17,197评论 1 51
  • 生活很多事都逼迫着我们前进,我最近有想考公务员的想法,我也不知这种想法是内心的真实想法还是因为其他什么,但是我能有...
    白色的小草阅读 1,469评论 1 0
  • 粉丝如何变现行动计划书 2016-12-03 慢酌客 慢酌客社群服务平台 慢酌客说:能花钱解决的,就不要花时间解决...
    慢酌客合伙人茶社阅读 7,241评论 0 0