亚信安慧AntDB-M 只读事务提交优化

news2024/9/21 17:56:40

一、事务操作介绍

数据库系统一般有三种开启和提交事务方法:

  1. 配置autocommit=1时,隐式开启事务,每执行一条DML的SQL语句,数据库系统会隐式的自动执行commit逻辑提交事务,不需要用户输入commit执行提交。

  2. 配置autocommit=0时,隐式开启事务,随后执行的DML的SQL语句都在同一个事务内,直到用户输入commit执行提交。

  3. 用户输入BEGIN/START TRANSACTION,显式开启事务,随后执行的DML的SQL语句都在同一个事务内,直到用户输入commit执行提交。

在事务开启和提交过程中执行的DML的SQL语句,申请到的表意向锁资源,根据2PL协议会一直持有直到事务提交或回滚才会释放。

如果用户使用autocommit=0或begin这两种开启事务,执行DML的SQL语句,未输入commit提交事务,在这期间,同时另一个用户执行相同表的DDL语句,如果开启事务和执行DML的语句是发生在主副本上,DDL请求会等待超时后失败;如果开启事务和执行DML语句发生在备副本上,这时DDL语句在主副本上是成功的,DDL语句通过复制协议同步到备副本上执行,会等待锁超时后失败,导致后续通过复制协议同步过来数据无法继续应用到备副本上,副本间数据同步中断。

二、 现有空闲长事务中止方案

AntDB-M起初通过配置事务超时间来解决长时间空闲事务未提交带来的事务占用资源未释放的问题,如果空闲事务超时,数据库系统会自动中止事务,执行回滚操作,释放事务资源。

基于空闲事务超时,释放事务资源的方案,有以下缺点:

  1. 超时时间配置值不好评估,如果确实有个别应用处理产生的长事务会超过空闲事务超时时间,会影响正常应用流程;

  2. 副本数据同步实时性不足,数据丢失风险,如果在在备副本上空闲事务超时时间范围内发生的DDL等待失败,副本数据同步中断;如果在DDL等待成功(DDL等锁时间大于空闲事务超时时间),但备副本同步落后。

三、 只读事务提交优化方案

AntDB-M后续做了进一步的优化,对于只读查询事务长时间未提交,并且数据库的隔离级别是读已提交(Read Committed)时,自动提交查询操作,立即释放事务资源,使并发的DDL执行成功,副本数据同步不中断,保证数据库集群稳定。

在数据库隔离级别为读已提交(Read Committed)时,且autocommit=0的场景下:

  1. 如果事务前序的只读查询操作的DML,每执行一条只读查询操作的DML后,系统自动提交;

  2. 如果事务执行过写操作的DML,之后的再执行只读查询或写操作的DML,不执行自动提交;

只读查询操作的DML有:SELECT语句(不带FOR UPDATE);

写操作的DML有:INSERT、UPDATE、DELETE、SELECT FOR UPDATE;

对于显式BEGIN/START TRANSACTION开始的事务,因为是显式开启事务,认为用户是自知的,不使用此方案。

此方案限定在读已提交(Read Committed)隔离级别,不会影响查询结果的正确性。

四、只读事务提交优化效果演示

演示环境使用Read-Committed隔离级别和autocommit=0。

如图1所示,在set allow_readonly_autocommit=off,关闭只读事务提交优化,只读SELECT操作在没有提交事务时会保留一把表意向锁,提交后锁释放掉。

图片

图1:优化前执行效果

如图2所示,在set allow_readonly_autocommit=on,开启只读事务提交优化,只读SELECT操作在事务未提交时也不会持有表意向锁,在UPDATE写操作后的只读SELECT操作不会释放锁,提交后所有锁都释放。

图片

图2:优化后执行效果

由此可见,该优化方案可解决备副本上因为只读事务查询操作长时间不提交导致DDL执行阻塞或失败问题,避免了数据库集群副本间数据同步落后或中断,提高了AntDB-M数据库集群的稳定性。

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

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

相关文章

Qt第三课 ----------按钮的控件属性

作者前言 🎂 ✨✨✨✨✨✨🍧🍧🍧🍧🍧🍧🍧🎂 ​🎂 作者介绍: 🎂🎂 🎂 🎉🎉&#x1f389…

视频推拉流/直播点播EasyDSS平台安装失败并报错“install mediaserver error”是什么原因?

TSINGSEE青犀视频推拉流/直播点播EasyDSS平台支持音视频采集、视频推拉流、播放H.265编码视频、存储、分发等视频能力服务,在应用场景中可实现视频直播、点播、转码、管理、录像、检索、时移回看等。此外,平台还支持用户自行上传视频文件,也可…

openeuler-无法dnf安装包问题

有个openEuler release 22.09系统机器,需要dnf安装些包等 [rootlydb ~]# more /etc/openEuler-release openEuler release 22.09 [rootlydb ~]# dnf -y install lrzsz OS …

【C++】Stack

个人主页~ Stack 一、Stack的介绍和使用1、stack的介绍2、stack的使用3、stack的模拟实现 二、容器适配器1、什么是适配器2、容器适配器的使用 三、deque1、原理介绍2、deque的使用3、deque的缺陷 一、Stack的介绍和使用 1、stack的介绍 stack详细解释 stack是一种容器适配器…

onlyoffice 使用记录(前端开发角度)

前端和Web文档生成器服务器交互 对于与 Web 文档生成器服务的交互,使用 POST 请求。 请求参数在请求正文中以 JSON 格式输入。 请求被发送到 https://documentserver/docbuilder 地址,其中 documentserver 是安装了 ONLYOFFICE 文档服务器的服务器的名称…

