GRIT: Consistent Distributed Transactions across Polyglot Microservices with Multiple Databases

GRIT 基于多个数据库的聚合微服务的一致性分布式事务

GRIT: Consistent Distributed Transactions across Polyglot Microservices with Multiple Databases


摘要

在应用程序当中最受欢迎的微服务架构给我们在多重微服务的分布式事务方面带来了新的挑战。这些微服务可能使用不同语言实现,并且使用多种不同的数据库。在当前环境下,我们非常需要一致性分布式事务,用现存的技术缺非常难实现。在这篇论文中,我们提出了GRIP:一种通过巧妙地利用确定性数据库技术和乐观并发控制协议解决了这个问题的协议。乐观地执行事务,并在执行阶段捕获其读集和写集。在执行阶段,会执行冲突检测,并且做出全局提交决策。逻辑提交事务首先被持久化到log中,然后异步应用到物理机当中。GRIT可以实现一致性,高吞吐量和序列化分布式事务,适用于调用了微服务的任何用用程序。在测试中我们演示了GRIT如何轻松支持跨多个微服务和数据库的分布式事务。



这里省略了一部分不重要的,下面从原论文从第二页开始。



GRIT利用了一些确定性的思想,例如在执行之前,对基于paxos的日志中的事务进行排序。与calvin中的侦查阶段(收集阶段)类似,我们在执行乐观并发控制执行阶段的时候,会乐观的在微服务中执行事务逻辑并且保存临时写结果。我们与calvin和FAUNADB不同的是,我们使用新的确定性冲突解决算法在OCC执行阶段之后立即解决冲突,并在其持久化到提交日志之前执行快速全局交协议。显然,GRIT可以显著减少终止事务的事务延迟。这还表明,只有已经提交的事务会进入事务日志。在事务日志执行过程中(物理化,实例化or落盘?)不需要进一步的执行。此外,日志播放部分也变得很简单,仅仅是应用在OCC执行阶段已经计算好的写操作。这就是为什么我们称它为事务的实体实现。
在这个样例中,我们展示了GRIT:支持跨微服务的一致分布式事务的新系统,微服务是用各种语言实现的,使用多个不同的底层数据库。该系统是高效的、可伸缩的,并为通过微服务公开的多个数据库之间的事务提供了序列化性。我们使用一个简化的应用程序场景来说明我们提出的挑战和解决方案。



架构和设计

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值