日本熟妇hd丰满老熟妇,中文字幕一区二区三区在线不卡 ,亚洲成片在线观看,免费女同在线一区二区

收發普通消息

普通消息是指云消息隊列 RocketMQ 版中無特性的消息,區別于有特性的定時和延時消息、順序消息和事務消息。不同消息類型所屬的Topic不能混用,例如收發普通消息的Topic不能用來收發其他類型的消息。本文提供使用TCP協議下的C/C++ SDK收發普通消息的示例代碼供您參考。

前提條件

您已完成以下操作:

  • 下載C/C++ SDK。更多信息,請參見版本說明。

  • 準備環境。更多信息,請參見環境準備(v1.x.x)。

  • 創建資源。代碼中涉及的資源信息,例如實例、Topic和Group ID等,需要在控制臺上提前創建。更多信息,請參見創建資源。

  • 獲取阿里云訪問密鑰AccessKey ID和AccessKey Secret。更多信息,請參見創建AccessKey

發送普通消息

請參考以下示例代碼進行消息發送。

#include "ONSFactory.h"
#include "ONSClientException.h"

using namespace ons;

int main()
{

    //創建Producer,并配置發送消息所必需的信息。
    ONSFactoryProperty factoryInfo; 
    //您在消息隊列RocketMQ版控制臺創建的Group ID。
    factoryInfo.setFactoryProperty(ONSFactoryProperty::ProducerId, "XXX");
    //設置TCP接入域名,進入消息隊列RocketMQ版控制臺實例詳情頁面的接入點區域查看。
    factoryInfo.setFactoryProperty(ONSFactoryProperty::NAMESRV_ADDR, "XXX");
    // 您在消息隊列RocketMQ版控制臺創建的Topic。
    factoryInfo.setFactoryProperty(ONSFactoryProperty::PublishTopics,"XXX" );
    //消息內容。
    factoryInfo.setFactoryProperty(ONSFactoryProperty::MsgContent, "XXX");
    //請確保環境變量ALIBABA_CLOUD_ACCESS_KEY_ID、ALIBABA_CLOUD_ACCESS_KEY_SECRET已設置。
    //AccessKey ID,阿里云身份驗證標識。
    factoryInfo.setFactoryProperty(ONSFactoryProperty::AccessKey, getenv("ALIBABA_CLOUD_ACCESS_KEY_ID"));
		//AccessKey Secret,阿里云身份驗證密鑰。
    factoryInfo.setFactoryProperty(ONSFactoryProperty::SecretKey, getenv("ALIBABA_CLOUD_ACCESS_KEY_SECRET"));


    //create producer;
    Producer *pProducer = ONSFactory::getInstance()->createProducer(factoryInfo);

    //在發送消息前,必須調用start方法來啟動Producer,只需調用一次即可。
    pProducer->start();

    Message msg(
            //普通消息所屬的Topic,切勿使用普通消息的Topic來收發其他類型的消息。
            factoryInfo.getPublishTopics(),
            //Message Tag,可理解為Gmail中的標簽,對消息進行再歸類,方便Consumer指定過濾條件在消息隊列RocketMQ版的服務器過濾。       
            "TagA",
            //Message Body,不能為空,消息隊列RocketMQ版不做任何干預,需要Producer與Consumer協商好一致的序列化和反序列化方式。
            factoryInfo.getMessageContent()
    );

    // 設置代表消息的業務關鍵屬性,請盡可能全局唯一。
    // 以方便您在無法正常收到消息情況下,可通過消息隊列RocketMQ版控制臺查詢消息并補發。
    // 注意:不設置也不會影響消息正常收發。
    msg.setKey("ORDERID_100");

    //發送消息,只要不拋出異常,就代表發送成功。     
    try
    {
        SendResultONS sendResult = pProducer->send(msg);
    }
    catch(ONSClientException & e)
    {
        //自定義處理exception的細節。
    }
    // 在應用退出前,必須銷毀Producer對象,否則會導致內存泄露等問題。
    pProducer->shutdown();

    return 0;
}

訂閱普通消息

訂閱普通消息的說明和示例代碼,請參見訂閱消息