创新实验报告VC++案例开发十二生肖的俄罗斯方块智力游戏完整代码设计方案

一.项目名称 十二生肖俄罗斯方块 二.开发背景: 俄罗斯方块是一个很低古老的一个小游戏,到但今日它还有很大的魅力。 三.技术路线或工作原理: 采用的软件及开发平台 Micosoft Visual 6.0 项目的总体方…

1.安卓逆向-说明

免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 内容参考于:图灵Python学院 正常来爬一个app的数据,在没有加密的情况下,就不需要去逆向,app没有加密也就可以正…

SprinBoot+Vue高校就业管理系统的设计与实现

目录 1 项目介绍2 项目截图3 核心代码3.1 Controller3.2 Service3.3 Dao3.4 application.yml3.5 SpringbootApplication3.5 Vue 4 数据库表设计5 文档参考6 计算机毕设选题推荐7 源码获取 1 项目介绍 博主个人介绍:CSDN认证博客专家,CSDN平台Java领域优质…

RickdiculouslyEasy--CTF-综合靶场

废话不多说,一个靶机,好几个flag,开整!!! 使用命令如下,来进行主机发现。 netdiscover -r 172.16.1.10 找到目标靶机 扫描端口 nmap 172.16.1.7 -p 1-65535 依次访问 第一个flag 9090端口 第…

使用CUBE_MX实现STM32 DMA 功能(存储器到存储器)

目录 一、使用DMA实现从存储器1发送数据到存储器2中 1.CUBE_MX配置 2.KEIL5配置 一、使用DMA实现从存储器1发送数据到存储器2中 1.CUBE_MX配置 1.在DMA选项中添加MEMORY TO MEMORY 选择数据宽度,并确保地址递增功能打开。 2.系统时钟72MHz 3.生成代码 2.KEIL5配…

创建Django 项目

创建一个新的 Django 项目: django-admin startproject myproject cd myproject 在 Django 项目中创建一个新的应用: python manage.py startapp myapp设置数据库 编辑 myproject/settings.py 文件中的数据库设置: DATABASES {default:…

研究: 用于训练大型语言模型的数据集往往缺乏透明度

研究人员开发了一种易于使用的工具,使人工智能从业人员能够找到适合其模型目的的数据,从而提高准确性并减少偏差。 这款名为 “数据出处资源管理器”(Data Provenance Explorer) 的新工具可以帮助从业人员在训练模型时对数据做出更明智的选择。 为了训练…

随机规划及其MATLAB实现

目录 引言 随机规划的基本模型 随机动态规划 随机动态规划建模实例​(随机动态规划): MATLAB中的随机规划实现 示例:两阶段随机规划 表格总结:随机规划求解方法与适用场景 结论 引言 随机规划(Stochastic Programming&…

SpringCloud之配置中心svn示例和refresh

SpringCloud之配置中心svn示例和refresh 上一篇配置中心git示例留了一个小问题,当重新修改配置文件提交后,客户端获取的仍然是修改前的信息,这个 问题我们先放下,待会再讲。国内很多公司都使用的svn来做代码的版本控制&#xff…

LabVIEW项目硬件设备选择

在LabVIEW开发项目中,硬件设备的选择至关重要,直接影响系统的性能、稳定性和开发效率。合适的硬件设备不仅能够有效支持项目目标的实现,还能提高整体测试和控制系统的灵活性。因此,从性能需求、兼容性、成本、扩展性等多个角度出发…

vue3 图片裁剪

最终效果 插件下载 pnpm install vue-cropper 配置 在main.js中配置: import VueCropper from vue-cropper; import vue-cropper/dist/index.css;app.use(VueCropper); 组件封装 components/Cropper/index.vue <temp

Linux基础---04vi编辑器指令常用集合及如何恢复意外断开未保存的文件

一.光标移动快键键集合 操作解释h,j,k,l左下上右i在光标位置编辑a在光标后一位编辑o换行编辑&#xff0c;另起一行ctrl f下翻一页ctrl b上翻一页ctrl d下翻半页ctrl u上翻半页数字0跳到行首&#xff0c;也就是跳到第0个字符^跳到行首的第一个字符shift 4跳到行尾shift g…

技术成神之路:设计模式(十三)访问者模式

介绍 访问者模式&#xff08;Visitor Pattern&#xff09;是一种行为型设计模式&#xff0c;它允许你在不改变对象结构的前提下&#xff0c;定义作用于这些对象的新操作。这种模式通过将操作逻辑从对象结构中抽离出来&#xff0c;使得新的操作可以无缝地添加到现有对象中。 1.定…

【漏洞复现】用友 NC pagesServlet Sql注入漏洞

免责声明&#xff1a; 本文内容旨在提供有关特定漏洞或安全漏洞的信息&#xff0c;以帮助用户更好地了解可能存在的风险。公布此类信息的目的在于促进网络安全意识和技术进步&#xff0c;并非出于任何恶意目的。阅读者应该明白&#xff0c;在利用本文提到的漏洞信息或进行相关测…

安装docker-compose最新版本

github下载地址 在github上下载最新版本&#xff0c;这里是centos7的环境直接下载这个就好了。 这里下载好传到服务器即可&#xff0c;这里查看没有权限 需要给文件增加x的执行权限。 ~]# ls -lh 总用量 61M -rw-------. 1 root root 1.7K 7月 29 2022 anaconda-ks.cfg -rw-r…