亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

對于redis 命令 rpoplpush的疑問

對于redis 命令 rpoplpush的疑問

jeck貓 2018-10-24 12:50:52
相比lpop,這個命令主要防止消息丟失的。如果lpop一個隊列,然后客戶端崩潰了,這時候這個消息就丟失了。官方的描述:可以添加一個客戶端專門用于監視備份表,它自動地將超過一定處理時限的消息重新放入隊列中去(負責處理該消息的客戶端可能已經崩潰),這樣就不會丟失任何消息了。那么,怎樣判斷超過一定時限的消息?我目前是這樣做的。1、rpoplpush 隊列,比如從A導出,備份到B。2、將得到的隊列zadd到一個有序集合zset里面。3、隊列完成,使用命令lrem將隊列移除出備份隊列B。如果進行到1步驟,沒有進行到2步驟,那就說明這個隊列丟失了。所以我只需要定期查詢B里面的隊列,是否存在zset里面就行了。貌似沒問題。但假如我的檢測程序運行在1和2步驟之間,那么就存在誤判了。避免這種情況,最好就是官方的描述:“超過一定處理時限的消息重新放入隊列中”,比如一個隊列,彈出來10秒之后再檢測就不會出現這種情況,那么如何判斷時間呢?
查看完整描述

1 回答

?
largeQ

TA貢獻2039條經驗 獲得超8個贊

自己找到答案了。另外維護一個zset。把備份隊列B的隊列先放入另外一個zset,隔15秒檢查一次。

查看完整回答
反對 回復 2018-10-24
  • 1 回答
  • 0 關注
  • 831 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號