苍穹最终一致性使用

news2024/11/27 18:34:21

适用场景

        最终一致模式可以保证跨数据库或跨节点更新时的数据一致。它会以1个更新操作为基准,注册多个其它更新操作,最终保证所有更新都成功,实现分布式事务的弱一致性。可以适用一个更新适用多个场景(跨云、跨库、跨系统)


工作原理

1、在第一次调用register注册最终一致服务的时候,会开启一个新的分布式事务,创建全局唯一xid
2、所有通过register注册的信息暂时不会执行,而是先记录到本地数据库的表中
t_dtx_local_tx_log
3、如果一切顺利,本地事务成功提交,会自动触发提交分布式事务到事务协调器
4、事务协调器收到提交后,会根据register的调用顺序逐个执行最终一致服务,直到全部完成
如果本地事务回滚了,会怎么处理?

回滚原理

当本地事务事务被回滚时,由于register的信息没有真正执行,所以相当于什么都没做,数据是一
致。同时,如果已经开启是分布式事务,则会通知协调器回滚。
如果在执行过程中,任何一个环节出现问题,包括宕机、程序ug、网络异常、数据库访问超时等
情况,KDTX是怎么保证数据最终还是一致的?可以阅读事务补偿部分。
使用最终一致模式之前,需要在业务数据库中创建本地事务表 

使用方法(代码部分)

1、创建最终一致服务

要使用最终一致模式,首先是创建最终一致服务(EC Service)。根据需要,可以创建1个或多个
服务,具体做法是:新建一个类继承kd.bos.kdtx.sdk.api.EventualConsistencyService,覆盖
execute方法,并把业务逻辑写在里面。

public class AlphaECService extends EventualConsistencyService {
 /**
 * @param param 业务参数
 * @param lastReturn 上一个服务返回结果
 */
 @Override
 public DtxResponse execute(Object param, Object lastReturn) throws Exception {
 CommonParam commonParam = (CommonParam) param;
 String foobar = commonParam.getString("foobar");
 // 业务逻辑代码部分
 
 return null;
 }
}

2、注册ServiceFactory

