一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫 - Redis - Redis基礎(chǔ)學(xué)習(xí)之管道機制詳析

Redis基礎(chǔ)學(xué)習(xí)之管道機制詳析

2019-11-20 21:53pjmike_pj Redis

這篇文章主要給大家介紹了關(guān)于Redis基礎(chǔ)學(xué)習(xí)之管道機制的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用Redis具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

Redis服務(wù)是一種C/S模型,提供請求-響應(yīng)式協(xié)議的TCP服務(wù),所以當(dāng)客戶端請求發(fā)出,服務(wù)端處理并返回結(jié)果到客戶端,一般是以阻塞形式等待服務(wù)端的響應(yīng),但這在批量處理連接時延遲問題比較嚴(yán)重,所以Redis為了提升或彌補這個問題,引入了管道技術(shù):可以做到服務(wù)端未及時響應(yīng)的時候,客戶端也可以繼續(xù)發(fā)送命令請求,做到客戶端和服務(wù)端互不干涉影響,服務(wù)端并最終返回所有服務(wù)端的響應(yīng),這在促進原有C/S模型交互的響應(yīng)速度上有了質(zhì)的提高。

以下是對 Redis管道機制的一個學(xué)習(xí)記錄

Pipeline簡介

Redis客戶端執(zhí)行一條命令:

  • 發(fā)送命令
  • 命令排隊
  • 執(zhí)行命令
  • 返回結(jié)果

其中發(fā)送命令和返回結(jié)果可以稱為 Round Trip Time (RTT,往返時間)。在Redis中提供了批量操作命令,例如mget、mset等,有效地節(jié)約了RTT。但是大部分命令是不支持批量操作的。

為此Redis提供了一個稱為管道(Pipeline) 的機制將一組Redis命令進行組裝,通過一次 RTT 傳輸給 Redis,再將這些 Redis 命令的執(zhí)行結(jié)果按順序傳遞給客戶端。即使用pipeline執(zhí)行了n次命令,整個過程就只需要一次 RTT。

對Pipeline進行性能測試

我們使用redis-benchmark 對Pipeline進行性能測試,該工具提供了 -P 的選項,此選項表示使用管道機制處理 n 條Redis請求,默認值為1。測試如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
# 不使用管道執(zhí)行g(shù)et set 100000次請求
[root@iz2zeaf3cg1099kiidi06mz ~]# redis-benchmark -t get,set -q -n 100000
SET: 55710.31 requests per second
GET: 54914.88 requests per second
# 每次pipeline組織的命令個數(shù) 為 100
[root@iz2zeaf3cg1099kiidi06mz ~]# redis-benchmark -P 100 -t get,set -q -n 100000
SET: 1020408.19 requests per second
GET: 1176470.62 requests per second
# 每次pipeline組織的命令個數(shù) 為 10000
[root@iz2zeaf3cg1099kiidi06mz ~]# redis-benchmark -P 10000 -t get,set -q -n 100000
SET: 321543.41 requests per second
GET: 241545.89 requests per second

從上面測試可以看出,使用pipeline的情況下 Redis 每秒處理的請求數(shù)遠大于 不使用 pipeline的情況。

當(dāng)然每次pipeline組織的命令個數(shù)不能沒有節(jié)制,否則一次組裝Pipeline數(shù)據(jù)量過大,一方面會增加 客戶端等待時間,另一方面會造成一定的網(wǎng)絡(luò)阻塞。

從上面的測試中也可以看出,如果一次pipeline組織的命令個數(shù)為 10000,但是它對應(yīng)的QPS 卻小于 一次pipeline命令個數(shù)為 100的。所以每次組織 Pipeline的命令個數(shù)不是越多越好,可以將一次包含大量命令的 Pipeline 拆分為 多個較小的 Pipeline 來完成。

Pipeline關(guān)于RTT的說明

在官網(wǎng)上有一段這樣的描述:

Redis基礎(chǔ)學(xué)習(xí)之管道機制詳析

大致意思就是 :

