许多业务流程都要求将事件安排在未来的某个日期。 例如,在与客户进行初次销售联系之后,我们可能希望在将来某个时间安排后续电话。 EasyNetQ可以通过其未来发布功能帮助您实现此功能。 例如,我们在这里使用FuturePublish扩展方法来安排未来一个月的后续销售电话。 请注意,FuturePublish使用UTC时间。

var followUpCallMessage = new FollowUpCallMessage( .. );

bus.FuturePublish(DateTime.UtcNow.AddMonths(), followUpCallMessage);

从现在开始三个月后,EasyNetQ将发布该消息,并且FollowUpCallMessage的任何订户都将收到原始消息的副本。

FuturePublish要求EasyNetQ.Scheduler服务正在运行。

1,它是如何工作的?

当您调用bus.FuturePublish(publishDate,message)时,EasyNetQ将您的消息包装在系统消息“ScheduleMe”中并将其发布到RabbitMQ。 调度程序服务订阅此消息。 当它收到一个ScheduleMe消息时,它将其存储在其本地数据库中。 调度程序服务在其数据库中查找调度日期到期的消息,当它发现任何到期的消息时,它将原始消息从ScheduleMe消息解开并发布到总线。

2,安装调度程序服务

  1. 在SQL Server中,创建一个新的数据库EasyNetQ.Scheduler

  2. 获取EasyNetQ的源代码

    git clone git@github.com:mikehadlow/EasyNetQ.git

  3. 在Visual Studio中打开EasyNetQ.2012解决方案。 在文件夹DatabaseScripts - > EasyNetQ.Scheduler中,您可以找到许多SQL脚本。 在EasyNetQ.Scheduler数据库中打开并运行它们。 您需要首先运行CreateWorkTables.sql,其他则是存储过程脚本,并且可以按任意顺序运行。

  4. 构建解决方案。

  5. 找到\ Source \ EasyNetQ.Scheduler \ bin \ Debug并将内容复制到您选择的部署文件夹。

  6. 在文本编辑器中打开EasyNetQ.Scheduler.exe.config,并将“rabbit”和“scheduleDb”连接字符串分别指向您的RabbitMQ代理和SQL Server实例。

  7. 打开控制台窗口并将路径更改为部署EasyNetQ.Scheduler的文件夹。

  8. 运行以下命令将EasyNetQ.Scheduler安装为Windows服务:

    EasyNetQ.Scheduler.exe install

    Configuration Result: [Success] Name EasyNetQ.Scheduler [Success] ServiceName EasyNetQ.Scheduler Topshelf v3.1.106.0, .NET Framework v4.0.30319.18051

    Running a transacted installation.

    Beginning the Install phase of the installation. Installing EasyNetQ.Scheduler service Installing service EasyNetQ.Scheduler... Service EasyNetQ.Scheduler has been successfully installed. Creating EventLog source EasyNetQ.Scheduler in log Application...

    The Install phase completed successfully, and the Commit phase is beginning.

    The Commit phase completed successfully.

    The transacted install has completed.

3,支持延迟消息插件

RabbitMQ延迟消息插件将新的交换类型添加到RabbitMQ,从而允许延迟消息传递。

EasyNetQ通过定义新的调度程序类型来提供对使用该交换的支持:DelayedExchangeScheduler。

这允许您像以前一样使用相同的Future Publish接口,但取消未来的消息除外。 由于延迟消息插件不支持消息取消,因此无论何时调用FuturePublish指定cancelKey,或者调用CancelFuturePublish时,调度程序都会抛出NotImplementedException异常。

以下示例显示了如何发布将在三个月后交付的消息:

bus = RabbitHutch.CreateBus("host=localhost", x => x.Register<IScheduler, DelayedExchangeScheduler>());

var followUpCallMessage = new FollowUpCallMessage( .. );

bus.FuturePublish(DateTime.UtcNow.AddMonths(), followUpCallMessage);

第一行指示EasyNetQ使用支持延迟消息交换的新调度程序。 接下来,该消息将创建并发布,交付时间设置为三个月。 请注意,FuturePublish使用UTC时间。

DelayedExchangeScheduler需要安装Delayed Message Plugin。

①插件安装

延迟消息插件可以在社区插件页面上找到。 为您的RabbitMQ安装下载相应的.ez文件,将其复制到RabbitMQ的插件文件夹中,然后通过运行以下命令启用它:

rabbitmq-plugins enable rabbitmq_delayed_message_exchange

该插件需要RabbitMQ 3.4或更新版本。

②怎么运行的

当您调用bus.FuturePublish(...)时,EasyNetQ会自动创建新的x延迟消息交换以及正常交换并将它们绑定在一起。 该消息在延迟交换中发布,该交换将存储该消息,直到交付它为止。 此时,该消息被路由到正常交换并从那里到绑定队列。

当您调用Publish(...)方法时,消息将发布到正常交换,从而防止与使用新的x延迟消息交换相关的任何性能下降。

延迟交换持续使用Mnesia的消息。 这可以防止在服务器停机时丢失信息。 一旦服务器恢复,所有符合条件的消息都将按计划交付。

