資料介紹
軟件簡(jiǎn)介
RocketMQ 開源版本任意時(shí)間延時(shí)隊(duì)列實(shí)現(xiàn)
定時(shí)消息:Producer將消息發(fā)送到消息隊(duì)列RocketMQ版服務(wù)端,但并不期望立馬投遞這條消息,而是推遲到在當(dāng)前時(shí)間點(diǎn)之后的某一個(gè)時(shí)間投遞到Consumer進(jìn)行消費(fèi),該消息即定時(shí)消息。
延時(shí)消息:Producer將消息發(fā)送到消息隊(duì)列RocketMQ版服務(wù)端,但并不期望立馬投遞這條消息,而是延遲一定時(shí)間后才投遞到Consumer進(jìn)行消費(fèi),該消息即延時(shí)消息。
定時(shí)消息與延時(shí)消息在代碼配置上存在一些差異,但是最終達(dá)到的效果相同:消息在發(fā)送到消息隊(duì)列RocketMQ版服務(wù)端后并不會(huì)立馬投遞,而是根據(jù)消息中的屬性延遲固定時(shí)間后才投遞給消費(fèi)者。
適用場(chǎng)景
定時(shí)消息和延時(shí)消息適用于以下一些場(chǎng)景:
消息生產(chǎn)和消費(fèi)有時(shí)間窗口要求,例如在電商交易中超時(shí)未支付關(guān)閉訂單的場(chǎng)景,在訂單創(chuàng)建時(shí)會(huì)發(fā)送一條延時(shí)消息。
這條消息將會(huì)在30分鐘以后投遞給消費(fèi)者,消費(fèi)者收到此消息后需要判斷對(duì)應(yīng)的訂單是否已完成支付。
如支付未完成,則關(guān)閉訂單。如已完成支付則忽略。
通過(guò)消息觸發(fā)一些定時(shí)任務(wù),例如在某一固定時(shí)間點(diǎn)向用戶發(fā)送提醒消息。
使用方式 定時(shí)消息和延時(shí)消息的使用在代碼編寫上存在略微的區(qū)別:
發(fā)送定時(shí)消息需要明確指定消息發(fā)送時(shí)間點(diǎn)之后的某一時(shí)間點(diǎn)作為消息投遞的時(shí)間點(diǎn)。
發(fā)送延時(shí)消息時(shí)需要設(shè)定一個(gè)延時(shí)時(shí)間長(zhǎng)度,消息將從當(dāng)前發(fā)送時(shí)間點(diǎn)開始延遲固定時(shí)間之后才開始投遞。
注意事項(xiàng)
定時(shí)消息的精度會(huì)有1s~2s的延遲誤差。
定時(shí)和延時(shí)消息的msg.setStartDeliverTime參數(shù)需要設(shè)置成當(dāng)前時(shí)間戳之后的某個(gè)時(shí)刻(單位毫秒)。
如果被設(shè)置成當(dāng)前時(shí)間戳之前的某個(gè)時(shí)刻,消息將立刻投遞給消費(fèi)者。
定時(shí)和延時(shí)消息的msg.setStartDeliverTime參數(shù)可設(shè)置40天內(nèi)的任何時(shí)刻(單位毫秒),超過(guò)40天消息發(fā)送將失敗。
StartDeliverTime是服務(wù)端開始向消費(fèi)端投遞的時(shí)間。如果消費(fèi)者當(dāng)前有消息堆積,那么定時(shí)和延時(shí)消息會(huì)排在堆積消息后面,將不能嚴(yán)格按照配置的時(shí)間進(jìn)行投遞。
由于客戶端和服務(wù)端可能存在時(shí)間差,消息的實(shí)際投遞時(shí)間與客戶端設(shè)置的投遞時(shí)間之間可能存在偏差。
如何使用
推薦使用阿里云提供的rocketmq版本的pom
<dependency> <groupId>com.aliyun.openservicesgroupId> <artifactId>ons-clientartifactId> <version>1.8.4.Finalversion> dependency>
消息發(fā)送
import com.aliyun.openservices.ons.api.*; import com.aliyun.openservices.shade.org.apache.commons.lang3.time.DateFormatUtils; import java.util.Date; import java.util.Properties; public class ProducerDelayTest { public static void main(String[] args) { Properties properties = new Properties(); // AccessKey ID阿里云身份驗(yàn)證,在阿里云RAM控制臺(tái)創(chuàng)建。 properties.put(PropertyKeyConst.AccessKey, "XXX"); // AccessKey Secret阿里云身份驗(yàn)證,在阿里云RAM控制臺(tái)創(chuàng)建。 properties.put(PropertyKeyConst.SecretKey, "XXX"); // 設(shè)置TCP接入域名,進(jìn)入消息隊(duì)列RocketMQ版控制臺(tái)實(shí)例詳情頁(yè)面的接入點(diǎn)區(qū)域查看。 properties.put(PropertyKeyConst.NAMESRV_ADDR, "localhost:9876"); Producer producer = ONSFactory.createProducer(properties); // 在發(fā)送消息前,必須調(diào)用start方法來(lái)啟動(dòng)Producer,只需調(diào)用一次即可。 producer.start(); { Message msg = new Message( // 您在消息隊(duì)列RocketMQ版控制臺(tái)創(chuàng)建的Topic。 "TopicTest", // Message Tag,可理解為Gmail中的標(biāo)簽,對(duì)消息進(jìn)行再歸類,方便Consumer指定過(guò)濾條件在消息隊(duì)列RocketMQ版服務(wù)器過(guò)濾。 "TagA", // Message Body可以是任何二進(jìn)制形式的數(shù)據(jù),消息隊(duì)列RocketMQ版不做任何干預(yù),需要Producer與Consumer協(xié)商好一致的序列化和反序列化方式。 "演示15秒鐘>>> ".getBytes()); // 設(shè)置代表消息的業(yè)務(wù)關(guān)鍵屬性,請(qǐng)盡可能全局唯一。 // 以方便您在無(wú)法正常收到消息情況下,可通過(guò)控制臺(tái)查詢消息并補(bǔ)發(fā)。 // 注意:不設(shè)置也不會(huì)影響消息正常收發(fā)。 msg.setKey("ORDERID_100e"); try { // 延時(shí)消息,單位毫秒(ms),在指定延遲時(shí)間(當(dāng)前時(shí)間之后)進(jìn)行投遞,例如消息在15秒后投遞。 long delayTime = System.currentTimeMillis() + 15000; System.out.println("發(fā)送時(shí)間>>" + DateFormatUtils.format(new Date(), "yyyy-MM-dd HH
- 隊(duì)列實(shí)現(xiàn)數(shù)據(jù)循環(huán)外顯示源碼下載 4次下載
- 220MHz高性能差分振蕩器SiT9121 4次下載
- 高性能Type-C/DP1.4至HDMI2.0b轉(zhuǎn)換器CS5265AN 22次下載
- MX25L6445E高性能串行閃存規(guī)范文件 20次下載
- 高性能嵌入式堆棧Azure PTOS USBX概述 10次下載
- 高效高性能LED恒流驅(qū)動(dòng)電源芯片AX2028 24次下載
- 高性能低成本的藍(lán)牙模塊CSR6576原理圖 16次下載
- 怎么樣實(shí)現(xiàn)車輛隊(duì)列行駛系統(tǒng)的總體設(shè)計(jì)論文 5次下載
- 單片機(jī)實(shí)現(xiàn)FIFO循環(huán)隊(duì)列的代碼和資料免費(fèi)下載
- PIC32MX5XX/6XX/7XX系列高性能 32 位閃存單片機(jī)
- OV971高性能視頻汽車視覺應(yīng)用簡(jiǎn)介.pdf 1次下載
- 一種適用于任意余數(shù)基的高性能后向轉(zhuǎn)換結(jié)構(gòu)_楊鵬 0次下載
- MIMO天線中的延時(shí)失衡性能分析 27次下載
- 基于雙接收緩沖隊(duì)列的CAN驅(qū)動(dòng)模型設(shè)計(jì)
- 一種高效的磁盤隊(duì)列I/O機(jī)制
- FPGA延時(shí)Verilog HDL實(shí)現(xiàn) 353次閱讀
- Kafka高性能背后的技術(shù)原理 395次閱讀
- 裸機(jī)中環(huán)形隊(duì)列與RTOS中消息隊(duì)列有何區(qū)別呢? 736次閱讀
- 消息隊(duì)列的發(fā)展歷史 1183次閱讀
- Free RTOS的信息隊(duì)列 776次閱讀
- 如何使用消息隊(duì)列進(jìn)行通信 1436次閱讀
- 如何使用消息隊(duì)列進(jìn)行通信 1384次閱讀
- 淺析OSAT的高性能封裝技術(shù) 5437次閱讀
- 什么是消息隊(duì)列?消息隊(duì)列中間件重要嗎? 1446次閱讀
- SystemVerilog中的隊(duì)列 4125次閱讀
- 實(shí)現(xiàn)一個(gè)雙端隊(duì)列的步驟簡(jiǎn)析 1465次閱讀
- 什么是優(yōu)先隊(duì)列?漫畫形式帶你詳細(xì)了解優(yōu)先隊(duì)列 8091次閱讀
- 消息總線和消息隊(duì)列的區(qū)別是什么? 1.6w次閱讀
- FIFO隊(duì)列原理簡(jiǎn)述 擁塞避免原理 1w次閱讀
- Java常用消息隊(duì)列原理介紹及性能對(duì)比 8453次閱讀
下載排行
本周
- 1AN158 GD32VW553 Wi-Fi開發(fā)指南
- 1.51MB | 2次下載 | 免費(fèi)
- 2嵌入式軟件開發(fā)符合ISO 26262 功能安全標(biāo)準(zhǔn)
- 1.61 MB | 1次下載 | 免費(fèi)
- 3AN095 提高GD32溫度傳感器使用精度的方法
- 631.03KB | 1次下載 | 免費(fèi)
- 4PZT驅(qū)動(dòng)開關(guān)電路
- 0.09 MB | 1次下載 | 免費(fèi)
- 5模擬電路仿真實(shí)現(xiàn)
- 2.94MB | 1次下載 | 免費(fèi)
- 6PCB繪制基礎(chǔ)知識(shí)
- 2.44MB | 1次下載 | 免費(fèi)
- 7電子線路板及仿真實(shí)現(xiàn)
- 1.54MB | 1次下載 | 免費(fèi)
- 8AN4873-使用PIC單片機(jī)的集成運(yùn)算放大器測(cè)量水中的總?cè)芙夤腆w
- 591.02KB | 1次下載 | 免費(fèi)
本月
- 1ADI高性能電源管理解決方案
- 2.43 MB | 452次下載 | 免費(fèi)
- 2免費(fèi)開源CC3D飛控資料(電路圖&PCB源文件、BOM、
- 5.67 MB | 139次下載 | 1 積分
- 3基于STM32單片機(jī)智能手環(huán)心率計(jì)步器體溫顯示設(shè)計(jì)
- 0.10 MB | 132次下載 | 免費(fèi)
- 4美的電磁爐維修手冊(cè)大全
- 1.56 MB | 24次下載 | 5 積分
- 5如何正確測(cè)試電源的紋波
- 0.36 MB | 19次下載 | 免費(fèi)
- 6感應(yīng)筆電路圖
- 0.06 MB | 10次下載 | 免費(fèi)
- 7LZC3106G高性能諧振控制器中文手冊(cè)
- 1.29 MB | 9次下載 | 1 積分
- 8萬(wàn)用表UT58A原理圖
- 0.09 MB | 9次下載 | 5 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935121次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
- 1.48MB | 420062次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233088次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191367次下載 | 10 積分
- 5十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
- 158M | 183335次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81581次下載 | 10 積分
- 7Keil工具M(jìn)DK-Arm免費(fèi)下載
- 0.02 MB | 73810次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65988次下載 | 10 積分
評(píng)論
查看更多