我們知道redis支持很多種結構的數據,那么如何使用redis作為異步隊列使用呢?
- 使用list結構,rpush生產消息,lpop消費消息。
- lpop沒有消息的時候,可適當sleep后重試。
- 若不使用sleep方案,可使用blpop消費消息,它會阻塞直至消息到來。
pub/sub的主題訂閱者模式的優缺點
優點:可實現生產一次消費多次,實現1:N的消息隊列。
缺點:在消費者下線的情況下,生產的消息會丟失,需要專業的消息隊列如rabbitMQ。
如何使用redis實現演示隊列?
可配合使用sortedset,時間戳為score,消息內容為key,調用zadd來生產消息。消費者用zrangebyscore指令獲取數據輪詢進行處理。
以上總結參考:https://mp.weixin.qq.com/s/HEEhaVLNMGr4W06hPxWKjA