tnblog
首页
视频
资源
登录

.net core 集成事件,分布式事务解决方案

9317人阅读 2020/10/29 13:54 总访问:3659162 评论:1 收藏:0 手机
分类: .net后台框架

.netcore

.net core 集成事件,分布式事务解决方案


简单介绍

CAP是基于.Net标准的库,该库是处理分布式事务的解决方案,具有EventBus功能,它轻巧,易于使用且高效。
在构建SOA或MicroService系统的过程中,我们通常需要使用事件来集成每个服务。在此过程中,简单使用消息队列并不能保证可靠性。CAP采用与当前数据库集成的本地消息表程序来解决在分布式系统相互调用的过程中可能发生的异常。它可以确保事件消息在任何情况下都不会丢失。
您也可以将CAP用作EventBus。CAP提供了一种更简单的方法来实现事件发布和订阅。在订阅和发送过程中,您不需要继承或实现任何接口。

安装与代码构建

相关资源包

  1. DotNetCore.CAP
  2. DotNetCore.CAP.RabbitMQ
  3. DotNetCore.CAP.SqlServer
  4. DotNetCore.CAP.Dashboard

定义相关实体

OrderPaymentSucceededIntegrationEvent.cs
  1. public class OrderPaymentSucceededIntegrationEvent
  2. {
  3. public OrderPaymentSucceededIntegrationEvent(long orderId) => OrderId = orderId;
  4. public long OrderId { get; }
  5. }

定义相关服务

OrderPaymentSucceededIntegrationEvent.cs
  1. public interface ISubscriberService
  2. {
  3. void OrderPaymentSucceeded(OrderPaymentSucceededIntegrationEvent @event);
  4. }
  5. public class SubscriberService : ISubscriberService, ICapSubscribe
  6. {
  7. [CapSubscribe("OrderPaymentSucceeded")]
  8. public void OrderPaymentSucceeded(OrderPaymentSucceededIntegrationEvent @event)
  9. {
  10. //处理队列中消息的地方
  11. }
  12. }

注入服务

Startup.cs
  1. services.AddTransient<ISubscriberService, SubscriberService>();
  2. services.AddDbContext<TestDBContext>(option => option.UseSqlServer(Configuration.GetValue<string>("MSSQLServer")));
  3. services.AddCap((option) =>
  4. {
  5. option.UseEntityFramework<TestDBContext>();
  6. option.UseRabbitMQ(options =>
  7. {
  8. Configuration.GetSection("RabbitMQ").Bind(options);
  9. });
  10. option.UseDashboard(options =>
  11. {
  12. options.AppPath = "applicationpath";
  13. options.PathMatch = "/cap";
  14. });
  15. });

在分布式环境中,内置的仪表板将Consul集成为节点发现,在实现网关代理功能的同时,还可以轻松查看节点或其他节点数据,就像您正在访问本地资源一样。简单点就像上面那样。

  1. services.AddCap(x =>
  2. {
  3. //...
  4. // Register Dashboard
  5. x.UseDashboard();
  6. // Register to Consul
  7. x.UseDiscovery(d =>
  8. {
  9. d.DiscoveryServerHostName = "localhost";
  10. d.DiscoveryServerPort = 8500;
  11. d.CurrentNodeHostName = "localhost";
  12. d.CurrentNodePort = 5800;
  13. d.NodeId = 1;
  14. d.NodeName = "CAP No.1 Node";
  15. });
  16. });

查看配置

appsettings.json
  1. {
  2. "MSSQLServer": "Server=xx;Database=TestDB;User ID=xx;Password=xxxxxx;",
  3. "RabbitMQ": {
  4. "HostName": "xx.xx.xx.xx",
  5. "UserName": "guest",
  6. "Password": "guest",
  7. "VirtualHost": "/",
  8. "ExchangeName": "geek_queue"
  9. },
  10. }

在控制器中定义消费接口

WeatherForecastController.cs
  1. [ApiController]
  2. [Route("[controller]")]
  3. public class WeatherForecastController : ControllerBase
  4. {
  5. private readonly ICapPublisher _capBus;
  6. public WeatherForecastController(ICapPublisher capPublisher)
  7. {
  8. _capBus = capPublisher;
  9. }
  10. [HttpGet]
  11. public async Task<string> Get()
  12. {
  13. _capBus.Publish("OrderPaymentSucceeded",new OrderPaymentSucceededIntegrationEvent(10L));
  14. return await Task.FromResult<string>("ok");
  15. }
  16. }

