2018開工第一天,記錄一下

来源:https://www.cnblogs.com/mxlandxt/archive/2018/02/26/8471517.html
-Advertisement-
Play Games

導論 記錄一下阿裡雲消息服務與Spring的整合,以及ProducerId與ConsumerId的管理,其他的消息服務也是類似(RocketMQ、Kafka),阿裡雲消息服務性能還是很可觀的,雖然收費,單也推薦使用。 整合 消息服務的概念就不想多說了,需要的可以去看官方文檔, "參考文檔" 。 創建 ...


導論

記錄一下阿裡雲消息服務與Spring的整合,以及ProducerId與ConsumerId的管理,其他的消息服務也是類似(RocketMQ、Kafka),阿裡雲消息服務性能還是很可觀的,雖然收費,單也推薦使用。

整合

消息服務的概念就不想多說了,需要的可以去看官方文檔,參考文檔

創建topic

首先創建topic,如下圖填好信息就OK了。

圖一

創建成功之後是這樣

圖二

ProducerId的創建

圖三

ConsumerId的創建

圖四

整合spring

上面那些步驟信息填完整之後topic、ProducerId、ConsumerId都創建好了就可以使用消息隊列了

Producer的整合

     <bean id="producer" class="com.aliyun.openservices.ons.api.bean.ProducerBean" init-method="start"
          destroy-method="shutdown">
        <property name="properties"> <!--生產者配置信息-->
            <props>
                <!-- 生成者ID,需要提前在阿裡雲創建  -->
                <prop key="ProducerId">PID-SIT-TransitHub-NotifyUnbind</prop> <!--請替換為自己的賬戶信息-->
                <!-- AccessKey、SecretKey由阿裡雲分配 -->
                <prop key="AccessKey">LTAIqfzogBNFeohh11</prop>
                <prop key="SecretKey">zoahuhZKscEk5Q8Qtr</prop>
                <!-- 根據自己伺服器選擇不同的tcp接入url,此處選擇公網 -->
                <prop key="ONSAddr">http://onsaddr-internet.aliyun.com/rocketmq/nsaddr4client-internet</prop>
            </props>
        </property>
    </bean>

Consumer的整合

<!-- 創建Listener將消費者處於阻塞狀態,只要有自己topic訂閱的消息發佈消息馬上就會訂閱到-->
<bean id="tsmDeleteAidMsgListener" class="com.snowball.hub.msg.DataMessageListener" /> Listener配置
<bean id="consumer" class="com.aliyun.openservices.ons.api.bean.ConsumerBean"
    init-method="start" destroy-method="shutdown">
    <property name="properties">
        <props>
            <prop key="ConsumerId">CID-SIT-OPS-NotifyUnbind</prop> 
            <prop key="AccessKey">${access_key}</prop>
            <prop key="SecretKey">${secret_key}</prop>
            <!--將消費者線程數固定為50個,該線程不會和主業務線程耦合-->
            <prop key="ConsumeThreadNums">50</prop>
        </props>
    </property>
    <property name="subscriptionTable">
        <map>
            <entry value-ref="tsmDeleteAidMsgListener">
                <key>
                    <bean class="com.aliyun.openservices.ons.api.bean.Subscription">
                        <!-- 此處填將之前創建的topic -->
                        <property name="topic" value="snb-test-topic4" />
                        <property name="expression" value="*" />
                        <!--
                        expression即Tag,可以設置成具體的Tag,如 taga||tagb||tagc,也可設置成*。 *僅代表訂閱所有Tag,不支持通配
                        -->
                    </bean>
                </key>
            </entry>
            更多的訂閱添加entry節點即可
        </map>
    </property>
</bean>

Consumer的整合和Producer基本一致,不同的是需要創建一個Listener,作用已經在註釋中說明。

使用阿裡雲sdk發佈和訂閱消息

上面只是整合了普通消息,阿裡雲MQ消息分很四種,每一種的整合API都不一樣,具體整合細節可以參考文章開始出的參考文檔。

發佈消息
public class ProducerTest {
    
    //如果和spring整合了,那就直接註入就好了,本次使用傳統的發佈方式
    //@Autowired
    //private Producer producer;
    
    //topic的管理最好做成可配置,可以對應不同的環境管理不同的topic,本次還是使用傳統的//方式發佈
    //@Value("#{configProperties['send_unbind_topic']}")
    //private String send_unbind_topic;

