## 發布訂閱
* 發布者不是計劃發送消息給特定的接收者(訂閱者),而是發布的消息分到不同的頻道,不需要知道什么樣的訂閱者訂閱
* 訂閱者對一個或多個頻道感興趣,只需接收感興趣的消息,不需要知道什么樣的發布者發布的
* 發布者和訂閱者的解耦合可以帶來更大的擴展性和更加動態的網絡拓撲
* 客戶端發到頻道的消息,將會被推送到所有訂閱此頻道的客戶端
* 客戶端不需要主動去獲取消息,只需要訂閱頻道,這個頻道的內容就會被推送過來
## 消息的格式
* 推送消息的格式包含三部分
* part1:消息類型,包含三種類型
* subscribe,表示訂閱成功
* unsubscribe,表示取消訂閱成功
* message,表示其它終端發布消息
* 如果第一部分的值為subscribe,則第二部分是頻道,第三部分是現在訂閱的頻道的數量
* 如果第一部分的值為unsubscribe,則第二部分是頻道,第三部分是現在訂閱的頻道的數量,如果為0則表示當前沒有訂閱任何頻道,當在Pub/Sub以外狀態,客戶端可以發出任何redis命令
* 如果第一部分的值為message,則第二部分是來源頻道的名稱,第三部分是消息的內容
## 命令
* 訂閱
~~~
SUBSCRIBE 頻道名稱 [頻道名稱 ...]
~~~
* 取消訂閱
* 如果不寫參數,表示取消所有訂閱
~~~
UNSUBSCRIBE 頻道名稱 [頻道名稱 ...]
~~~
* 發布
~~~
PUBLISH 頻道 消息
~~~
- mysql
- 1.創建庫和表
- 1.1.數據庫簡介
- 1.2.安裝管理
- 1.3.數據完整性
- 1.4.命令腳本操作
- 2.查詢
- 2.1.條件
- 2.2.聚合
- 2.3.分組
- 2.4.排序
- 2.5.分頁
- 3.高級
- 3.1.關系
- 3.2.連接
- 3.3.自關聯
- 3.4.子查詢
- 3.5.內置函數
- 3.6.視圖
- 3.7.事務
- 4.與python交互
- 4.1.交互類型
- 4.2.增改刪
- 4.3.查詢
- 4.4.封裝
- 4.5.用戶登錄
- Nosql簡介
- mongodb
- 1.基本操作
- 1.1.環境安裝
- 1.2.數據庫操作
- 1.3.集合操作
- 1.4.數據類型
- 1.5.數據操作
- 1.6.數據查詢
- 1.6.1.Limit與Skip
- 1.6.2.投影
- 1.6.3.排序
- 1.6.4.統計個數
- 1.6.5.消除重復
- 2.高級操作
- 2.1.聚合aggregate
- 2.1.1.$group
- 2.1.2.$match
- 2.1.3.$project
- 2.1.4.$sort
- 2.1.5.$limit,$skip
- 2.1.6.$unwind
- 2.2.安全
- 2.3.復制(副本集)
- 2.4.備份和恢復
- 2.5.與python交互
- redis
- 1.基本配置
- 2.數據操作
- 2.1.string
- 2.2.鍵命令
- 2.3.hash
- 2.4.list
- 2.5.set
- 2.6.zset
- 4.高級
- 4.1.發布訂閱
- 4.2.主從配置
- 5.與python交互
- 6.login登陸完善