0

0

SQL 分布式架构下的数据一致性

舞夢輝影

舞夢輝影

发布时间:2026-01-24 17:32:03

|

170人浏览过

|

来源于php中文网

原创

2PC常被绕过因其存在单点阻塞、协调器故障致悬挂事务、网络分区无法自动回滚等问题,高吞吐场景下协调延迟拖垮性能;替代方案包括本地消息表+定时补偿、Seata AT模式、TCC等。

sql 分布式架构下的数据一致性

分布式事务中 2PC 为什么常被绕过

因为 2PC 在跨节点场景下存在单点阻塞、协调器故障导致悬挂事务、网络分区时无法自动回滚等问题,实际生产中多数系统选择不强依赖它。尤其在高吞吐写入场景(如订单+库存+积分拆分到不同库),协调延迟会直接拖垮响应时间。

常见替代方案包括:

  • 业务层最终一致性:用 本地消息表 + 定时补偿 替代全局事务
  • 基于 Seata AT 模式:依赖 undo log 自动反向 SQL,但要求数据库支持行级锁且不能有 DDL 并发
  • 使用 TCC:需手动编码 Try/Confirm/Cancel 三个阶段,对业务侵入大,但可控性高

SELECT ... FOR UPDATE 在分库分表后失效的原因

分库分表中间件(如 ShardingSphereMyCat)通常只保证单逻辑表内的行锁语义,跨分片的 SELECT ... FOR UPDATE 会被路由到多个物理库执行,彼此无锁感知,等价于加了 N 个互不相关的本地锁。

这意味着:

  • 若两个事务分别锁定不同分片上的记录,仍可能引发脏写
  • FOR UPDATE 不会触发跨节点锁等待,也不会报错,行为静默但危险
  • 唯一可靠方式是把需要原子更新的数据尽量收敛到同一分片(例如用 user_id 做分片键,让账户余额和交易流水落在同库)

读已提交(READ COMMITTED)在分布式库中不等于“读到一致快照”

每个物理库独立维护自己的事务视图和 MVCC 快照,即使所有库都设为 READ COMMITTED,应用从不同分片并发读取时,仍可能看到部分已提交、部分未提交的状态——这不是隔离级别配置错误,而是架构层面的固有限制。

华友协同办公自动化OA系统
华友协同办公自动化OA系统

华友协同办公管理系统(华友OA),基于微软最新的.net 2.0平台和SQL Server数据库,集成强大的Ajax技术,采用多层分布式架构,实现统一办公平台,功能强大、价格便宜,是适用于企事业单位的通用型网络协同办公系统。 系统秉承协同办公的思想,集成即时通讯、日记管理、通知管理、邮件管理、新闻、考勤管理、短信管理、个人文件柜、日程安排、工作计划、工作日清、通讯录、公文流转、论坛、在线调查、

下载

典型表现:

  • 查订单主表返回 status = 'paid',但关联查支付明细表却为空(因支付记录落在另一分片,尚未同步提交)
  • 使用 XASeata XA 可强制统一快照起点,但性能损耗显著,且要求所有参与库支持 XA 协议
  • 更轻量做法是引入 全局时间戳服务(如 TSO),在业务读取前先获取一个单调递增时间点,再按该时间点查询各分片

异步复制延迟导致的 主从不一致 怎么收敛

MySQL 主从、TiDB Learner 副本、甚至 Kafka-based CDC 同步链路,都存在毫秒到秒级延迟。当应用刚写完主库就立刻查从库,大概率读到旧值。

缓解手段不是消除延迟(做不到),而是控制读请求的可见性边界:

  • 关键路径强制走主库:比如用户刚下单,后续查订单详情必须打到 write datasource
  • 利用 GTIDbinlog position 做从库读前校验(ShardingSphere 支持 hint 指定主库位点)
  • 对非实时场景,用 缓存双删 + 延迟消息校验 替代强一致读,例如更新 DB 后删缓存,再发延迟 5s 的 MQ 消息重刷缓存

最易被忽略的是:很多团队以为加了 read_uncommitted 就能解决读延迟,其实它只会让问题更隐蔽——你读到了未提交的中间态,比读旧值还难排查。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

685

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

324

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

348

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1117

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

359

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

717

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

577

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

419

2024.04.29

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.9万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 808人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号