 public static void main(String[] args) {
     Properties properties = new Properties();
     // 您在MQ控制台創建的Producer ID
     properties.put(PropertyKeyConst.ProducerId, "XXX");
     // 鑒權用AccessKey,在阿裡雲伺服器管理控制台創建
     properties.put(PropertyKeyConst.AccessKey,"XXX");
     // 鑒權用SecretKey,在阿裡雲伺服器管理控制台創建
     properties.put(PropertyKeyConst.SecretKey, "XXX");
     // 設置 TCP 接入功能變數名稱(此處以公共雲的公網接入為例)
     properties.put(PropertyKeyConst.ONSAddr,
       "http://onsaddr-internet.aliyun.com/rocketmq/nsaddr4client-internet");

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

     //迴圈發送消息
     while(true){
         Message msg = new Message( //
             // 在控制台創建的Topic,即該消息所屬的Topic名稱
             "TopicTestMQ",
             // Message Tag,
             // 可理解為Gmail中的標簽,對消息進行再歸類,方便Consumer指定過濾條件在MQ伺服器過濾
             "TagA",
             // Message Body
             // 任何二進位形式的數據, MQ不做任何干預,
             // 需要Producer與Consumer協商好一致的序列化和反序列化方式
             "Hello MQ".getBytes());
         // 設置代表消息的業務關鍵屬性,請儘可能全局唯一,以方便您在無法正常收到消息情況下,可通過MQ控制台查詢消息並補發
         // 註意:不設置也不會影響消息正常收發
         msg.setKey("ORDERID_100");
         // 發送消息,只要不拋異常就是成功
         // 列印Message ID,以便用於消息發送狀態查詢
         SendResult sendResult = producer.send(msg);
         System.out.println("Send Message success. Message ID is: " + sendResult.getMessageId());
     }

     // 在應用退出前,可以銷毀Producer對象
     // 註意:如果不銷毀也沒有問題
     producer.shutdown();
 }
}

消息發佈成功可以看到sendResult是這樣的信息

{"messageId":"0200010546D011E87BD078ACF4180003","topic":"TPC-SIT-COM-TransitHub-NotifyUnbind"}

根據messageId可以定位這條消息的軌跡,可以很清晰的定位消息的消費軌跡。
圖五

訂閱消息
public class ConsumerTest {
    public static void main(String[] args) {
        Properties properties = new Properties();
        // 您在MQ控制台創建的Consumer ID
        properties.put(PropertyKeyConst.ConsumerId, "XXX");
        // 鑒權用AccessKey,在阿裡雲伺服器管理控制台創建
        properties.put(PropertyKeyConst.AccessKey, "XXX");
        // 鑒權用SecretKey,在阿裡雲伺服器管理控制台創建
        properties.put(PropertyKeyConst.SecretKey, "XXX");
        // 設置 TCP 接入功能變數名稱(此處以公共雲公網環境接入為例)
        properties.put(PropertyKeyConst.ONSAddr,
          "http://onsaddr-internet.aliyun.com/rocketmq/nsaddr4client-internet");

        Consumer consumer = ONSFactory.createConsumer(properties);
        //這個Listener如果之前已經在spring容器中註冊過直接使用就好了,這裡就不演示了
        consumer.subscribe("TopicTestMQ", "*", new MessageListener() {
            public Action consume(Message message, ConsumeContext context) {
                System.out.println("Receive: " + message);
                return Action.CommitMessage;
            }
        });
        consumer.start();
        System.out.println("Consumer Started");
    }
}

消息的發佈與訂閱就這麼多,要使用消息服務總結起來就四步。

  1. 開通服務
  2. 申請資源
  3. 發佈消息
  4. 訂閱消息
總結

消息的產品很多,阿裡雲的消息服務是目前互聯網公司使用占比很大的,本次只是很簡單介紹消息服務的使用,具體實現細節筆者也在學習中。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • HTML是Web統一語言,這些容納在尖括弧里的簡單標簽,構成瞭如今的Web。 1991年,Tim Berners-Lee編寫了一份叫做“HTML標簽”的文檔,裡面包含了大約20個用來標記網頁的HTML標簽。他直接借用SGML的標記格式,也就是後來我們看到的HTML標記的格式。 從IETF到W3C:H ...
  • 1. ps 鏈接: https://pan.baidu.com/s/1mjYbcJA 密碼: pqdt2. HTML5+CSS3從入門到精通.iso 鏈接: https://pan.baidu.com/s/1cUHz3o 密碼: gdyw3. Javascript視頻教程 鏈接: https://p ...
  • 一切皆對象 屬性:升高 體重 方法:唱歌 跳舞 打招呼 數據類型:字元串、數字、布爾、數組、對象、Null、Undefined (面試會考) Null:空 false Undefined 沒有聲明 false 面向對象 鍵值對 數據類型:字元串 數組 布爾 對象 NAN undefined 知識點1 ...
  • @{ Layout = null; ViewBag.Title = "Login Page"; } IndexMain @*樣式*@ ...
  • 偽元素選擇器: ::first-letter:為某個元素中的文字的首字母或第一個字使用樣式。 ::first-line:為某個元素的第一行文字使用樣式。 ::before:在某個元素之前插入一些內容。 ::after:在某個元素之後插入一些內容 ::selection:匹配元素中被用戶選中或處於高亮 ...
  • 一、指令定義 對於指令,可以把它簡單的理解成在特定DOM元素上運行的函數,指令可以擴展這個元素的功能。 首先來看個完整的參數示例再來詳細的介紹各個參數的作用及用法: 二、指令參數的作用和意義(這個地方只選常用的幾種來講一下) restrict[string] 一般考慮到瀏覽器的相容性,強烈建議使用默 ...
  • /// <summary> /// 抽象聚合介面 /// </summary> public interface IListCollection { Iterator GetIterator(); } //迭代器抽象類 public interface Iterator { bool MoveNex ...
  • 一、Metrics簡介 應用監控系統Metrics由Metrics.NET+InfluxDB+Grafana組合而成,通過客戶端Metrics.NET在業務代碼中埋點,Metrics.NET會把收集到數據存儲在InfluxDB資料庫中,然後通過Grafana來展示監控數據。其中,InfluxDB服務 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...