开发者社区> 问答> 正文

.NET SDK 发送定时消息如何实现?



MQ 发送定时消息


目前支持的域包括公网、华东1、华北2、华东2、华南1。
定时消息可以做到在指定时间之后才可被消费者消费,用于解决一些消息生产和消费有时间窗口要求的场景,或者通过消息触发定时任务的场景,类似于延迟队列。代码示例如下。

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Runtime.InteropServices;
  6. using ons;
  7. namespace ons
  8. {
  9.     class onscsharp
  10.     {
  11.         static void Main(string[] args)
  12.         {
  13.             //producer创建和正常工作的参数,必须输入
  14.             ONSFactoryProperty factoryInfo = new ONSFactoryProperty();
  15.             factoryInfo.setFactoryProperty(factoryInfo.ProducerId, "XXX ");//您在MQ控制台申请的Producer ID
  16.             factoryInfo.setFactoryProperty(factoryInfo.PublishTopics, "XXX");//您在MQ控制台申请的Topic
  17.             factoryInfo.setFactoryProperty(factoryInfo.MsgContent, "XXX");//消息内容
  18.             factoryInfo.setFactoryProperty(factoryInfo.AccessKey, "XXX");//AccessKey 阿里云身份验证,在阿里云服务器管理控制台创建
  19.             factoryInfo.setFactoryProperty(factoryInfo.SecretKey,"XXX");//SecretKey 阿里云身份验证,在阿里云服务器管理控制台创建
  20.             //创建producer
  21.             ONSFactory onsfactory = new ONSFactory();
  22.             Producer pProducer = onsfactory.getInstance().createProducer(factoryInfo);
  23.             //在发送消息前,必须调用start方法来启动Producer,只需调用一次即可
  24.             pProducer.start();
  25.             Message msg = new Message(
  26.                 //Message Topic
  27.                 factoryInfo.getPublishTopics(),
  28.                 //Message Tag
  29.                 "TagA",
  30.                 //Message Body
  31.                 factoryInfo.getMessageContent()
  32.             );
  33.             // 设置代表消息的业务关键属性,请尽可能全局唯一。
  34.             // 以方便您在无法正常收到消息情况下,可通过MQ Console查询消息并补发。
  35.             // 注意:不设置也不会影响消息正常收发
  36.             msg.setKey("ORDERID_100");
  37.             // deliver time 单位 ms,指定一个时刻,在这个时刻之后才能被消费,这个例子表示3s后才能被消费
  38.             long deliverTime = 获取系统当前时间(ms) + 3000;
  39.             msg.setStartDeliverTime(deliverTime);
  40.             //发送消息,只要不抛出异常,就代表发送成功
  41.             try
  42.             {
  43.                 SendResultONS sendResult = pProducer.send(msg);
  44.             }
  45.             catch(ONSClientException e)
  46.             {
  47.                 //发送失败处理
  48.             }
  49.             // 在应用退出前,必须销毁Producer对象,否则会导致内存泄露等问题
  50.             pProducer.shutdown();
  51.         }
  52.     }
  53. }

展开
收起
猫饭先生 2017-10-27 10:06:37 1733 0
0 条回答
写回答
取消 提交回答
问答排行榜
最热
最新

相关电子书

更多
从 SDK 到编解码:视频直播架构解析 立即下载
跨平台的云服务SDK需要什么 立即下载
一个跨平台的云服务SDK需要什么 立即下载