redis 事務及鎖應用/發佈訂閱/

分類: NoSQLhtml

                                    MySQL                    Redis
開啓      Start transaction      mutil
語句      普通SQL                  通命令
失敗      rollback                   discard
成功      commit                    exec

注:rollback和discard的區別,若是已經成功執行了2條語句,第三條語句出錯,rollback後前2條的語句影響消失,而redis中discard只是結束本次事務,前2條語句形成的影響仍然存在。
redis

Redis 發佈訂閱

Redis 發佈訂閱(pub/sub)是一種消息通訊模式:發送者(pub)發送消息,訂閱者(sub)接收消息。ui

Redis 客戶端能夠訂閱任意數量的頻道。spa

下圖展現了頻道 channel1 , 以及訂閱這個頻道的三個客戶端 —— client2 、 client5 和 client1 之間的關係:code

pubsub1

當有新消息經過 PUBLISH 命令發送給頻道 channel1 時, 這個消息就會被髮送給訂閱它的三個客戶端:htm

pubsub2


實例

如下實例演示了發佈訂閱是如何工做的。在咱們實例中咱們建立了訂閱頻道名爲 redisChat:事務

redis 127.0.0.1:6379> SUBSCRIBE redisChatReading messages... (press Ctrl-C to quit)1) "subscribe"2) "redisChat"3) (integer) 1

如今,咱們先從新開啓個 redis 客戶端,而後在同一個頻道 redisChat 發佈兩次消息,訂閱者就能接收到消息。get

redis 127.0.0.1:6379> PUBLISH redisChat "Redis is a great caching technique"(integer) 1redis 127.0.0.1:6379> PUBLISH redisChat "Learn redis by w3cschool.cc"(integer) 1# 訂閱者的客戶端會顯示以下消息1) "message"2) "redisChat"3) "Redis is a great caching technique"1) "message"2) "redisChat"3) "Learn redis by w3cschool.cc"

Redis 發佈訂閱命令

下表列出了 redis 發佈訂閱經常使用命令:it

序號 命令及描述
1 PSUBSCRIBE pattern [pattern ...]
訂閱一個或多個符合給定模式的頻道。
2 PUBSUB subcommand [argument [argument ...]]
查看訂閱與發佈系統狀態。
3 PUBLISH channel message
將信息發送到指定的頻道。
4 PUNSUBSCRIBE [pattern [pattern ...]]
退訂全部給定模式的頻道。
5 SUBSCRIBE channel [channel ...]
訂閱給定的一個或多個頻道的信息。
6 UNSUBSCRIBE [channel [channel ...]] 指退訂給定的頻道。
相關文章
相關標籤/搜索