当前位置:首页 > 科技  > 软件

.NET开源的处理分布式事务的解决方案

来源: 责编: 时间:2023-11-30 09:28:04 314观看
导读前言在分布式系统中,由于各个系统服务之间的独立性和网络通信的不确定性,要确保跨系统的事务操作的最终一致性是一项重大的挑战。今天给大家推荐一个.NET开源的处理分布式事务的解决方案基于 .NET Standard 的 C# 库:CAP

前言

在分布式系统中,由于各个系统服务之间的独立性和网络通信的不确定性,要确保跨系统的事务操作的最终一致性是一项重大的挑战。今天给大家推荐一个.NET开源的处理分布式事务的解决方案基于 .NET Standard 的 C# 库:CAP。XS828资讯网——每日最新资讯28at.com

CAP项目介绍

CAP 是一个基于 .NET Standard 的 C# 库,它是一种处理分布式事务的解决方案,同样具有 EventBus 的功能,它具有轻量级、易使用、高性能等特点。CAP 是一个EventBus,同时也是一个在微服务或者SOA系统中解决分布式事务问题的一个框架。它有助于创建可扩展,可靠并且易于更改的微服务系统。XS828资讯网——每日最新资讯28at.com

什么是 EventBus?

事件总线是一种机制,它允许不同的组件彼此通信而不彼此了解。组件可以将事件发送到Eventbus,而无需知道是谁来接听或有多少其他人来接听。组件也可以侦听Eventbus上的事件,而无需知道谁发送了事件。这样,组件可以相互通信而无需相互依赖。同样,很容易替换一个组件。只要新组件了解正在发送和接收的事件,其他组件就永远不会知道。XS828资讯网——每日最新资讯28at.com

CAP架构预览

图片图片XS828资讯网——每日最新资讯28at.com

CAP支持的存储

SQL Server、MySQL、PostgreSql、MongoDB、In-Memory Storage。XS828资讯网——每日最新资讯28at.com

CAP 支持以下几种运输方式

RabbitMQ、Kafka、Azure Service Bus、Amazon SQS、NATS、In-Memory Queue、Redis Streams、Apache Pulsar。XS828资讯网——每日最新资讯28at.com

怎么选择运输器

图片图片XS828资讯网——每日最新资讯28at.com

项目源码

图片图片XS828资讯网——每日最新资讯28at.com

快速开始

安装DotNetCore.CAP Nuget包

图片图片XS828资讯网——每日最新资讯28at.com

CAP 支持主流的消息队列作为传输器:

  • 我本地安装的是DotNetCore.CAP.RabbitMQ。
//你可以按需选择下面的包进行安装:PM> Install-Package DotNetCore.CAP.KafkaPM> Install-Package DotNetCore.CAP.RabbitMQPM> Install-Package DotNetCore.CAP.AzureServiceBusPM> Install-Package DotNetCore.CAP.AmazonSQSPM> Install-Package DotNetCore.CAP.NATSPM> Install-Package DotNetCore.CAP.RedisStreamsPM> Install-Package DotNetCore.CAP.Pulsar

图片图片XS828资讯网——每日最新资讯28at.com

CAP 提供了主流数据库作为存储:

  • 我本地安装的是DotNetCore.CAP.MongoDB。
// 按需选择安装你正在使用的数据库:PM> Install-Package DotNetCore.CAP.SqlServerPM> Install-Package DotNetCore.CAP.MySqlPM> Install-Package DotNetCore.CAP.PostgreSqlPM> Install-Package DotNetCore.CAP.MongoDB

图片图片XS828资讯网——每日最新资讯28at.com

配置CAP到 Program.cs 文件中,如下:

