欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

redis發(fā)布訂閱_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

 更新時(shí)間:2017年08月25日 10:34:43   作者:huangxincheng  
這篇文章主要介紹了redis發(fā)布訂閱,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

其實(shí)在很多的MQ產(chǎn)品中都存在這樣的一個(gè)模式,我們常聽到的一個(gè)例子就是郵件訂閱的場(chǎng)景,什么意思呢,也就是說100個(gè)人訂閱了你的博客,如果博主發(fā)表了文章,那么100個(gè)人就會(huì)同時(shí)收到通知郵件,除了這個(gè)場(chǎng)景還能找到其他場(chǎng)景么,當(dāng)然有啦,你想想,如果你要在內(nèi)存里面做一個(gè)讀寫分離的程序,為了維持?jǐn)?shù)據(jù)的完整性,你是不是需要保證在寫入的時(shí)候,也要分發(fā)到各個(gè)讀內(nèi)存的程序中呢?所以說場(chǎng)景還是很多的,在于你的挖掘~~~ 下面還是從基本命令入手:

一:命令簡(jiǎn)介

從redis手冊(cè)上面可以看到,其實(shí)“發(fā)布、訂閱”模式才區(qū)區(qū)6個(gè)命令,下面聽我一一解說下哈~~~

1. subscribe

SUBSCRIBE channel [channel ...]

訂閱給定的一個(gè)或多個(gè)頻道的信息。     

從上面的官方解釋上來看,它的玩法有一點(diǎn)像現(xiàn)實(shí)生活中我們聽收音機(jī)一個(gè)道理,要想聽收音機(jī),我們要做什么?肯定就是調(diào)頻啦,只有在正確的頻道上面,我們才能聽得到好聽的節(jié)目,所以說subscribe首先要訂閱一個(gè)頻道(channel),下面我舉個(gè)例子,開兩個(gè)client,分別訂閱著msg 這個(gè)頻道,比如下面這樣:

2.publish  

到現(xiàn)在為止,這兩個(gè)subscibe都在監(jiān)視著msg這個(gè)頻道,接下來,如果msg頻道有消息傳出,必定會(huì)被subscribe接收到,先我們還是看看redis手冊(cè)上怎么用這個(gè)命令。

PUBLISH channel message

將信息 message 發(fā)送到指定的頻道 channel 。

看到上面命令的用法,我也就放心了。

看到么有,publish在msg這個(gè)頻道上面發(fā)送消息后,被subscribe監(jiān)視到了,然后就被分別打印輸出了,好了,到現(xiàn)在為止,最基本的發(fā)布訂閱模式就是這樣,是不是很簡(jiǎn)單哈。。。其實(shí)呢??? 也就是這么簡(jiǎn)單吶,但是呢,有時(shí)候我們還有這樣一個(gè)需求,就是我能不能模糊匹配key呢???舉了例子,就是要求訂閱china為前綴的所有頻道,如果這樣也可以做到的話,那確實(shí)是很牛啦。。。強(qiáng)大的redis自然會(huì)做到這一點(diǎn),它提供了的命令就是:Psubscribe。

3. Psubscribe

PSUBSCRIBE pattern [pattern ...]

訂閱一個(gè)或多個(gè)符合給定模式的頻道。

每個(gè)模式以 * 作為匹配符,比如 it* 匹配所有以 it 開頭的頻道( it.news 、 it.blog 、 it.tweets 等等), news.* 匹配所有以 news. 開頭的頻道( news.it 、 news.global.today 等等),諸如此類。

看到上面的解釋,你心里可能就在想,這不就是正則匹配么。。。而且前綴“P”就是Pattern的意思,對(duì)吧,接下來我就訂閱一下所有china為前綴的channel。

好了,最常用的也就是這三個(gè)命令,接下來我們簡(jiǎn)單分析一下代碼。

二: 源碼簡(jiǎn)單分析

其實(shí)redis的發(fā)布訂閱模式,使用RedisServer下面的 pubsub_channels字典 和 pubsub_patterns數(shù)組存放的,所有的操作代碼都

在pubsub.c文件下,如下圖:

1.   pubsub_channels 

可以看到,它是一個(gè)字典結(jié)構(gòu),通過注釋你應(yīng)該明白,它的key為channel,value為list。

2.   pubsub_patterns

同樣從注釋中,你可以看到,其實(shí)它就是存放模式匹配的subscribe的clients列表,對(duì)吧,用一個(gè)list數(shù)組實(shí)現(xiàn)。 

3.   subcribeCommand

