摘要:基于實現(xiàn)的延遲隊列參考有贊延遲隊列設(shè)計實現(xiàn)項目地址應(yīng)用場景訂單超過分鐘未支付,自動關(guān)閉訂單完成后如果用戶一直未評價天后自動好評會員到期前天到期前天分別發(fā)送短信提醒猜想支付寶異步通知時間間隔是如何實現(xiàn)的通知的間隔頻率一般是訂單支付成功后生成
delay-queue
基于Redis實現(xiàn)的延遲隊列, 參考有贊延遲隊列設(shè)計實現(xiàn)
項目地址
應(yīng)用場景訂單超過30分鐘未支付,自動關(guān)閉
訂單完成后, 如果用戶一直未評價, 5天后自動好評
會員到期前15天, 到期前3天分別發(fā)送短信提醒
猜想支付寶異步通知時間間隔是如何實現(xiàn)的(通知的間隔頻率一般是:2m,10m,10m,1h,2h,6h,15h)
訂單支付成功后, 生成通知任務(wù), 放入消息隊列中.
任務(wù)內(nèi)容包含Array{0,0,2m,10m,10m,1h,2h,6h,15h}和通知到第幾次N(這里N=1, 即第1次).
消費者從隊列中取出任務(wù), 根據(jù)N取得對應(yīng)的時間間隔為0, 立即發(fā)送通知.
第1次通知失敗, N += 1 => 2
從Array中取得間隔時間為2m, 添加一個延遲時間為2m的任務(wù)到延遲隊列, 任務(wù)內(nèi)容仍包含Array和N
第2次通知失敗, N += 1 => 3, 取出對應(yīng)的間隔時間10m, 添加一個任務(wù)到延遲隊列, 同上
......
第7次通知失敗, N += 1 => 8, 取出對應(yīng)的間隔時間15h, 添加一個任務(wù)到延遲隊列, 同上
第8次通知失敗, N += 1 => 9, 取不到間隔時間, 結(jié)束通知
利用Redis的有序集合,member為JobId, score為任務(wù)執(zhí)行的時間戳,
每秒掃描一次集合,取出執(zhí)行時間小于等于當(dāng)前時間的任務(wù).
依賴Redis
運行./delay-queue -c delay-queue.conf
HTTP接口HTTP Server監(jiān)聽0.0.0.0:9277, Redis連接地址127.0.0.1:6379, 數(shù)據(jù)庫編號1
請求方法 POST
請求Body及返回值均為json
返回值{ "code": 0, "message": "添加成功", "data": null }
參數(shù)名 | 類型 | 含義 | 備注 |
---|---|---|---|
code | int | 狀態(tài)碼 | 0: 成功 非0: 失敗 |
message | string | 狀態(tài)描述信息 | |
data | object, null | 附加信息 |
URL地址 /push
{ "topic": "order", "id": "15702398321", "delay": 3600, "ttr": 120, "body": "{"uid": 10829378,"created": 1498657365 }" }
參數(shù)名 | 類型 | 含義 | 備注 |
---|---|---|---|
topic | string | Job類型 | |
id | string | Job唯一標(biāo)識 | 需確保JobID唯一 |
delay | int | Job需要延遲的時間, 單位:秒 | |
ttr | int | Job執(zhí)行超時時間, 單位:秒 | |
body | string | Job的內(nèi)容,供消費者做具體的業(yè)務(wù)處理,如果是json格式需轉(zhuǎn)義 |
服務(wù)端會Hold住連接, 直到隊列中有任務(wù)或180秒后超時返回,
任務(wù)執(zhí)行完成后需調(diào)用finish接口刪除任務(wù), 否則任務(wù)會重復(fù)投遞, 消費端需能處理同一任務(wù)的多次投遞
URL地址 /pop
{ "topic": "order" }
參數(shù)名 | 類型 | 含義 | 備注 |
---|---|---|---|
topic | string | Job類型 |
隊列中有任務(wù)返回值
{ "code": 0, "message": "操作成功", "data": { "id": "15702398321", "body": "{"uid": 10829378,"created": 1498657365 }" } }
隊列為空返回值
{ "code": 0, "message": "操作成功", "data": null }刪除任務(wù)
URL地址 /delete
{ "id": "15702398321" }
參數(shù)名 | 類型 | 含義 | 備注 |
---|---|---|---|
id | string | Job唯一標(biāo)識 |
URL地址 /finish
{ "id": "15702398321" }
參數(shù)名 | 類型 | 含義 | 備注 |
---|---|---|---|
id | string | Job唯一標(biāo)識 |
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/23164.html
摘要:基于的延遲消息隊列中間件,采用開發(fā),支持等多種語言客戶端。參考有贊延遲隊列設(shè)計中的部分設(shè)計,優(yōu)化后實現(xiàn)。會員到期前天,短信通知續(xù)費。其他針對某個任務(wù),延遲執(zhí)行功能的需求。服務(wù)器端定時使用連接池并行將中到期的放入對應(yīng)的中,供客戶端取出。 Delayer 基于 Redis 的延遲消息隊列中間件,采用 Golang 開發(fā),支持 PHP、Golang 等多種語言客戶端。 參考 有贊延遲隊列設(shè)計...
摘要:如果任務(wù)沒有在規(guī)定時間內(nèi)完成,那么該有序集合的任務(wù)將會被重新放入隊列中。這兩個進程操縱了三個隊列,其中一個,負責(zé)即時任務(wù),兩個,負責(zé)延時任務(wù)與待處理任務(wù)。如果任務(wù)執(zhí)行成功,就會刪除中的任務(wù),否則會被重新放入隊列中。 在實際的項目開發(fā)中,我們經(jīng)常會遇到需要輕量級隊列的情形,例如發(fā)短信、發(fā)郵件等,這些任務(wù)不足以使用 kafka、RabbitMQ 等重量級的消息隊列,但是又的確需要異步、重試...
閱讀 2820·2021-11-24 09:39
閱讀 3389·2021-11-19 09:40
閱讀 2259·2021-11-17 09:33
閱讀 3750·2021-10-08 10:04
閱讀 3038·2021-09-26 09:55
閱讀 1666·2021-09-22 15:26
閱讀 929·2021-09-10 10:51
閱讀 3129·2019-08-30 15:44