builder.Services.AddCap(x =>            {                //如果你使用的 EF 进行数据操作,你需要添加如下配置:                //配置数据库上下文                x.UseEntityFramework<AppDbContext>();                //如果你使用的 MongoDB,你可以添加如下配置:                x.UseMongoDB("ConnectionStrings");  //注意,仅支持MongoDB 4.0+集群                //CAP RabbitMQ 配置                x.UseRabbitMQ(rab => {                    rab.HostName = "192.0.1.1";                    rab.Password = "123456";                    rab.Port = 5672;                    rab.UserName = "123456";                });            });

发布

在 Controller 中注入 ICapPublisher 然后使用 ICapPublisher 进行消息发送。XS828资讯网——每日最新资讯28at.com

public class PublishController : Controller{    private readonly ICapPublisher _capBus;    public PublishController(ICapPublisher capPublisher)    {        _capBus = capPublisher;    }        //不使用事务    [Route("~/without/transaction")]    public IActionResult WithoutTransaction()    {        _capBus.Publish("xxx.services.show.time", DateTime.Now);        // Publish delay message        _capBus.PublishDelayAsync(TimeSpan.FromSeconds(delaySeconds), "xxx.services.show.time", DateTime.Now);         return Ok();    }    //Ado.Net 中使用事务,自动提交    [Route("~/adonet/transaction")]    public IActionResult AdonetWithTransaction()    {        using (var connection = new MySqlConnection(ConnectionString))        {            using (var transaction = connection.BeginTransaction(_capBus, autoCommit: true))            {                //业务代码                _capBus.Publish("xxx.services.show.time", DateTime.Now);            }        }        return Ok();    }    //EntityFramework 中使用事务,自动提交    [Route("~/ef/transaction")]    public IActionResult EntityFrameworkWithTransaction([FromServices]AppDbContext dbContext)    {        using (var trans = dbContext.Database.BeginTransaction(_capBus, autoCommit: true))        {            //业务代码            _capBus.Publish("xxx.services.show.time", DateTime.Now);        }        return Ok();    }}

订阅

Action Method

在 Action 上添加 CapSubscribeAttribute 来订阅相关消息。XS828资讯网——每日最新资讯28at.com

public class PublishController : Controller{    [CapSubscribe("xxx.services.show.time")]    public void CheckReceivedMessage(DateTime datetime)    {        Console.WriteLine(datetime);    }}

Service Method

如果你的订阅方法没有位于 Controller 中,则你订阅的类需要继承 ICapSubscribe:XS828资讯网——每日最新资讯28at.com

namespace xxx.Service{    public interface ISubscriberService    {        void CheckReceivedMessage(DateTime datetime);    }    public class SubscriberService: ISubscriberService, ICapSubscribe    {        [CapSubscribe("xxx.services.show.time")]        public void CheckReceivedMessage(DateTime datetime)        {        }    }}

项目源码地址

更多项目实用功能和特性欢迎前往项目开源地址查看

本文链接:http://www.28at.com/showinfo-26-35288-0.html.NET开源的处理分布式事务的解决方案

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 消息队列备选架构选择,你选择哪个?

下一篇: 利用 Golang 中的 Recover 处理错误

标签:
  • 热门焦点
  • 掘力计划第 20 期:Flutter 混合开发的混乱之治

    在掘力计划系列活动第20场,《Flutter 开发实战详解》作者,掘金优秀作者,Github GSY 系列目负责人恋猫的小郭分享了Flutter 混合开发的混乱之治。Flutter 基于自研的 Skia 引擎
  • 一年经验在二线城市面试后端的经验分享

    忠告这篇文章只适合2年内工作经验、甚至没有工作经验的朋友阅读。如果你是2年以上工作经验,请果断划走,对你没啥帮助~主人公这篇文章内容来自 「升职加薪」星球星友 的投稿,坐
  • 深度探索 Elasticsearch 8.X:function_score 参数解读与实战案例分析

    在 Elasticsearch 中,function_score 可以让我们在查询的同时对搜索结果进行自定义评分。function_score 提供了一系列的参数和函数让我们可以根据需求灵活地进行设置。近期
  • 一个注解实现接口幂等,这样才优雅!

    场景码猿慢病云管理系统中其实高并发的场景不是很多,没有必要每个接口都去考虑并发高的场景,比如添加住院患者的这个接口,具体的业务代码就不贴了,业务伪代码如下:图片上述代码有
  • 雅柏威士忌多款单品价格大跌,泥煤顶流也不香了?

    来源 | 烈酒商业观察编 | 肖海林今年以来,威士忌市场开始出现了降温迹象,越来越多不断暴涨的网红威士忌也开始悄然回归市场理性。近日,LVMH集团旗下苏格兰威士忌品牌雅柏(Ardbeg
  • 共享单车的故事讲到哪了?

    来源丨海克财经与共享充电宝相差不多,共享单车已很久没有被国内热点新闻关照到了。除了一再涨价和用户直呼用不起了。近日多家媒体再发报道称,成都、天津、郑州等地多个共享单
  • 2天涨粉255万,又一赛道在抖音爆火

    来源:运营研究社作者 | 张知白编辑 | 杨佩汶设计 | 晏谈梦洁这个暑期,旅游赛道彻底火了:有的「地方」火了&mdash;&mdash;贵州村超旅游收入 1 个月超过 12 亿;有的「博主」火了&m
  • 花7万退货退款无门:谁在纵容淘宝珠宝商家造假?

    来源:极点商业作者:杨铭在淘宝购买珠宝玉石后,因为保证金不够赔付,店铺关闭,退货退款难、维权无门的比比皆是。&ldquo;提供相关产品鉴定证书,支持全国复检,可以30天无理由退换货。&
  • AI艺术欣赏体验会在上海梅赛德斯奔驰中心音乐俱乐部上演

    光影交错的镜像世界,虚实幻化的视觉奇观,虚拟偶像与真人共同主持,这些场景都出现在2019世界人工智能大会的舞台上。8月29日至31日,“AI艺术欣赏体验会”在上海
Top