好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 詳解redis是如何實現隊列消息的ack

詳解redis是如何實現隊列消息的ack

熱門標簽:小紅書怎么地圖標注店 最簡單的百度地圖標注 地圖標注如何即時生效 百度商家地圖標注怎么做 西藏教育智能外呼系統價格 地圖標注費用 太原營銷外呼系統 竹間科技AI電銷機器人 玄武湖地圖標注

前言

由于公司提供的隊列實在太過于蛋疼而且還限制不能使用其他隊列,但為了保證數據安全性需要一個可以有ack功能的隊列。

原生的redis中通過L/R PUSH/POP方式來實現隊列的功能,這個當然是沒辦法滿足需求的(沒有ack功能),所以需要自己對redis的list(隊列)做個小小的調整。

大體思路為在POP時將pop出的數據放到備份的地方,當有ACK請求(確認消息被消耗)后將備份的信息刪除掉;每次在pop前需要檢查備份隊列中有沒有過期的數據沒有ack的,如果有則PUSH到list中后再從list中POP出來。

以下腳本使用lua實現,只需要在執行前加載到redis中即可。

消息本身需要包含id屬性

push沒什么問題,原生即可(此處以LPUSH為例)

pop時腳本

local not_empty = function(x)
 return (type(x) == "table") and (not x.err) and (#x ~= 0)
end

local qName = ARGV[1] --隊列名稱
local currentTime = ARGV[2] --當前時間,這個需要從外部傳入,不能使用redis自身時間,如果使用自身時間可能導致redis本身的backup在重放請求時出現不一致性
local considerAsFailMaxTimeSpan = ARGV[3] --超時時間設定,當消息超過一定時間還沒有ack則認為此消息需要再次入隊

local zsetName= qName ..'BACKUP'
local hashName= qName ..'CONTEXT'

local tmp = redis.call('ZRANGEBYSCORE',zsetName , '-INF', tonumber(currentTime) - tonumber(considerAsFailMaxTimeSpan), 'LIMIT', 0, 1)
if (not_empty(tmp)) then
 redis.call('ZREM', zsetName, tmp[1]) --此處拿出的為消息的唯一id
 redis.call('LPUSH', qName, redis.call('HGET', hashName, tmp[1]))
end
tmp = redis.call('RPOP', qName)
if (tmp) then
 local msg = cjson.decode(tmp)
 local id = msg['id']
 redis.call('ZADD', zsetName, tonumber(currentTime), id)
 redis.call('HSET',hashName , id, tmp)
end
return tmp

ack時候比較簡單,只需要將指定id從set和hash中刪除即可

 local key = ARGV[1]
 local qName=ARGV[2]
 redis.call('ZREM', qName..'BACKUP', key)
 redis.call('HDEL', qName..'CONTEXT', key)

在程序中使用前需要顯示load這兩個腳本,后面直接調用這兩個腳本的sha值即可執行。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • 詳解Redis用鏈表實現消息隊列
  • SpringBoot利用redis集成消息隊列的方法
  • PHP使用php-resque庫配合Redis實現MQ消息隊列的教程
  • Java利用Redis實現消息隊列的示例代碼
  • phpredis提高消息隊列的實時性方法(推薦)
  • PHP基于Redis消息隊列實現發布微博的方法
  • php+redis消息隊列實現搶購功能
  • 深入理解redis分布式鎖和消息隊列
  • PHP+Redis 消息隊列 實現高并發下注冊人數統計的實例
  • redis中隊列消息實現應用解耦的方法

標簽:澳門 贛州 景德鎮 香港 唐山 廣東 揚州 林芝

巨人網絡通訊聲明:本文標題《詳解redis是如何實現隊列消息的ack》,本文關鍵詞  詳解,redis,是,如何,實現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解redis是如何實現隊列消息的ack》相關的同類信息!
  • 本頁收集關于詳解redis是如何實現隊列消息的ack的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 久久成人国产精品青青| 毛茸茸亚洲人美女高潮| 色姑娘天天干| 福利网站在线观看| 双性精h调教灌尿打屁股老章节 | 天降女子无删减无打码| 天啦噜.com精品影院| 永春县| 双性h文| 女同志亚洲人狂| 免费阅读黄色小说| 欧美????XXXX男人泡| 国产一级a毛一级a毛免费观看 | 91精品人妻系列无码专区四季 | 车多肉多的abo双a| 扒开内裤趴着女人打屁股动态图| 嗯~啊~快点??死我男男电影| ???18水蜜桃??大黄瓜??| 成人毛片免费网站| 日韩成人在线影院| 女同啪啪免费网站www| 娇妻初尝黑人巨小说| 777色婷婷AV一区二区三99| 欧美18一20男同69GAy| 老头巨大粗长xxxxx| 最近中文字幕在线MV视频下载| 美女的男人桶爽网站| 特黄做受又粗又大又硬老头| 久久精品亚洲AV无码一区二区三区| gogo全球高清大尺度美女人体| 欧美乱码精品一区二区三区卡| 扒掉乳罩秘?露出奶头壁纸 | 污动漫男女互插| 暗交拗女一区二区三区视频| 美国色情三级欧美三级| 双性花蒂抹药带环h| 九九九99久久国产精品| 久久国产精品99精品国产| 久视频免费精品6| 午夜精区av无码中文字幕| 性色AV丁香精品视频|