.netcore 分布式事务CAP2.6之控制台使用

上一编.netcore 分布式事务CAP2.6 快速入门 讲了cap2.6的快速入门,这次我们来讲讲在控制台中如何使用cap2.6。因为cap2.6的内存模式目前已经可以使用了,相关组件已经更新,所以这次我们以简单的内存模式为例。

1:创建项目

创建一个名叫CAPConsoleDemo的 “控制台应用(.NET Core)” 程序,.netcore版本要求在2.2或以上。

2:添加相关引用

在nuget中添加 DotNetCore.CAP  DotNetCore.CAP.InMemoryStorage  Savorboard.CAP.InMemoryMessageQueue  Microsoft.Extensions.Hosting 等组件的引用。 

 640?wx_fmt=png

3:构建常规Host主机

常规host主机是.net core 2.1中引入的,本质是移除了web功能的webhost,以前webhost的所有依赖注入,生命周期管理,日志管理等都可以在控制台程序中使用。以后webhost都会是基于常规host来实现的。

实现方式也很简单,只要将Programe.cs中改成下面这样就好了

 

640?wx_fmt=png

4:添加推送程序

  4.1:添加一个继承自IHostedService的Publish类,并在里面创建一个定时器,每秒推送一次事件。

640?wx_fmt=png


4.2:在Programe.CreateHostBuilder方法中添加推送服务 services.AddHostedService<Publish>();  

640?wx_fmt=png

4.3:f5运行程序,此时是已经可以正常推送消息了。

640?wx_fmt=png

5:添加监听服务

5.1:创建一个承继自ICapSubscribe接口的类Events,并监听Order.Created事件,代码如下: 

 
 

640?wx_fmt=png


5.2:在在Programe.CreateHostBuilder方法中添加监听服务 services.AddSingleton<ICapSubscribe, Events>(); 

640?wx_fmt=png

6:大功造成

F5运行程序,可以看到程序在一边推送一边接收。

640?wx_fmt=png

7:同一事件,多个服务监听处理。

默认情况下,一个事件只会被一个监听者处理,即使我们创建了多个服务来监听同一事件,也只会有一个服务收到此事件,其它服务是收不到的。那么怎么让多个服务同时处理同一事件呢?答案是使用分组,在添加监听器时使用不同的分组名称。

7.1:我们将Events类中的代码,稍微改动一下,使用两个都监听Order.Created事件的方法,但命名成不同的分组。

 
 

640?wx_fmt=png


7.2:F5运行,如下图所示,一次推送事件,两个监听服务都处理了此事件。

640?wx_fmt=png

示例代码下载https://pan.baidu.com/s/1X2uCvcLjQ9AiqxMD3CtTcA

 
 

原文链接:https://www.cnblogs.com/sunyuliang/p/11447565.html


.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com 

640?wx_fmt=jpeg

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值