11,EasyNetQ-调度事件与定时发布的更多相关文章

  1. cocos2d调度器(定时执行某函数)

    调度器(scheduler) 继承关系 原理介绍 Cocos2d-x调度器为游戏提供定时事件和定时调用服务.所有Node对象都知道如何调度和取消调度事件,使用调度器有几个好处: 每当Node不再可见或 ...

  2. Tinkphp定时发布文章的教程

    第一步:在文章表中加一个字段,用来保存定时发布的时间 假定我把这个字段设为 push_time 默认为 0 第二步:写一个方法来检查文章列表,把文章列表到时间的文章改为发布状态 //定时发布文章 pu ...

  3. 定时发布任务,在global.asax中获取文件的物理路径的方法

    如果要把一个相对路径或者虚拟路径映射道服务器的物理路径,通常会使用Server.MapPath()函数,比如将根目录下的html目录映射为物理路径:Server.MapPath("html& ...

  4. CC2540 OSAL 学习其中原理,以及 给任务 添加 一个事件(定时发送串口消息)

    参考学习大神博客: http://blog.csdn.net/feilusia/article/details/51083953 : http://blog.csdn.net/xiaoleiacmer ...

  5. wordpress自动批量定时发布插件 DX-auto-publish

    DX-auto-publish是一款wordpress自动发布插件,方便实用. 该wordpress插件的主要功能如下: 1.能够自动批量定时发布wordpress站点的草稿文章,无需每篇文章都手动设 ...

  6. C#中的事件-订阅与发布

    我们用一个简单的例子,来说明一下这种消息传递的机制. 有一家三口,妈妈负责做饭,爸爸和孩子负责吃...将这三个人,想象成三个类. 妈妈有一个方法,叫做“做饭”.有一个事件,叫做“开饭”.做完饭后,调用 ...

  7. 【JavaScript】让事件支持先发布后订阅

    之前写过一个的事件管理器,就是普通的先订阅后发布模式.但实际场景中我们需要做到后订阅的也能收到发布的消息.比如我们关注微信公众号,还是能看到历史消息的.类似于qq离线消息,我先发给你,你登录了就能收到 ...

  8. 使用call、apply和bind解决js中烦人的this,事件绑定时的this和传参问题

    1.什么是this 在JavaScript中this可以是全局对象.当前对象或者任意对象,这完全取决于函数的调用方式,this 绑定的对象即函数执行的上下文环境(context). 为了帮助理解,让我 ...

  9. C# 事件 订阅与发布

    两种方式: 一: //服务器 public class Server { //服务器发布的事件 public event Action<string> MyEvent; public vo ...

随机推荐

  1. java 两个list 交集 并集 差集 去重复并集

    前提需要明白List是引用类型,引用类型采用引用传递. 我们经常会遇到一些需求求集合的交集.差集.并集.例如下面两个集合: List<String> list1 = new ArrayLi ...

  2. SpringBoot几个重要的事件回调、监听机制

    (1).需要配置在META-INF/Spring.factories 1.ApplicationContextInitializer // // Source code recreated from ...

  3. MongoDB的基本概念

    MongoDB的基本概念 库 db就是数据库 文档就是数据表的行 集合就是数据表,这个没有模式,啥叫没有模式呢,就是没有列的定义,随便什么属性都行,这点就比关系行数据库牛逼10000000倍,逆天了.

  4. 嵌入式系统C编程之错误处理

    前言 本文主要总结嵌入式系统C语言编程中,主要的错误处理方式.文中涉及的代码运行环境如下: 一  错误概念 1.1 错误分类 从严重性而言,程序错误可分为致命性和非致命性两类.对于致命性错误,无法执行 ...

  5. linux统计某个特定文件名的大小总和【原创】

    [hch@EAISRVBJ2 log]$find ./ -name "test_chs_00*"|xargs du -ck|grep total|awk 'BEGIN{sum=0} ...

  6. oracle分区分表

    (1) 表空间及分区表的概念表空间: 是一个或多个数据文件的集合,所有的数据对象都存放在指定的表空间中,但主要存放的是表, 所以称作表空间.分区表:        当表中的数据量不断增大,查询数据的速 ...

  7. 单个 LINQ to Entities 查询中的两个结构上不兼容的初始化过程中出现类型“XXXX”

    最近在做一个报表的时候,用EF使用了Contact方法,但是程式运行一直出错.最近终于找到原因了,写下来提醒下自己.好了,进入正题: 现在我举个栗子,目前数据库中有ParentStudent表和Sub ...

  8. python操作haproxy.cfg文件

    需求 1.查 输入:www.oldboy.org 获取当前backend下的所有记录 2.新建 输入: arg = { 'bakend': 'www.oldboy.org', 'record':{ ' ...

  9. Ex 6_4 判断序列是否由合法单词组成..._第六次作业

    设字符串为s,字符串中字符的个数为n,vi[i]表示前i+1个字符是否能组成有效的单词vi[i]=true表示能组成有效的单词,vi[i]=false表示不能组成有效的单词,在每个字符串前加一个空格, ...

  10. php获取POST数据的三种方法

    方法一,$_POST $_POST或$_REQUEST存放的是PHP以key=>value的形式格式化以后的数据. $_POST方式是通过 HTTP POST 方法传递的变量组成的数组,是自动全 ...