阅读502 返回首页    go 人物


定时消息和延时消息__特色功能_消息队列 MQ-阿里云

本文档主要介绍 MQ 定时消息和延时消息的概念、适用场景以及使用过程中的注意事项。

概念介绍

  • 定时消息:Producer 将消息发送到 MQ 服务端,但并不期望这条消息立马投递,而是推迟到在当前时间点之后的某一个时间投递到 Consumer 进行消费,该消息即定时消息。
  • 延时消息:Producer 将消息发送到 MQ 服务端,但并不期望这条消息立马投递,而是延迟一定时间后才投递到 Consumer 进行消费,该消息即延时消息。

定时消息与延迟消息在代码配置上存在一些差异,但是最终达到的效果相同:消息在发送到 MQ 服务端后并不会立马投递,而是根据消息中的属性延迟固定时间后才投递给消费者。

适用场景

定时/延时消息适用于如下一些场景:

  • 消息生产和消费有时间窗口要求:比如在电商交易中超时未支付关闭订单的场景,在订单创建时会发送一条 MQ 延时消息,这条消息将会在30分钟以后投递给消费者,消费者收到此消息后需要判断对应的订单是否已完成支付。如支付未完成,则关闭订单,如已完成支付则忽略。
  • 通过消息触发一些定时任务,比如在某一固定时间点向用户发送提醒消息。

使用方式

定时消息、延时消息的使用在代码编写上存在略微的区别:

  • 发送定时消息需要明确指定消息发送时间点之后的某一时间点作为消息投递的时间点。
  • 发送延时消息时需要设定一个延时时间长度,消息将从当前发送时间点开始延迟固定时间之后才开始投递。

发送定时消息

  1. public class ProducerDelayTest {
  2. public static void main(String[] args) {
  3. Properties properties = new Properties();
  4. properties.put(PropertyKeyConst.ProducerId, "XXX");//您在 MQ 控制台创建的 Producer ID
  5. properties.put(PropertyKeyConst.AccessKey, "XXX");// 阿里云身份验证,在阿里云服务器管理控制台创建
  6. properties.put(PropertyKeyConst.SecretKey, "XXX");// 阿里云身份验证,在阿里云服务器管理控制台创建
  7. Producer producer = ONSFactory.createProducer(properties);
  8. // 在发送消息前,必须调用 start 方法来启动 Producer,只需调用一次即可。
  9. producer.start();
  10. Message msg = new Message( //
  11. // Message Topic
  12. "Topic",
  13. // Message Tag 可理解为 Gmail 中的标签,对消息进行再归类,方便 Consumer 指定过滤条件在 MQ 服务器过滤
  14. "tag",
  15. // Message Body 可以是任何二进制形式的数据, MQ 不做任何干预,需要 Producer 与 Consumer 协商好一致的序列化和反序列化方式
  16. "Hello MQ".getBytes());
  17. // 设置代表消息的业务关键属性,请尽可能全局唯一
  18. // 以方便您在无法正常收到消息情况下,可通过 MQ 控制台查询消息并补发。
  19. // 注意:不设置也不会影响消息正常收发
  20. msg.setKey("ORDERID_100");
  21. /**
  22. * 定时消息投递,设置投递的具体时间戳,单位毫秒例如2016-03-07 16:21:00投递
  23. */
  24. long timeStamp =new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").parse("2016-03-07 16:21:00").getTime();
  25. msg.setStartDeliverTime(timeStamp);
  26. // 发送消息,只要不抛异常就是成功
  27. SendResult sendResult = producer.send(msg);
  28. System.out.println("Message Id:" + sendResult.getMessageId());
  29. // 在应用退出前,销毁 Producer 对象
  30. // 注意:如果不销毁也没有问题
  31. producer.shutdown();
  32. }
  33. }

发送延时消息

  1. public class ProducerDelayTest {
  2. public static void main(String[] args) {
  3. Properties properties = new Properties();
  4. properties.put(PropertyKeyConst.ProducerId, "XXX");// 您在控制台创建的 Producer ID
  5. properties.put(PropertyKeyConst.AccessKey, "XXX");// AccessKey 阿里云身份验证,在阿里云服务器管理控制台创建
  6. properties.put(PropertyKeyConst.SecretKey, "XXX");// SecretKey 阿里云身份验证,在阿里云服务器管理控制台创建
  7. Producer producer = ONSFactory.createProducer(properties);
  8. // 在发送消息前,必须调用 start 方法来启动 Producer,只需调用一次即可。
  9. producer.start();
  10. Message msg = new Message( //
  11. // Message Topic
  12. "Topic",
  13. // Message Tag, 可理解为 Gmail 中的标签,对消息进行再归类,方便 Consumer 指定过滤条件在 MQ 服务器过滤
  14. "tag",
  15. // Message Body 可以是任何二进制形式的数据, MQ 不做任何干预,需要 Producer 与 Consumer 协商好一致的序列化和反序列化方式
  16. "Hello MQ".getBytes());
  17. // 设置代表消息的业务关键属性,请尽可能全局唯一。
  18. // 以方便您在无法正常收到消息情况下,可通过 MQ 控制台查询消息并补发。
  19. // 注意:不设置也不会影响消息正常收发
  20. msg.setKey("ORDERID_100");
  21. // deliver time 单位 ms,指定一个时刻,在这个时刻之后才能被消费,这个例子表示 3s 后才能被消费
  22. long delayTime = 3000;
  23. msg.setStartDeliverTime(System.currentTimeMillis() + delayTime);
  24. // 发送消息,只要不抛异常就是成功
  25. SendResult sendResult = producer.send(msg);
  26. System.out.println("Message Id:" + sendResult.getMessageId());
  27. // 在应用退出前,销毁 Producer 对象
  28. // 注意:如果不销毁也没有问题
  29. producer.shutdown();
  30. }
  31. }

注意事项

  1. 定时/延时消息 msg.setStartDeliverTime 的参数需要设置成当前时间戳之后的某个时刻(单位毫秒),如果被设置成当前时间戳之前的某个时刻,消息将立刻投递给消费者。
  2. 定时/延时消息 msg.setStartDeliverTime 的参数可设置40天内的任何时刻(单位毫秒),超过40天消息发送将失败。
  3. 消费者存在消息堆积时,定时/延时消息将不能严格按照配置的时间进行消费。

最后更新:2016-11-23 16:04:16

  上一篇:go 集群消费和广播消费__特色功能_消息队列 MQ-阿里云
  下一篇:go 发布订阅管理__控制台使用指南_消息队列 MQ-阿里云