Pipeline管道機制不單單是為了減少RTT的一種方式,它實際上大大提高了Redis的QPS。原因是,在沒有使用管道機制的情況下,從訪問數(shù)據(jù)結(jié)構(gòu)和產(chǎn)生回復(fù)的角度來看,為每個命令提供服務(wù)是非常便宜的。但是從底層套接字的角度來看,這是非常昂貴的,這涉及read()和write()系統(tǒng)調(diào)用,從用戶態(tài)切換到內(nèi)核態(tài),這種上下文切換開銷是巨大。而使用Pipeline的情況下,通常使用單個read()系統(tǒng)調(diào)用讀取許多命令,然后使用單個write()系統(tǒng)調(diào)用傳遞多個回復(fù),這樣就提高了QPS

批量命令與Pipeline對比

  • 批量命令是原子的,Pipeline 是非原子的
  • 批量命令是一個命令多個 key,Pipeline支持多個命令
  • 批量命令是 Redis服務(wù)端實現(xiàn)的,而Pipeline需要服務(wù)端和客戶端共同實現(xiàn)

使用jedis執(zhí)行 pipeline

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
public class JedisUtils {
 private static final JedisUtils jedisutils = new JedisUtils();
 
 public static JedisUtils getInstance() {
 return jedisutils;
 }
 
 public JedisPool getPool(String ip, Integer port) {
 JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
 jedisPoolConfig.setMaxIdle(RedisConfig.MAX_IDLE);
 jedisPoolConfig.setMaxTotal(RedisConfig.MAX_ACTIVE);
 jedisPoolConfig.setMaxWaitMillis(RedisConfig.MAX_WAIT);
 jedisPoolConfig.setTestOnBorrow(true);
 jedisPoolConfig.setTestOnReturn(true);
 JedisPool pool = new JedisPool(jedisPoolConfig, ip, port,RedisConfig.TIMEOUT,RedisConfig.PASSWORD);
 return pool;
 }
 
 public Jedis getJedis(String ip, Integer port) {
 Jedis jedis = null;
 int count = 0;
 while (jedis == null && count < RedisConfig.RETRY_NUM) {
  try {
  jedis = getInstance().getPool(ip, port).getResource();
  } catch (Exception e) {
  System.out.println("get redis failed");
  }
  count++;
 }
 return jedis;
 }
 
 public void closeJedis(Jedis jedis) {
 if (jedis != null) {
  jedis.close();
 }
 }
 
 public static void main(String[] args) throws InterruptedException {
 Jedis jedis = JedisUtils.getInstance().getJedis("127.0.0.1", 6379);
 Pipeline pipeline = jedis.pipelined();
 pipeline.set("hello", "world");
 pipeline.incr("counter");
 System.out.println("還沒執(zhí)行命令");
 Thread.sleep(100000);
 System.out.println("這里才開始執(zhí)行");
 pipeline.sync();
 }
}

在睡眠100s的時候查看 Redis,可以看到此時在pipeline中的命令并沒有執(zhí)行,命令都被放在一個隊列中等待執(zhí)行:

?
1
2
3
4
127.0.0.1:6379> get hello
(nil)
127.0.0.1:6379> get counter
(nil)

睡眠結(jié)束后,使用 pipeline.sync()完成此次pipeline對象的調(diào)用。

?
1
2
3
4
127.0.0.1:6379> get hello
"world"
127.0.0.1:6379> get counter
"1"

必須要執(zhí)行pipeline.sync() 才能最終執(zhí)行命令,當(dāng)然可以使用 pipeline.syncANdReturnAll回調(diào)機制將pipeline響應(yīng)命令進行返回。

參考資料 & 鳴謝

  • Redis開發(fā)與運維
  • Using pipelining to speedup Redis queries

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對服務(wù)器之家的支持。

原文鏈接:https://juejin.im/post/5be01187e51d452b02557014

延伸 · 閱讀