运行测试

添加消息

消费

查看 Dashboard (http://localhost:5000/cap)

查看订阅列表


欢迎加群讨论技术,1群:677373950(满了,可以加,但通过不了),2群:656732739

评价

Session

2022/2/9 16:45:24

[good]

net core 使用 EF Code First

下面这些内容很老了看这篇:https://www.tnblog.net/aojiancc2/article/details/5365 项目使用多层,把数据库访问...

.net mvc分部页,.net core分部页

.net分部页的三种方式第一种:@Html.Partial(&quot;_分部页&quot;)第二种:@{ Html.RenderPartial(&quot;分部页&quot;);}...

StackExchange.Redis操作redis(net core支持)

官方git开源地址https://github.com/StackExchange/StackExchange.Redis官方文档在docs里边都是官方的文档通过nuget命令下...

.net core 使用session

tip:net core 2.2后可以直接启用session了,不用在自己添加一次session依赖,本身就添加了使用nuget添加引用Microsoft.AspN...

通俗易懂,什么是.net?什么是.net Framework?什么是.net core?

朋友圈@蓝羽 看到一篇文章写的太详细太通俗了,搬过来细细看完,保证你对.NET有个新的认识理解原文地址:https://www.cnblo...

asp.net core2.0 依赖注入 AddTransient与AddScoped的区别

asp.net core主要提供了三种依赖注入的方式其中AddTransient与AddSingleton比较好区别AddTransient瞬时模式:每次都获取一...

.net core 使用 Kestrel

Kestrel介绍 Kestrel是一个基于libuv的跨平台web服务器 在.net core项目中就可以不一定要发布在iis下面了Kestrel体验可以使...

net core中使用cookie

net core中可以使用传统的cookie也可以使用加密的cookieNET CORE中使用传统cookie设置:HttpContext.Response.Cookies.Appe...

net core项目结构简单分析

一:wwwrootwwwroot用于存放网站的静态资源,例如css,js,图片与相关的前端插件等lib主要是第三方的插件,例如微软默认引用...

net core使用EF之DB First

一.新建一个.net core的MVC项目新建好项目后,不能像以前一样直接在新建项中添加ef了,需要用命令在添加ef的依赖二.使用Nug...

.net core使用requestresponse下载文件下载excel等

使用request获取内容net core中request没有直接的索引方法,需要点里边的Query,或者formstringbase64=Request.Form[&quot;f...

iframe自适应高度与配合net core使用

去掉iframe边框frameborder=&quot;0&quot;去掉滚动条scrolling=&quot;no&quot;iframe 自适应高度如果内容是固定的,那么就...

net core启动报错Unable to configure HTTPS endpoint. No server certificate was specified

这是因为net core2.1默认使用的https,如果使用Kestrel web服务器的话没有安装证书就会报这个错其实仔细看他的错误提示,其...

net core中使用url编码与解码操作

net core中暂时还没有以前asp.net与mvc中的server对象。获取url的编码与解码操作不能使用以前的server对象来获取。使用的是...

下载net core

官方下载地址:https://dotnet.microsoft.com/download 进来之后就可以看到最新的下载版本可以直接点击下载,也可以下载其...

net core使用依赖注入来装载EF的上下文对象

妹子情人节快乐~.net core中用了不少的依赖注入,官方文档中也推荐使用。这样使用依赖注入来管理ef对象,还是比较科学,比如...
这一世以无限游戏为使命!
排名
2
文章
657
粉丝
44
评论
93
docker中Sware集群与service
尘叶心繁 : 想学呀!我教你呀
一个bug让程序员走上法庭 索赔金额达400亿日元
叼着奶瓶逛酒吧 : 所以说做程序员也要懂点法律知识
.net core 塑形资源
剑轩 : 收藏收藏
映射AutoMapper
剑轩 : 好是好,这个对效率影响大不大哇,效率高不高
ASP.NET Core 服务注册生命周期
剑轩 : http://www.tnblog.net/aojiancc2/article/details/167
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术