上一编讲了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 等组件的引用。

3:构建常规Host主机

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

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

  1. using Microsoft.Extensions.DependencyInjection;
  2. using Microsoft.Extensions.Hosting;
  3. using Savorboard.CAP.InMemoryMessageQueue;
  4. using System;
  5.  
  6. namespace CAPConsoleDemo
  7. {
  8. class Program
  9. {
  10. static void Main(string[] args)
  11. {
  12. CreateHostBuilder(args).Build().Run(); //构建一个常规Host
  13. }
  14. static IHostBuilder CreateHostBuilder(string[] args)
  15. {
  16. var build = new HostBuilder();
  17. build.ConfigureServices((hostContext, services) =>
  18. {
  19. services.AddCap(option => //添加CAP框架
  20. {
  21. option.UseInMemoryStorage(); //使用内存存储
  22. option.UseInMemoryMessageQueue(); //使用内存队列
  23. option.UseDashboard(); //添加监控仪表盘
  24. });
  25. });
  26. return build;
  27. }
  28. }
  29. }

4:添加推送程序

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

  1. using DotNetCore.CAP;
  2. using Microsoft.Extensions.Hosting;
  3. using System;
  4. using System.Threading;
  5. using System.Threading.Tasks;
  6.  
  7. namespace CAPConsoleDemo
  8. {
  9. public class Publish : IHostedService
  10. {
  11. private ICapPublisher capPublish; //CAP发布程序
  12. private Timer _timer; //定时器
  13.  
  14. public Publish(ICapPublisher capPublish) //自动注入CAP程序
  15. {
  16. this.capPublish = capPublish;
  17. }
  18.  
  19. public Task StartAsync(CancellationToken cancellationToken)
  20. {
  21. _timer = new Timer(work, null, TimeSpan.Zero, TimeSpan.FromSeconds()); //每秒运行一次推送任务
  22. return Task.CompletedTask;
  23. }
  24. private void work(object state)
  25. {
  26. capPublish.Publish<string>("Order.Created", DateTime.Now.ToString()); //推送Order.Created事件
  27. Console.WriteLine("推送:" + DateTime.Now.ToString());
  28. }
  29.  
  30. public Task StopAsync(CancellationToken cancellationToken)
  31. {
  32. return Task.CompletedTask;
  33. }
  34. }
  35. }

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

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

5:添加监听服务

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

  1. using DotNetCore.CAP;
  2. using System;
  3. using System.Threading.Tasks;
  4.  
  5. namespace ConsoleApp2
  6. {
  7. public class Events : ICapSubscribe
  8. {
  9.  
  10. [CapSubscribe("Order.Created")] //监听Order.Created事件
  11. public async Task OrderCreatedEventHand(string msg)
  12. {
  13. Console.WriteLine("--接收:"+ msg);
  14. }
  15.  
  16. }
  17. }

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

6:大功造成

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

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

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

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

  1. using DotNetCore.CAP;
  2. using System;
  3. using System.Threading.Tasks;
  4.  
  5. namespace CAPConsoleDemo
  6. {
  7. public class Events : ICapSubscribe
  8. {
  9.  
  10. [CapSubscribe("Order.Created", Group = "Group1")] //监听Order.Created事件,并命名为Group1
  11. public async Task OrderCreatedEventHand(string msg)
  12. {
  13. Console.WriteLine("--Group1接收:" + msg);
  14. }
  15.  
  16. [CapSubscribe("Order.Created", Group = "Group2")] //监听Order.Created事件,并命名为Group2
  17. public async Task Group2(string msg)
  18. {
  19. Console.WriteLine("--Group2接收:" + msg);
  20. }
  21. }
  22. }

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

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