精彩推薦
  • Redisredis中如何使用lua腳本讓你的靈活性提高5個逼格詳解

    redis中如何使用lua腳本讓你的靈活性提高5個逼格詳解

    這篇文章主要給大家介紹了關(guān)于redis中如何使用lua腳本讓你的靈活性提高5個逼格的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具...

    一線碼農(nóng)5812019-11-18
  • Redisredis實現(xiàn)排行榜功能

    redis實現(xiàn)排行榜功能

    排行榜在很多地方都能使用到,redis的zset可以很方便地用來實現(xiàn)排行榜功能,本文就來簡單的介紹一下如何使用,具有一定的參考價值,感興趣的小伙伴們...

    乘月歸5022021-08-05
  • Redis詳解Redis復(fù)制原理

    詳解Redis復(fù)制原理

    與大多數(shù)db一樣,Redis也提供了復(fù)制機制,以滿足故障恢復(fù)和負載均衡等需求。復(fù)制也是Redis高可用的基礎(chǔ),哨兵和集群都是建立在復(fù)制基礎(chǔ)上實現(xiàn)高可用的...

    李留廣10222021-08-09
  • RedisRedis 事務(wù)知識點相關(guān)總結(jié)

    Redis 事務(wù)知識點相關(guān)總結(jié)

    這篇文章主要介紹了Redis 事務(wù)相關(guān)總結(jié),幫助大家更好的理解和學(xué)習(xí)使用Redis,感興趣的朋友可以了解下...

    AsiaYe8232021-07-28
  • Redisredis 交集、并集、差集的具體使用

    redis 交集、并集、差集的具體使用

    這篇文章主要介紹了redis 交集、并集、差集的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友...

    xiaojin21cen10152021-07-27
  • RedisRedis的配置、啟動、操作和關(guān)閉方法

    Redis的配置、啟動、操作和關(guān)閉方法

    今天小編就為大家分享一篇Redis的配置、啟動、操作和關(guān)閉方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧 ...

    大道化簡5312019-11-14
  • RedisRedis如何實現(xiàn)數(shù)據(jù)庫讀寫分離詳解

    Redis如何實現(xiàn)數(shù)據(jù)庫讀寫分離詳解

    Redis的主從架構(gòu),能幫助我們實現(xiàn)讀多,寫少的情況,下面這篇文章主要給大家介紹了關(guān)于Redis如何實現(xiàn)數(shù)據(jù)庫讀寫分離的相關(guān)資料,文中通過示例代碼介紹...

    羅兵漂流記6092019-11-11
  • RedisRedis全量復(fù)制與部分復(fù)制示例詳解

    Redis全量復(fù)制與部分復(fù)制示例詳解

    這篇文章主要給大家介紹了關(guān)于Redis全量復(fù)制與部分復(fù)制的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用Redis爬蟲具有一定的參考學(xué)習(xí)...

    豆子先生5052019-11-27
主站蜘蛛池模板: a级毛片毛片免费很很综合 a级黄色视屏 | 欧美另类videos另类粗暴 | 色呦呦在线免费观看 | 青青在线视频观看 | 欧美亚洲高清日韩成人 | 99精品视频只99有精品 | 欧美vpswindows动物 | 国产女乱淫真高清免费视频 | 8x在线永久成人影院 | jizz 日本亚洲 | 欧美办公室激情videos高清 | 好大好硬好湿好紧h | 半挠脚心半黄的网站 | 五月天综合久久 | 动漫xnxx | 给我免费观看的视频在线播放 | 免费99精品国产自在现线 | 国产精品综合在线 | 欧美人xxxxxbbbb | 久久亚洲精品中文字幕60分钟 | 欧美美女被艹 | 我的年轻漂亮继坶三级 | 深夜视频免费看 | 日本一区免费观看 | www.国产在线观看 | 免费的毛片视频 | 极端 成熟 性别 视频 | 九九精品视频在线观看 | 2018高清国产一道国产 | a一区二区三区视频 | 2019nv天堂香蕉在线观看 | 激情影院免费 | 国产欧美日韩精品一区二区三区 | 国产成人影院在线观看 | 91在线播 | 男人的j伸到女人的屁股眼 男人吃奶动态图 | 国产一级毛片外aaaa | 扒开放荡老师裙子猛烈的进入 | 欧美午夜性春猛交bbb | 亚洲看片lutube在线入口 | 91porn最新地址 |