「跨数据库、微服务」 FreeSql 分布式事务 TCC/Saga 编排重要性

本文介绍了FreeSql Cloud如何支持跨数据库访问和分布式事务,特别是TCC和Saga模式。通过示例展示了在库存不足的情况下,如何处理事务的回滚和重试。同时探讨了在微服务场景中,事务单元如何调用远程服务并实现服务编排,以及在遇到问题时如何利用消息队列和条件链路进行处理。
摘要由CSDN通过智能技术生成

前言

FreeSql 支持
MySql/SqlServer/PostgreSQL/Oracle/Sqlite/Firebird/达梦/Gbase/神通/人大金仓/翰高/Clickhouse/MsAccess Ado.net 数据库,以及 Odbc 的专门实现包。

FreeSql.Cloud 为 FreeSql 提供跨数据库访问,分布式事务TCC、SAGA解决方案,支持 .NET Core 2.1+, .NET Framework 4.0+.

本文主要讲解从跨数据库访问,到分布式事务落地,再升级到微服务服务编排探讨。写下本文更多的成份是带有疑问号,希望有微服务落地经验的朋友指教一下。

TCC 事务特点:

  • Try 用于资源冻结/预扣;
  • Try 全部环节通过,代表业务一定能完成,进入 Confirm 环节;
  • Try 任何环节失败,代表业务失败,进入 Cancel 环节;
  • Confirm 失败会进行重试N次,直到交付成功,或者人工干预;
  • Cancel 失败会进行重试N次,直到取消成功,或者人工干预;

SAGA 事务特点:

  • Commit 用于业务提交;
  • Commit 全部环节通过,代表业务交付成功;
  • Commit 任何环节失败,代表业务失败,进入 Cancel 环节;
  • Cancel 失败会进行重试N次,直到取消成功,或者人工干预;

由于 TCC/Saga 两种流程有相似之处,因此本文主要以 Saga 为例讲解应用代码。本文讲解的落地场景如下:

第一步:去 数据库db1 扣除 user.Point - 10
第二步:去 数据库db2 扣除 goods.Stock - 1
第三步:去 数据库db3 创建订单

第二步库存不足时,整个流程怎么执行?


⚡ 快速开始

dotnet add package FreeSql.Cloud

or

Install-Package FreeSql.Cloud

public enum DbEnum { db1, db2, db3 }var fsql = new FreeSqlCloud<DbEnum>("app001"); //提示:泛型可以传入 stringfsql.DistributeTrace = log => Console.WriteLine(log.Split('\n')[0].Trim());fsql.Register(DbEnum.db1, () => new FreeSqlBuilder()    .UseConnectionString(DataType.SqlServer, @"Data Source=...")    .Build());fsql.Register(DbEnum.db2, () => new FreeSqlBuilder()    .UseConnectionString(DataType.MySql, @"Data Source=...")    .Build());fsql.Register(DbEnum.db3, () => new FreeSqlBuilder()    .UseConnectionString
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值