Redis队列和阻塞队列
生活随笔
收集整理的這篇文章主要介紹了
Redis队列和阻塞队列
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
redis 隊列的優點是輕量級,業務足夠簡單時不需要使用rabbitMq這樣專業的消息中間件;缺點是彈出隊列中的元素時,即使該消息處理失敗也無法再次進行消費
Redis隊列 List
簡單演示如下
普通的redis隊列,為了實現業務,通常會使用while進行循環,這樣的話沒有消息時依舊會頻繁的執行循環,造成cpu的空轉,所以一般會在代碼中增加sleep來解決該問題,但因此又會造成消息延遲問題。
阻塞隊列可以很好的解決這些問題。
Redis阻塞隊列
redis隊列提供了 “阻塞式” 拉取消息的命令:BRPOP / BLPOP,這里的 B 指的是阻塞(Block)。
如果隊列為空,消費者在拉取消息時就「阻塞等待」,一旦有新消息過來,就通知消費者立即處理新消息。
阻塞隊列實現:
使用 BRPOP 這種阻塞式方式拉取消息時,還支持傳入一個「超時時間」,如果設置為 0,則表示不設置超時,直到有新消息才返回,否則會在指定的超時時間后返回 NULL
下面是某業務完整的消費者代碼
注意:
實際項目中redis連接超時時間遠大于20s,因此正常情況不會出現redis超時問題。以防萬一增加redis異常捕獲,出現異常時殺掉當前進程,同時supervisord會自動重新拉起該進程
總結
以上是生活随笔為你收集整理的Redis队列和阻塞队列的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 台达ES2与台达温控器ASCII通讯程序
- 下一篇: linux cmake编译源码,linu