婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識(shí)庫 > 詳解redis是如何實(shí)現(xiàn)隊(duì)列消息的ack

詳解redis是如何實(shí)現(xiàn)隊(duì)列消息的ack

熱門標(biāo)簽:小紅書怎么地圖標(biāo)注店 最簡單的百度地圖標(biāo)注 地圖標(biāo)注如何即時(shí)生效 百度商家地圖標(biāo)注怎么做 西藏教育智能外呼系統(tǒng)價(jià)格 地圖標(biāo)注費(fèi)用 太原營銷外呼系統(tǒng) 竹間科技AI電銷機(jī)器人 玄武湖地圖標(biāo)注

前言

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

原生的redis中通過L/R PUSH/POP方式來實(shí)現(xiàn)隊(duì)列的功能,這個(gè)當(dāng)然是沒辦法滿足需求的(沒有ack功能),所以需要自己對redis的list(隊(duì)列)做個(gè)小小的調(diào)整。

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

以下腳本使用lua實(shí)現(xiàn),只需要在執(zhí)行前加載到redis中即可。

消息本身需要包含id屬性

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

pop時(shí)腳本

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

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

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時(shí)候比較簡單,只需要將指定id從set和hash中刪除即可

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

在程序中使用前需要顯示load這兩個(gè)腳本,后面直接調(diào)用這兩個(gè)腳本的sha值即可執(zhí)行。

總結(jié)

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

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

標(biāo)簽:澳門 贛州 景德鎮(zhèn) 香港 唐山 廣東 揚(yáng)州 林芝

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解redis是如何實(shí)現(xiàn)隊(duì)列消息的ack》,本文關(guān)鍵詞  詳解,redis,是,如何,實(shí)現(xiàn),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解redis是如何實(shí)現(xiàn)隊(duì)列消息的ack》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳解redis是如何實(shí)現(xiàn)隊(duì)列消息的ack的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 岢岚县| 芜湖市| 思茅市| 芜湖市| 墨玉县| 贺州市| 长丰县| 灌阳县| 南康市| 汝阳县| 吴桥县| 土默特右旗| 通化县| 延长县| 台州市| 河东区| 淮滨县| 扎赉特旗| 昌江| 潞城市| 台北县| 玉龙| 翁牛特旗| 儋州市| 湄潭县| 思茅市| 康马县| 潼南县| 惠安县| 扎赉特旗| 绥芬河市| 红桥区| 东兰县| 舒兰市| 根河市| 安陆市| 嘉定区| 麻城市| 白水县| 珲春市| 贵阳市|