1 回答

TA貢獻(xiàn)1877條經(jīng)驗(yàn) 獲得超6個(gè)贊
沒(méi)有直接或簡(jiǎn)單的方法可以做到這一點(diǎn)。延遲的作業(yè)保留在sorted sets
待處理時(shí)間score
和作業(yè)負(fù)載中value
。
有多種方法可以從排序集中刪除元素(大多數(shù)方法需要一些努力,具體取決于延遲隊(duì)列的大?。?,例如
您獲得分派作業(yè)的“準(zhǔn)確”有效負(fù)載,然后使用ZREM將其刪除。這很困難,因?yàn)閷?duì)象(具有所有參數(shù)的作業(yè)的序列化版本)可能很大,并且您無(wú)法創(chuàng)建“精確”作業(yè),因?yàn)樗哂形ㄒ粯?biāo)識(shí)符。您可以使用ZRANGEBYSCORE和獲取它的列表
WITHSCORES
。它將為您提供職位列表及其分?jǐn)?shù)。您可以使用分?jǐn)?shù)來(lái)識(shí)別要延遲的工作。獲取值(序列化有效負(fù)載)然后使用ZREM
.如果在特定時(shí)間只有一項(xiàng)作業(yè)要處理,您可以使用ZREMRANGEBYSCORE并使用處理時(shí)間。如果正好有 n 個(gè)作業(yè)需要在該時(shí)間處理,那么其他作業(yè)也可以被刪除,因?yàn)?code>ZREMRANGEBYSCORE需要時(shí)間間隔。
您可以嘗試使用ZSCAN掃描整個(gè)延遲列表(帶分頁(yè))并找到作業(yè)的分?jǐn)?shù)和標(biāo)識(shí)符,然后使用ZREMRANGEBYLEX和標(biāo)識(shí)符將其刪除。
另一種方法可以是在方法的開(kāi)頭放置取消條件
handle
。這個(gè)需要應(yīng)用層開(kāi)發(fā)。每當(dāng)您將作業(yè)推送到隊(duì)列時(shí),您都會(huì)向該作業(yè)發(fā)送一個(gè)標(biāo)識(shí)符,并將相同的標(biāo)識(shí)符(您可以理解的)也放入Redis中(大于EXPIRE
延遲時(shí)間)。當(dāng)你想取消它時(shí),然后從Redis中刪除它。在handle方法內(nèi)部檢查Redis中是否存在給定的標(biāo)識(shí)符,如果不存在則從代碼塊提前返回。
- 1 回答
- 0 關(guān)注
- 151 瀏覽
添加回答
舉報(bào)