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為了解決高并發、高可擴展、高可用、大數據存儲問題而產生的數據庫解決方...
    克魯德李閱讀 5,371評論 0 36
  • Spring Cloud為開發人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發現,斷路器,智...
    卡卡羅2017閱讀 134,992評論 19 139
  • 1.1 資料 ,最好的入門小冊子,可以先于一切文檔之前看,免費。 作者Antirez的博客,Antirez維護的R...
    JefferyLcm閱讀 17,120評論 1 51
  • 生活很多事都逼迫著我們前進,我最近有想考公務員的想法,我也不知這種想法是內心的真實想法還是因為其他什么,但是我能有...
    白色的小草閱讀 204評論 1 0
  • 粉絲如何變現行動計劃書 2016-12-03 慢酌客 慢酌客社群服務平臺 慢酌客說:能花錢解決的,就不要花時間解決...
    慢酌客合伙人茶社閱讀 2,533評論 0 0