.netcore 分布式事务CAP2.6之控制台使用的更多相关文章

  1. 使用Cap解决.Netcore分布式事务

    一.什么是Cap    CAP 是一个基于 .NET Standard 的 C# 库,它是一种处理分布式事务的解决方案,同样具有 EventBus 的功能,它具有轻量级.易使用.高性能等特点. 在我们 ...

  2. 分布式事务框架.NetCore CAP总结

    来自CAP原作者yang-xiaodong的原理图: 本文撰写者:cmliu,部分内容引用自官方文档,部分内容待更新# .NetCore CAP # 1,简介 CAP 是一个遵循 .NET Stand ...

  3. EntityFramework 6.x多个上下文迁移实现分布式事务

    前言 自从项目上了.NET Core平台用上了EntityFramework Core就再没碰过EntityFramework 6.x版本,目前而言EntityFramework 6.x是用的最多,无 ...

  4. 使用“消息服务框架”(MSF)实现分布式事务的三阶段提交协议(电商创建订单的示例)

    1,示例解决方案介绍 在上一篇 <消息服务框架(MSF)应用实例之分布式事务三阶段提交协议的实现>中,我们分析了分布式事务的三阶段提交协议的原理,现在我们来看看如何使用消息服务框架(MSF ...

  5. 阿里开源分布式事务解决方案 Fescar

    微服务倡导将复杂的单体应用拆分为若干个功能简单.松耦合的服务,这样可以降低开发难度.增强扩展性.便于敏捷开发.当前被越来越多的开发者推崇,系统微服务化后,一个看似简单的功能,内部可能需要调用多个服务并 ...

  6. 分布式事务解决方案FESCAR

    项目地址:FESCAR 以下是官网的文档.简介2019年,Fescar 是 阿里巴巴 开源的 分布式事务中间件,以 高效 并且对业务 0 侵入 的方式,解决 微服务 场景下面临的分布式事务问题. 1. ...

  7. fescar分布式事务(概览)

    1. fescar分布式事务(概览) 1.1. 概述   Fescar 是 阿里巴巴 开源的 分布式事务中间件,以 高效 并且对业务0 侵入 的方式,解决 微服务 场景下面临的分布式事务问题. 1.2 ...

  8. 分布式事务解决方案以及 .Net Core 下的实现(上)

    数据一致性是构建业务系统需要考虑的重要问题 , 以往我们是依靠数据库来保证数据的一致性.但是在微服务架构以及分布式环境下实现数据一致性是一个很有挑战的的问题.最近在研究分布式事物,分布式的解决方案有很 ...

  9. 来了!阿里开源分布式事务解决方案 Fescar

    摘要: 阿里妹导读:广为人知的阿里分布式事务解决方案:GTS(Global Transaction Service),已正式推出开源版本,取名为“Fescar”,希望帮助业界解决微服务架构下的分布式事 ...

随机推荐

  1. 第一篇博客 安装open live writer

    第一篇博客安装open live writer http://openlivewriter.org/ 有的人可能会打不开,所以我准备了一个百度云的链接地址 链接:https://pan.baidu.c ...

  2. ListView 控件总结

     1.ListView类           1.常用的基本属性:         (1)FullRowSelect:设置是否行选择模式.(默认为false) 提示:只有在Details视图该属性才有 ...

  3. PHP与ECMAScript_2_数据类型

    PHP ECMAScript 数据类型 基本:String.Integer.Float.Boolean 基本:String. Number. Boolean.NULL.undefined 复合:Arr ...

  4. Linux命令(部分)

    LINUX:实现某一功能,命令执行依赖于解释器程序.       内部:属于shell部分       外部:独立于shell解释器程序.       系统结构由外到内:用户 ⇢ 外围程序 ⇢ 硬件  ...

  5. CSDN Markdown 超链接

    CSDN Markdown 的超链接总是在当前页面打开新的链接,后来发现了一种可以在新窗口打开超链接的语法,如下: <a href="https://zh.wikipedia.org/ ...

  6. 后端开发实践系列之二——领域驱动设计(DDD)编码实践

    Martin Fowler在<企业应用架构模式>一书中写道: I found this(business logic) a curious term because there are f ...

  7. Apache Flink 1.9 重大特性提前解读

    今天在 Apache Flink meetup ·北京站进行 Flink 1.9 重大新特性进行了讲解,两位讲师分别是 戴资力/杨克特,zhisheng 我也从看完了整个 1.9 特性解读的直播,预计 ...

  8. Unity经典游戏教程之:贪吃蛇

    版权声明: 本文原创发布于博客园"优梦创客"的博客空间(网址:http://www.cnblogs.com/raymondking123/)以及微信公众号"优梦创客&qu ...

  9. jdk安装及环境配置

    1.下载对应的安装包(我们公司用的是jdk 1.8) 2.选择对应版本,点击安装,在选择安装位置的时候,选择自己对应存放的位置,其他都点击下一步就行了,先安装jdk,后安装jre 3.环境变量,选择 ...

  10. Two types of people with high scores of English exams

    I believe that there are two types of people who get high scores in English exams: 1) have high inte ...