.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 等组件的引用。
3:构建常规Host主机
常规host主机是.net core 2.1中引入的,本质是移除了web功能的webhost,以前webhost的所有依赖注入,生命周期管理,日志管理等都可以在控制台程序中使用。以后webhost都会是基于常规host来实现的。
实现方式也很简单,只要将Programe.cs中改成下面这样就好了
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using Savorboard.CAP.InMemoryMessageQueue;
using System; namespace CAPConsoleDemo
{
class Program
{
static void Main(string[] args)
{
CreateHostBuilder(args).Build().Run(); //构建一个常规Host
}
static IHostBuilder CreateHostBuilder(string[] args)
{
var build = new HostBuilder();
build.ConfigureServices((hostContext, services) =>
{
services.AddCap(option => //添加CAP框架
{
option.UseInMemoryStorage(); //使用内存存储
option.UseInMemoryMessageQueue(); //使用内存队列
option.UseDashboard(); //添加监控仪表盘
});
});
return build;
}
}
}
4:添加推送程序
4.1: 添加一个继承自IHostedService的Publish类,并在里面创建一个定时器,每秒推送一次事件。
using DotNetCore.CAP;
using Microsoft.Extensions.Hosting;
using System;
using System.Threading;
using System.Threading.Tasks; namespace CAPConsoleDemo
{
public class Publish : IHostedService
{
private ICapPublisher capPublish; //CAP发布程序
private Timer _timer; //定时器 public Publish(ICapPublisher capPublish) //自动注入CAP程序
{
this.capPublish = capPublish;
} public Task StartAsync(CancellationToken cancellationToken)
{
_timer = new Timer(work, null, TimeSpan.Zero, TimeSpan.FromSeconds()); //每秒运行一次推送任务
return Task.CompletedTask;
}
private void work(object state)
{
capPublish.Publish<string>("Order.Created", DateTime.Now.ToString()); //推送Order.Created事件
Console.WriteLine("推送:" + DateTime.Now.ToString());
} public Task StopAsync(CancellationToken cancellationToken)
{
return Task.CompletedTask;
}
}
}
4.2:在Programe.CreateHostBuilder方法中添加推送服务 services.AddHostedService<Publish>();
4.3:f5运行程序,此时是已经可以正常推送消息了。
5:添加监听服务
5.1:创建一个承继自ICapSubscribe接口的类Events,并监听Order.Created事件,代码如下:
using DotNetCore.CAP;
using System;
using System.Threading.Tasks; namespace ConsoleApp2
{
public class Events : ICapSubscribe
{ [CapSubscribe("Order.Created")] //监听Order.Created事件
public async Task OrderCreatedEventHand(string msg)
{
Console.WriteLine("--接收:"+ msg);
} }
}
5.2: 在在Programe.CreateHostBuilder方法中添加监听服务 services.AddSingleton<ICapSubscribe, Events>();
6:大功造成
F5运行程序,可以看到程序在一边推送一边接收。
7:同一事件,多个服务监听处理。
默认情况下,一个事件只会被一个监听者处理,即使我们创建了多个服务来监听同一事件,也只会有一个服务收到此事件,其它服务是收不到的。那么怎么让多个服务同时处理同一事件呢?答案是使用分组,在添加监听器时使用不同的分组名称。
7.1:我们将Events类中的代码,稍微改动一下,使用两个都监听Order.Created事件的方法,但命名成不同的分组。
using DotNetCore.CAP;
using System;
using System.Threading.Tasks; namespace CAPConsoleDemo
{
public class Events : ICapSubscribe
{ [CapSubscribe("Order.Created", Group = "Group1")] //监听Order.Created事件,并命名为Group1
public async Task OrderCreatedEventHand(string msg)
{
Console.WriteLine("--Group1接收:" + msg);
} [CapSubscribe("Order.Created", Group = "Group2")] //监听Order.Created事件,并命名为Group2
public async Task Group2(string msg)
{
Console.WriteLine("--Group2接收:" + msg);
}
}
}
7.2:F5运行,如下图所示,一次推送事件,两个监听服务都处理了此事件。
示例代码下载:https://pan.baidu.com/s/1X2uCvcLjQ9AiqxMD3CtTcA
.netcore 分布式事务CAP2.6之控制台使用的更多相关文章
- 使用Cap解决.Netcore分布式事务
一.什么是Cap CAP 是一个基于 .NET Standard 的 C# 库,它是一种处理分布式事务的解决方案,同样具有 EventBus 的功能,它具有轻量级.易使用.高性能等特点. 在我们 ...
- 分布式事务框架.NetCore CAP总结
来自CAP原作者yang-xiaodong的原理图: 本文撰写者:cmliu,部分内容引用自官方文档,部分内容待更新# .NetCore CAP # 1,简介 CAP 是一个遵循 .NET Stand ...
- EntityFramework 6.x多个上下文迁移实现分布式事务
前言 自从项目上了.NET Core平台用上了EntityFramework Core就再没碰过EntityFramework 6.x版本,目前而言EntityFramework 6.x是用的最多,无 ...
- 使用“消息服务框架”(MSF)实现分布式事务的三阶段提交协议(电商创建订单的示例)
1,示例解决方案介绍 在上一篇 <消息服务框架(MSF)应用实例之分布式事务三阶段提交协议的实现>中,我们分析了分布式事务的三阶段提交协议的原理,现在我们来看看如何使用消息服务框架(MSF ...
- 阿里开源分布式事务解决方案 Fescar
微服务倡导将复杂的单体应用拆分为若干个功能简单.松耦合的服务,这样可以降低开发难度.增强扩展性.便于敏捷开发.当前被越来越多的开发者推崇,系统微服务化后,一个看似简单的功能,内部可能需要调用多个服务并 ...
- 分布式事务解决方案FESCAR
项目地址:FESCAR 以下是官网的文档.简介2019年,Fescar 是 阿里巴巴 开源的 分布式事务中间件,以 高效 并且对业务 0 侵入 的方式,解决 微服务 场景下面临的分布式事务问题. 1. ...
- fescar分布式事务(概览)
1. fescar分布式事务(概览) 1.1. 概述 Fescar 是 阿里巴巴 开源的 分布式事务中间件,以 高效 并且对业务0 侵入 的方式,解决 微服务 场景下面临的分布式事务问题. 1.2 ...
- 分布式事务解决方案以及 .Net Core 下的实现(上)
数据一致性是构建业务系统需要考虑的重要问题 , 以往我们是依靠数据库来保证数据的一致性.但是在微服务架构以及分布式环境下实现数据一致性是一个很有挑战的的问题.最近在研究分布式事物,分布式的解决方案有很 ...
- 来了!阿里开源分布式事务解决方案 Fescar
摘要: 阿里妹导读:广为人知的阿里分布式事务解决方案:GTS(Global Transaction Service),已正式推出开源版本,取名为“Fescar”,希望帮助业界解决微服务架构下的分布式事 ...
随机推荐
- Spring方法级别数据校验:@Validated + MethodValidationPostProcessor
每篇一句 在<深度工作>中作者提出这么一个公式:高质量产出=时间*专注度.所以高质量的产出不是靠时间熬出来的,而是效率为王 相关阅读 [小家Java]深入了解数据校验:Java Bean ...
- shiro 和 spring boot 的集成
1 添加依赖 使用 shiro-spring-boot-web-starter 在 spring boot 中集成 shiro 只需要再添加一个依赖 <dependency> <gr ...
- vue更改了数据但是视图却没有更新
今日总结:让钩子函数背锅的一上午,跪求原谅 需求:页面刷新时,保留当前页面的选中状态 解决思路:在data里设置一下初始值,保证首次进入有默认选中状态,其次再操作时,把选中的状态存sessionSto ...
- [转]jQuery不同版本区别
原文转载自csdn:http://blog.csdn.net/u010167032/article/details/23666145 了解不同版本之间的差异,与助于选择适合自己项目的版本. ⒈4重要新 ...
- BrowserSync,自动刷新,解放F5,去掉更新提示
BrowserSync虽然这个技术不算新,但是依然有用.略微介绍下 没有安装node,先安装node,这里不再做介绍 安装 npm install -g browser-sync 全局安装,方便在任 ...
- CodeForces 372 A. Counting Kangaroos is Fun
题意,有n只袋鼠,没每只袋鼠有个袋子,大小为si,一个袋鼠可以进入另外一个袋鼠的袋子里面,当且仅当另一个袋鼠的袋子是他的二倍或二倍一上,然后中国袋鼠就是不可见的,不能出现多个袋鼠嵌套的情况.让你求最少 ...
- 疯子的算法总结(三) STL Ⅱ迭代器(iterator) + 容器
一.迭代器(Iterator) 背景:指针可以用来遍历存储空间连续的数据结构,但是对于存储空间费连续的,就需要寻找一个行为类似指针的类,来对非数组的数据结构进行遍历. 定义:迭代器是一种检查容器内元素 ...
- 把Jar包加入windows系统服务
之前在服务器上不一个Java服务时候,总是开着一堆黑框框,非常不雅,重点是极其容易误关,所以把可执行Jar文件加入Windows系统服务,看起来是个非常不错的选择!(实际上也确实是非常不错的选择) ! ...
- ibatis 核心原理解析
最近查找一个生产问题的原因,需要深入研究 ibatis 框架的源码.虽然最后证明问题的原因与 ibatis 无关,但是这个过程加深了对 ibatis 框架原理的理解. 这篇文章主要就来讲讲 ibati ...
- HTML/CSS:block,inline和inline-block概念和区别
总体概念 block和inline这两个概念是简略的说法,完整确切的说应该是 block-level elements (块级元素) 和 inline elements (内联元素).block元素通 ...