Redis - pipelining(管道)

來源:互聯網
上載者:User

標籤:

用戶端向伺服器發送一個查詢請求,並監聽 socket 返回,等待伺服器響應。通常是阻塞模式,在收到伺服器響應之前是掛起的,不能繼續發送請求。

可以使用管道來改善這種情況。在使用管道的情況下,用戶端可以請求伺服器而不必理會伺服器是否有回複。這樣就可以一次發出多個命令。

下面是 Jedis 一般情況下和開啟管道後發送一系列請求所用時間的對比。

 

public class PipelineTest {    public static void main(String[] args) {        Jedis jedis = new Jedis("127.0.0.1", 6379);        withoutPipeline(jedis);        withPipeline(jedis);            }        private static void withoutPipeline(Jedis jedis){        long start = System.currentTimeMillis();        jedis.set("name", "gpf");        for (int i = 0; i < 1000; i++) {            jedis.append("name", "x");        }        long end = System.currentTimeMillis();        jedis.disconnect();        System.out.println("time withoutPipeline:"+(end-start));        System.out.println(jedis.get("name"));    }        private static void withPipeline(Jedis jedis){        long start = System.currentTimeMillis();        jedis.set("name", "gpf");        Pipeline pl = jedis.pipelined();        for (int i = 0; i < 1000; i++) {            pl.append("name", "y");        }        pl.sync();        long end = System.currentTimeMillis();        System.out.println("time withPipeline:"+(end-start));        System.out.println(jedis.get("name"));    }}

 

多次測試結果均如下面結果所示:

time withoutPipeline:158gpfxxxxxxxxxxxxxxxxxxxxx...time withPipeline:22gpfyyyyyyyyyyyyyyyyyyyyy...

可以看出,開啟管道後,效率提升顯著。

 

Redis - pipelining(管道)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.