通過下面的代碼,你是不是在腦子里面很有輪廓了???其實(shí)這個(gè)pubsub_channels果然就是key=channel,value=list的存放模式,這個(gè)list就是所謂的clients列表,這樣的話,你就知道了哪些key掛了哪些clients,對(duì)吧,如果再publish的話,只需要遍歷一下這個(gè)list就知道結(jié)果了。

4.  publishCommand

先前也說了,publish的原理很簡(jiǎn)單,就是找到字典中的channel這個(gè)key,獲取到clients之后,遍歷client的來發(fā)送信息。

同樣的道理,pubsub_patterns也是差不多的實(shí)現(xiàn),只要大家簡(jiǎn)單看一下pubsub.c這個(gè)源代碼文件,差不多都會(huì)懂得

相關(guān)文章

  • redis清空所有數(shù)據(jù)的三種方法

    redis清空所有數(shù)據(jù)的三種方法

    本文主要介紹了redis清空所有數(shù)據(jù)的三種方法,主要包括FLUSHALL,FLUSHDB,SCREPT FLUSH這三個(gè)指令,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-09-09
  • 保證Redis中存儲(chǔ)的Token安全性的示例詳解

    保證Redis中存儲(chǔ)的Token安全性的示例詳解

    確保Redis中存儲(chǔ)的Token安全性是一個(gè)多層面的任務(wù),涉及到網(wǎng)絡(luò)、應(yīng)用、數(shù)據(jù)和操作等多個(gè)方面的安全措施,本文給大家介紹了一些詳細(xì)的實(shí)踐建議和示例,并有詳細(xì)的代碼供大家參考,需要的朋友可以參考下
    2024-03-03
  • Redis刪除過期key策略詳解

    Redis刪除過期key策略詳解

    Redis是一款高性能的開源內(nèi)存數(shù)據(jù)庫,廣泛應(yīng)用于緩存、消息隊(duì)列、實(shí)時(shí)分析等場(chǎng)景,在Redis中,我們經(jīng)常需要?jiǎng)h除過期的key,以釋放內(nèi)存空間并保持?jǐn)?shù)據(jù)的有效性,本文將為您詳細(xì)介紹Redis的過期key刪除策略,幫助您更好地管理和優(yōu)化Redis數(shù)據(jù)庫
    2023-10-10
  • Redis?布隆過濾器命令的使用詳解

    Redis?布隆過濾器命令的使用詳解

    這篇文章主要介紹了Redis?布隆過濾器的相關(guān)命令的使用,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-08-08
  • Redis設(shè)置鍵的生存時(shí)間或過期時(shí)間的方法詳解

    Redis設(shè)置鍵的生存時(shí)間或過期時(shí)間的方法詳解

    這篇文章主要介紹了Redis如何設(shè)置鍵的生存時(shí)間或過期時(shí)間,通過EXPIRE命令或者PEXIPIRE命令,客戶端可以以秒或者毫秒精度為數(shù)據(jù)庫中的某個(gè)鍵設(shè)置生存時(shí)間,文中有詳細(xì)的代碼供供大家參考,需要的朋友可以參考下
    2024-03-03
  • Redis主從復(fù)制詳解

    Redis主從復(fù)制詳解

    今天小編就為大家分享一篇關(guān)于Redis主從復(fù)制詳解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • 淺析Redis分布式鎖

    淺析Redis分布式鎖

    本篇文章通過實(shí)例給大家講解了Redis分布式鎖工作原理以及用法分享,有需要的朋友參考學(xué)習(xí)下吧。
    2017-12-12
  • Redis哨兵模式介紹

    Redis哨兵模式介紹

    這篇文章介紹了Redis哨兵模式,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-02-02
  • 使用Redis實(shí)現(xiàn)實(shí)時(shí)排行榜功能

    使用Redis實(shí)現(xiàn)實(shí)時(shí)排行榜功能

    排行榜功能是一個(gè)很普遍的需求。使用 Redis 中有序集合的特性來實(shí)現(xiàn)排行榜是又好又快的選擇。接下來通過本文給大家介紹使用Redis實(shí)現(xiàn)實(shí)時(shí)排行榜功能,需要的朋友可以參考下
    2021-07-07
  • 使用Redis實(shí)現(xiàn)用戶積分排行榜的教程

    使用Redis實(shí)現(xiàn)用戶積分排行榜的教程

    這篇文章主要介紹了使用Redis實(shí)現(xiàn)用戶積分排行榜的教程,包括一個(gè)用PHP腳本進(jìn)行操作的例子,需要的朋友可以參考下
    2015-04-04

最新評(píng)論