public class ServiceFactory {
 static {
 serviceMap.put("XXXXX", "kd.fi.ai.mservice.dtxservice.XXXXX
 }
}

事务操作部分

// 插件本身已经开启了本地事务,传播属性是required
public class FoobarOperationPlugin extends AbstractOperationServicePlugIn {
    @Override
    public void beginOperationTransaction(BeginOperationTransactionArgs e) {

        ECGlobalSession.begin(SCENES_CODE);
        // 注册分布式事务1
       ECGlobalSession.register(CLOUD_ID, APP_ID, ALPHA_EC_SERVICE);
    }
    @Override
    public void endOperationTransaction(EndOperationTransactionArgs e) {
        // 注册分布式事务2
        ECGlobalSession.register(CLOUD_ID, APP_ID, BRAVO_EC_SERVICE);
    }
}

业务场景配置 

场景编码:要求唯一,和代码中的scenesCode保持一致,否则会抛异常
场景名:具有中文含义的描述
所属应用:所属应用的appld
业务类型:业务归宿的种类,可以和场景编码相同 

具体文档链接:https://mp.csdn.net/mp_download/manage/download/UpDetailed

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/423537.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

4月17日第壹简报,星期一,农历闰二月廿七

4月17日第壹简报,星期一,农历闰二月廿七坚持阅读,静待花开1. 风云三号G星顺利入轨!我国成功发射首颗主动降水测量卫星(能探测到毛毛雨般的降水)。2. 四次出舱!神舟十五号乘组刷新单个乘组出舱活…

Opencv c++ 图片截取不规则ROI区域

做目标检测的很多时候,需要我们选择一个相对固定的区域来识别目标。 思路很简单,适合相机固定,ROI变化不大的场景。 1、原图备份后先截取不规则的ROI区域,其他区域置为黑背景,检测识别效果 2、在原图上,将…

全新适配鸿蒙生态,Cocos引擎助力3D应用开发

一、适配HarmonyOS背景 HarmonyOS 3.1版本自发布以来,备受广大开发者的好评,同时也吸引了鸿蒙生态众多伙伴的青睐。 鸿蒙生态所强调的智慧全场景、多端联动与跨设备流转等能力,与Cocos所具有的跨平台、低功耗、高性能三大核心特点不谋而合。C…

银河麒麟服务器ky10 sp3 x86编译安装postgresql(包含uuid)

目录 下载 编译安装 目录说明 脚本文件说明 压缩包说明 脚本代码 下载 官网 PostgreSQL: The worlds most advanced open source database 源码下载地址 PostgreSQL: File Browser 有多个版本可以选择,我选择的是10.23 点击下载即可 我下载好之后把他上传到…

Qt网络编程 (udp广播和接收例)

大纲概述senderreceiver演示概述 使用两个项目 1 sender 用来广播"hello world";2 receiver 用来接收广播信息 sender 1 创建Qdialog类2 在sender.pro 中添加 QT network 一行代码3 在sender.h 中声明类 class QUdpSocket;在声明一个私有对象QUdpSocket *sender;…

ASEMI代理AD8226ARZ-R7亚德诺(ADI)车规级AD8226ARZ-R7

编辑:ll ASEMI代理AD8226ARZ-R7亚德诺(ADI)车规级AD8226ARZ-R7 型号:AD8226ARZ-R7 品牌:ADI /亚德诺 封装:SOIC-8 批号:2023 安装类型:表面贴装型 引脚数量:8 类…

VS 创建ATL组件(C++)

目录1、新建ATL项目2、添加接口类、实现接口方法3、创建自己的方法。在头文件Add.h中添加声明4、在源文件Add.cpp中添加函数实现5、在MyComTest.idl中添加方法接口设置,如interface IAdd:IDispatch中所示。6、解决方案配置选择release, 平台选择x64,生成。MyComTest…

【数据结构与算法】判定给定的字符向量是否为回文算法

题目: Qestion: 试写一个算法判定给定的字符向量是否为回文。   回文解释: 回文是指正读反读均相同的字符序列,如“abba”和“abdba”均是回文,但“good”不是回文。 主要思路: 因为数据要求不是很严格并且是一个比较简单的…

软件测试—基础篇

软件测试—基础篇🔎软件测试的生命周期🔎如何描述一个BUG🔎如何定义BUG 的级别🔎BUG 的生命周期🔎测试的执行与管理测试的执行与管理如何发现更多的BUG🔎产生争执怎么办🔎结尾🔎软件…

基于PaddlePaddle的词向量实战 | 深度学习基础任务教程系列

词向量是自然语言处理中常见的一个操作,是搜索引擎、广告系统、推荐系统等互联网服务背后常见的基础技术。 在这些互联网服务里,我们经常要比较两个词或者两段文本之间的相关性。为了做这样的比较,我们往往把词表示成计算机适合处理的方式。最…

CRM管理系统有哪些优势?在企业中有什么作用?

CRM管理系统有哪些优势?在企业中有什么作用? 其实,公司上crm管理系统不仅不会增加员工负担,还能提升员工满意度、赋能员工。当然,前提是一款优质的CRM管理系统。 那么,一款优质的CRM管理系统一般具备哪些…

45.Promise,async,await

目录 1 Promise 1.1 状态 1.2 then 1.3 任务的优先级 1.4 连续then 1.4.1 then()的返回值也是一个Promise对象 1.4.2 默认情况下,在第一个then之后,会执行第二个then的成功函数 1.4.3 then的value可以用返回值传递 1.4.4 通过then的返…

为什么老年人会经常性出现吃饭呛咳的情况 什么因素导致的

其实很多老年人在吃饭或是喝水的时候,都存在吞咽困难的问题,呛咳或者是忘了如何下咽。其实在老年人群体当中,这也是一种较为常见的现象,但是很多人都把这种现象当回事。 对于呛咳的现象是很好判断的,在家里老人喝水或是…

专注区块链底层技术突破,“复杂美”用技术开源推动产业未来

杭州复杂美科技有限公司(以下简称:复杂美)成立于2008年,是一家致力于高性能撮合技术研发的区块链底层技术提供商,专注于区块链撮合系统、区块链清算系统的应用与推广。 公司于2013年启动区块链、智能合约的研发应用&am…

PyTorch 深度学习实战 | 基于 ResNet 的花卉图片分类

“工欲善其事,必先利其器”。如果直接使用 Python 完成模型的构建、导出等工作,势必会耗费相当多的时间,而且大部分工作都是深度学习中共同拥有的部分,即重复工作。所以本案例为了快速实现效果,就直接使用将这些共有部…

36岁大龄程序员被裁,找了2个月工作,年包从100万降到50万,要不要接?

为了找到工作,你愿意接受降薪多少?一位36岁的杭州程序员问:36岁被裁,找了2个月工作,年包从100万降到50万,真心纠结,要不要接?网友们分成了旗帜鲜明的两派,一派人认为不要…

【数学模型】欧拉公式和证明

一、说明 在图型学中,欧拉公式很有用处,比如皮克定律也可以用欧拉公式证明。本篇介绍欧拉公式的定义和三个证明过程。 二、欧拉公式 在任何一个规则球面地图上,用 R记区域个 数 ,V记顶点个数 ,E记边界个数 &#xff0c…

BGP基础知识

今天海翎光电的小编主要介绍一下BGP的相关基础知识,文章浅显易懂,适合对BGP完全没有了解的同学。 BGP介绍 边界网关协议BGP(Border Gateway Protocol)是一种实现自治系统AS(Autonomous System)之间的路由可…

【cmake篇】选择编译器及设置编译参数

实际开发的过程中,可能有多个版本的编译器,不同功能可能需要设置不同的编译参数。 参考博客链接:选择编译器及设置编译器选项 目录 一、选择编译器 1、查看系统中已有的编译器 2、选择编译器的两种方式 二、设置编译参数 1、add_compi…

CSSOM和CSSOM View

CSSOM和CSSOM View这两个我都不是熟悉的领域。 1.描述样式表和规则等 CSS 的模型部分(CSSOM) cssom中document.styleSheets :获取文档中所有的样式(只读),这个不常见,不做过多的介绍 2.元素视图…