日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

電子發(fā)燒友App

硬聲App

掃碼添加小助手

加入工程師交流群

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>電子資料>delaymq高性能的任意延時(shí)消息隊(duì)列

delaymq高性能的任意延時(shí)消息隊(duì)列

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

資料介紹

授權(quán)協(xié)議 GPL
開(kāi)發(fā)語(yǔ)言 Java
操作系統(tǒng) 跨平臺(tái)
軟件類型 開(kāi)源軟件

軟件簡(jiǎn)介

RocketMQ 開(kāi)源版本任意時(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í)消息的使用在代碼編寫(xiě)上存在略微的區(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)開(kāi)始延遲固定時(shí)間之后才開(kāi)始投遞。

注意事項(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ù)端開(kāi)始向消費(fèi)端投遞的時(shí)間。如果消費(fèi)者當(dāng)前有消息堆積,那么定時(shí)和延時(shí)消息會(huì)排在堆積消息后面,將不能?chē)?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

JAVA 開(kāi)源 服務(wù)端
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

評(píng)論

查看更多

下載排行

本周

  1. 1矽力杰 Silergy SY7215A 同步升壓調(diào)節(jié)器 規(guī)格書(shū) Datasheet 佰祥電子
  2. 1.12 MB  |  5次下載  |  免費(fèi)
  3. 2HT81696H 內(nèi)置升壓的30W立體聲D類音頻功放數(shù)據(jù)手冊(cè)
  4. 1.21 MB   |  1次下載  |  免費(fèi)
  5. 3HTA6863 3W超低噪聲超低功耗單聲道D類音頻功率放大器數(shù)據(jù)手冊(cè)
  6. 0.87 MB   |  次下載  |  免費(fèi)
  7. 4南芯 Southchip SC8802C 充電控制器 規(guī)格書(shū) Datasheet 佰祥電子
  8. 88.16 KB  |  次下載  |  免費(fèi)
  9. 5矽力杰 Silergy SY7065 同步升壓轉(zhuǎn)換器 規(guī)格書(shū) Datasheet 佰祥電子
  10. 910.67 KB  |  次下載  |  免費(fèi)
  11. 6矽力杰 Silergy SY7066 同步升壓轉(zhuǎn)換器 規(guī)格書(shū) Datasheet 佰祥電子
  12. 989.14 KB  |  次下載  |  免費(fèi)
  13. 7WD6208A產(chǎn)品規(guī)格書(shū)
  14. 631.24 KB  |  次下載  |  免費(fèi)
  15. 8NB685 26 V,12 A,低靜態(tài)電流,大電流 同步降壓變換器數(shù)據(jù)手冊(cè)
  16. 1.64 MB   |  次下載  |  2 積分

本月

  1. 1EMC PCB設(shè)計(jì)總結(jié)
  2. 0.33 MB   |  12次下載  |  免費(fèi)
  3. 2PD取電芯片 ECP5702規(guī)格書(shū)
  4. 0.88 MB   |  5次下載  |  免費(fèi)
  5. 3矽力杰 Silergy SY7215A 同步升壓調(diào)節(jié)器 規(guī)格書(shū) Datasheet 佰祥電子
  6. 1.12 MB  |  5次下載  |  免費(fèi)
  7. 4氮化鎵GaN FET/GaN HEMT 功率驅(qū)動(dòng)電路選型表
  8. 0.10 MB   |  3次下載  |  免費(fèi)
  9. 5PD取電芯片,可取5/9/12/15/20V電壓ECP5702數(shù)據(jù)手冊(cè)
  10. 0.88 MB   |  3次下載  |  免費(fèi)
  11. 6SY50655 用于高輸入電壓應(yīng)用的偽固定頻率SSR反激式穩(wěn)壓器英文資料
  12. 1.01 MB   |  3次下載  |  免費(fèi)
  13. 7怎么為半導(dǎo)體測(cè)試儀選擇精密放大器
  14. 0.65 MB   |  2次下載  |  免費(fèi)
  15. 8SY52341 次級(jí)側(cè)同步整流英文手冊(cè)
  16. 0.94 MB   |  2次下載  |  免費(fèi)

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935137次下載  |  10 積分
  3. 2開(kāi)源硬件-PMP21529.1-4 開(kāi)關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
  4. 1.48MB  |  420064次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233095次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費(fèi)下載
  8. 340992  |  191469次下載  |  10 積分
  9. 5十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
  10. 158M  |  183360次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81606次下載  |  10 積分
  13. 7Keil工具M(jìn)DK-Arm免費(fèi)下載
  14. 0.02 MB  |  73832次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65991次下載  |  10 積分
泽普县| 德安县| 舒城县| 鸡东县| 合水县| 榆中县| 滦平县| 高碑店市| 黄浦区| 安岳县| 屏山县| 浦北县| 黄陵县| 抚州市| 格尔木市| 长葛市| 永清县| 仁化县| 涞源县| 宝丰县| 邯郸县| 深圳市| 新源县| 乾安县| 惠来县| 嘉祥县| 类乌齐县| 家居| 宿迁市| 慈利县| 延长县| 乐昌市| 桦川县| 定兴县| 靖远县| 抚宁县| 邵阳市| 敦化市| 会泽县| 通许县| 汉中市|