91在线观看视频-91在线观看视频-91在线观看免费视频-91在线观看免费-欧美第二页-欧美第1页

電子發燒友App

硬聲App

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示
電子發燒友網>電子資料下載>電子資料>delaymq高性能的任意延時消息隊列

delaymq高性能的任意延時消息隊列

2022-06-14 | zip | 26.84 MB | 次下載 | 2積分

資料介紹

授權協議 GPL
開發語言 Java
操作系統 跨平臺
軟件類型 開源軟件

軟件簡介

RocketMQ 開源版本任意時間延時隊列實現

定時消息:Producer將消息發送到消息隊列RocketMQ版服務端,但并不期望立馬投遞這條消息,而是推遲到在當前時間點之后的某一個時間投遞到Consumer進行消費,該消息即定時消息。

延時消息:Producer將消息發送到消息隊列RocketMQ版服務端,但并不期望立馬投遞這條消息,而是延遲一定時間后才投遞到Consumer進行消費,該消息即延時消息。

定時消息與延時消息在代碼配置上存在一些差異,但是最終達到的效果相同:消息在發送到消息隊列RocketMQ版服務端后并不會立馬投遞,而是根據消息中的屬性延遲固定時間后才投遞給消費者。

適用場景

定時消息和延時消息適用于以下一些場景:

消息生產和消費有時間窗口要求,例如在電商交易中超時未支付關閉訂單的場景,在訂單創建時會發送一條延時消息。

這條消息將會在30分鐘以后投遞給消費者,消費者收到此消息后需要判斷對應的訂單是否已完成支付。

如支付未完成,則關閉訂單。如已完成支付則忽略。

通過消息觸發一些定時任務,例如在某一固定時間點向用戶發送提醒消息。

使用方式 定時消息和延時消息的使用在代碼編寫上存在略微的區別:

發送定時消息需要明確指定消息發送時間點之后的某一時間點作為消息投遞的時間點。

發送延時消息時需要設定一個延時時間長度,消息將從當前發送時間點開始延遲固定時間之后才開始投遞。

注意事項

定時消息的精度會有1s~2s的延遲誤差。

定時和延時消息的msg.setStartDeliverTime參數需要設置成當前時間戳之后的某個時刻(單位毫秒)。

如果被設置成當前時間戳之前的某個時刻,消息將立刻投遞給消費者。

定時和延時消息的msg.setStartDeliverTime參數可設置40天內的任何時刻(單位毫秒),超過40天消息發送將失敗。

StartDeliverTime是服務端開始向消費端投遞的時間。如果消費者當前有消息堆積,那么定時和延時消息會排在堆積消息后面,將不能嚴格按照配置的時間進行投遞。

由于客戶端和服務端可能存在時間差,消息的實際投遞時間與客戶端設置的投遞時間之間可能存在偏差。

如何使用

推薦使用阿里云提供的rocketmq版本的pom

       <dependency>
            <groupId>com.aliyun.openservicesgroupId>
            <artifactId>ons-clientartifactId>
            <version>1.8.4.Finalversion>
        dependency>

