采用2PC和TSO+MVCC方案实现的分布式事务,经常被质疑的问题是提交阶段延迟增加和TSO单点问题,针对这两个问题PolarDB-X进行了哪些工程实现上的优化?
两阶段提交由于增加了prepare的阶段,提交阶段的延迟高于单分片事务。但实际上对于单分区写入事务无论读是否跨分片,我们依然可以使用一阶段提交保证原子性,PolarDB-X支持自动识别这种情况,显著减少这类场景下的提交延迟。
TSO方案由于采用单点授时,一个潜在的问题是可能存在单点故障和单点性能瓶颈风险。PolarDB-X的GMS服务部署在三节点集群上,通过X-Paxos协议保证服务高可用。同时PolarDB-X多种场景进行了优化,使得带拆分条件的点查、点写,可不依赖GMS,提升查询性能同时也降低GMS的压力。另外,对于单个CN进程,默认采用grouping的方式将同一时间发生的多个TSO请求合并为batch操作,一次性获取,保证CN和GMS之间交互的指令包不会过多,进一步保证GMS不会成为系统瓶颈。
以上内容摘自《PolarDB-X 从入门到实战》电子书,点击https://developer.aliyun.com/ebook/download/7674可下载完整版
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
PolarDB 分布式版 (PolarDB for Xscale,简称“PolarDB-X”) 采用 Shared-nothing 与存储计算分离架构,支持水平扩展、分布式事务、混合负载等能力,100%兼容MySQL。 2021年开源,开源历程及更多信息访问:OpenPolarDB.com/about