消息發送

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阿里云身份驗證,在阿里云RAM控制臺創建。
        properties.put(PropertyKeyConst.AccessKey, "XXX");
        // AccessKey Secret阿里云身份驗證,在阿里云RAM控制臺創建。
        properties.put(PropertyKeyConst.SecretKey, "XXX");
        // 設置TCP接入域名,進入消息隊列RocketMQ版控制臺實例詳情頁面的接入點區域查看。
        properties.put(PropertyKeyConst.NAMESRV_ADDR, "localhost:9876");
        

        Producer producer = ONSFactory.createProducer(properties);
        // 在發送消息前,必須調用start方法來啟動Producer,只需調用一次即可。
        producer.start();

         {
            Message msg = new Message(
                    // 您在消息隊列RocketMQ版控制臺創建的Topic。
                    "TopicTest",
                    // Message Tag,可理解為Gmail中的標簽,對消息進行再歸類,方便Consumer指定過濾條件在消息隊列RocketMQ版服務器過濾。
                    "TagA",
                    // Message Body可以是任何二進制形式的數據,消息隊列RocketMQ版不做任何干預,需要Producer與Consumer協商好一致的序列化和反序列化方式。
                    "演示15秒鐘>>> ".getBytes());
            // 設置代表消息的業務關鍵屬性,請盡可能全局唯一。
            // 以方便您在無法正常收到消息情況下,可通過控制臺查詢消息并補發。
            // 注意:不設置也不會影響消息正常收發。
            msg.setKey("ORDERID_100e");
            try {
                // 延時消息,單位毫秒(ms),在指定延遲時間(當前時間之后)進行投遞,例如消息在15秒后投遞。
                long delayTime = System.currentTimeMillis() + 15000;
                System.out.println("發送時間>>" + DateFormatUtils.format(new Date(), "yyyy-MM-dd HH

下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1DD3118電路圖紙資料
  2. 0.08 MB   |  1次下載  |  免費
  3. 2AD庫封裝庫安裝教程
  4. 0.49 MB   |  1次下載  |  免費
  5. 3PC6206 300mA低功耗低壓差線性穩壓器中文資料
  6. 1.12 MB   |  1次下載  |  免費
  7. 4網絡安全從業者入門指南
  8. 2.91 MB   |  1次下載  |  免費
  9. 5DS-CS3A P00-CN-V3
  10. 618.05 KB  |  1次下載  |  免費
  11. 6海川SM5701規格書
  12. 1.48 MB  |  次下載  |  免費
  13. 7H20PR5電磁爐IGBT功率管規格書
  14. 1.68 MB   |  次下載  |  1 積分
  15. 8IP防護等級說明
  16. 0.08 MB   |  次下載  |  免費

本月

  1. 1貼片三極管上的印字與真實名稱的對照表詳細說明
  2. 0.50 MB   |  103次下載  |  1 積分
  3. 2涂鴉各WiFi模塊原理圖加PCB封裝
  4. 11.75 MB   |  89次下載  |  1 積分
  5. 3錦銳科技CA51F2 SDK開發包
  6. 24.06 MB   |  43次下載  |  1 積分
  7. 4錦銳CA51F005 SDK開發包
  8. 19.47 MB   |  19次下載  |  1 積分
  9. 5PCB的EMC設計指南
  10. 2.47 MB   |  16次下載  |  1 積分
  11. 6HC05藍牙原理圖加PCB
  12. 15.76 MB   |  13次下載  |  1 積分
  13. 7802.11_Wireless_Networks
  14. 4.17 MB   |  12次下載  |  免費
  15. 8蘋果iphone 11電路原理圖
  16. 4.98 MB   |  6次下載  |  2 積分

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935127次下載  |  10 積分
  3. 2開源硬件-PMP21529.1-4 開關降壓/升壓雙向直流/直流轉換器 PCB layout 設計
  4. 1.48MB  |  420064次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233089次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費下載
  8. 340992  |  191390次下載  |  10 積分
  9. 5十天學會AVR單片機與C語言視頻教程 下載
  10. 158M  |  183342次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81588次下載  |  10 積分
  13. 7Keil工具MDK-Arm免費下載
  14. 0.02 MB  |  73815次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65989次下載  |  10 積分
主站蜘蛛池模板: 国产日日操 | 四虎www成人影院观看 | 神马福利 | 国产亚洲美女精品久久久2020 | h网站在线| 日本拍拍拍 | 日本免费黄色录像 | 免费观看三级毛片 | 免费看国产精品久久久久 | 国产女同在线观看 | 日本免费www | xxxxxx日本老师hd68 | 特黄特色大片免费播放路01 | 久久国产香蕉一区精品 | 国内精品久久久久影院男同志 | 一级片在线播放 | 成人国产三级在线播放 | 插插天天| 特黄大片aaaaa毛片 | 欧美性videofree精品 | 韩国xxxxxxxx69 | 国产一级特黄aa大片在线 | 午夜免费视频观看在线播放 | 七月色婷婷 | 午夜精品在线视频 | h视频免费 | 色五月激情小说 | 亚州第一视频 | 在线二区 | 四虎影院国产精品 | 国模吧一区二区三区精品视频 | 亚洲国产影视 | 亚洲天堂网在线观看 | 欧美一级高清免费播放 | 国产呦精品系列在线 | 性色aⅴ闺蜜一区二区三区 性色成人网 | 亚洲va久久久久综合 | 国产永久视频夜色资源网 | 模特视频一二三区 | 7799国产精品久久久久99 | 国产情侣草莓视频在线 |