首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

游戏服务分布式事务优化(二)- 事务管理

前言 接上文 《游戏服务分布式事务优化(一)- Write Ahead Log(WAL) 模块》 在挺久以前我写过一篇分享 《在游戏服务器中使用分布式事务》 。...当时尝试在我们游戏服务中引入TCC模型分布式事务机制,以优化好友和公会服务一致性流程。...基本原理 首先,先简介一下这个分布式事务系统基本原理。详细一点可以看我之前一篇文章,《Google去中心化分布式系统论文三件套(Percolator、Spanner、F1)读后感》 。...而且本身分布式事务模块要接入规范就比较多,使用起来有一定难度,抽象非常复杂情况下使用起来就更困难了。...所有的事务事件必须满足 交换律 定期调用 tick() 接口 定义上述 vtable 内必须接口 由于我们只提供了SDK,对于RPC操作, 参与者(participator) 服务还必须接入以下服务:

2.6K30

比较微服务分布式事务模式

,并向其他服务发送此次变更 你可能有跨多个服务边界业务事务 由于用户会重试失败调用,因此你不得不实现幂等服务操作 本文中使用了一个简单场景来评估在分布式事务中处理双写多种方式,该场景中,一个客户端应用会调用一个微服务...或者B服务可以不使用分布式事务,转而使用本地事务,并实现幂等消费模式。...参与服务必须提供可恢复后端,这样协调器可以通过回滚来恢复整体状态。这种方式最大好处是能够通过本地事务让可能不支持分布式事务各种服务达到一致性状态。...不需要XA事务3.可以在协调器层面了解到分布式状态 劣势 1. 复杂分布式编程模型2. 参与服务可能要提供幂等补偿操作3. 最终一致性4....(并行处理) 如何选型分布式事务策略 正如你看到,在微服务架构中处理分布式事务时并不存在正确或错误模式。

2.4K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    服务(十六)——Seata 分布式事务框架

    分布式事务问题由来 分布式前 单机单库没这个问题 从1:1 -> 1:N -> N:N 单体应用被拆分成微服务应用,原来三个模块被拆分成三个独立应用,分别使用三个独立数据源,业务操作需要调用三三...此时每个服务内部数据一致性由本地事务来保证, 但是全局数据一致性问题没法保证。 一句话:一次业务操作需要跨多个数据源或需要跨多个系统进行远程调用,就会产生分布式事务问题。...Seata术语 是什么 Seata是一款开源分布式事务解决方案,致力于在微服务架构下提供高性能和简单易用分布式事务服务。...分布式事务业务说明 这里我们会创建三个服务,一个订单服务,一个库存服务,一个账户服务。...Alina Gingertail 分布式事务执行流程 TM开启分布式事务(TM向TC注册全局事务记录) ; 按业务场景,编排数据库、服务事务内资源(RM向TC汇报资源准备状态) ; TM结束分布式事务

    1.8K30

    服务 day19:分布式事务

    来实现 MQ 在分布式事务整个流程。  ...如何实现两个分布式服务(订单服务、学习服务)共同完成一件事即订单支付成功自动添加学生选课需求,这里关键是如何保证两个分布式服务事务一致性。...上边几个问题涉及到分布式事务控制,下面我们带着这些问题,来继续了解一下什么是分布式事务。 0x02 什么是分布式事务 在了解分布式事务之前,我们来回顾一下什么是分布式系统。 1、什么是分布式系统?...CAP 理论是分布式事务处理理论基础,了解了 CAP 理论有助于我们研究分布式事务处理方案。...三、Spring Task定时任务 0x01 需求分析 根据分布式事务研究结果,订单服务需要定时扫描任务表向 MQ 发送任务。

    2.1K20

    服务架构分布式事务解决方案

    分布式系统架构中,分布式事务问题是一个绕不过去挑战。而微服务架构流行,让分布式事问题日益突出! 下面我们以电商购物支付流程中,在各大参与者系统中可能会遇到分布式事务问题场景进行详细分析!...预扣减积分、锁定优惠券,此时电商平台内各服务间会有分布式事务问题,因为此时已经要跨多个内部服务修改数据; 2、支付平台中创建支付订单(选银行卡支付):查询账户、查询限制规则,符合条件就创建支付订单并跳转银行...,此时不会有分布式事务问题,因为还不会跨服务改数据; 3、银行平台中创建交易订单:查找账户、创建交易记录、判断账户余额并扣款、增加积分、通知支付平台,此时也会有分布式事务问题(如果是服务化架构的话);...] 如上图,把支付系统中银行扣款成功回调处理流程提取出来,对应分布式事务问题代码场景: /** 支付订单处理 **/ @Transactional(rollbackFor = Exception.class...以上分布式事务问题,需要多种分布式事务解决方案来进行处理。 订单处理:本地事务 资金账户加款、积分账户增加积分:TCC型事务(或两阶段提交型事务),实时性要求比较高,数据必须可靠。

    2.7K10

    如何实现微服务架构下分布式事务

    系统微服务化后,一个看似简单功能,内部可能需要调用多个服务并操作多个数据库实现,服务调用分布式事务问题变非常突出。 3. 微服务数量众多,其测试、部署、监控等都变得更加困难。...而对于第二个问题,现在还没有通用方案很好解决微服务产生事务问题。分布式事务已经成为微服务落地最大阻碍,也是最具挑战性一个技术难题。...为此,本文将深入和大家探讨微服务架构下,分布式事务各种解决方案。 分布式事务典型场景:银行转账业务 以银行转账业务为例,通常包括以下三种情况: A. 支行内转账:同一银行相同支行内转账 B....业务微服务改造后,转入、转出通常为不同服务,同一个微服务也通常运行于不同副本中。A可能变成一个分布式事务,也可能通过一些方法规避,在本地事务内完成。B和C很难规避,只能是分布式事务。...对于分布式事务,微服务最佳实践通常建议尽量规避,但是在很多业务场景是无法规避,比如上面的B、C转账场景,没有好办法在一个微服务本地事务内完成两个账户数据更新。

    92510

    服务化与分布式事务冲突解析

    我们先回顾一下,如果没有做所有上述架构和业务数据库拆分,那所有操作都由同一个jvm进程中同一个事务管理器控制,那么事物提交和回滚是比较容易控制,但是在分布式环境下,所有的操作都是以服务为业务单元...我们可以换一个思路,参考跨两个服务操作,假如我们将业务继续合并下沉,也就是B、C操作放到B事务中执行能够保证一致性,然后将A、B合并到A中执行,同样也能保证一致性,这样在分布式中跨3个进程服务调用我们也能够保证数据一致性...那么分布式系统中分布式事务如何保证数据一致性呢?...简单给出以下几个比较抽象方案: 产品层面;将强一致性需求转变成若一致性需求,或者说从设计角度规避分布式场景强一致性 强一致性但相对简单业务场景;比方说只跨两个服务单元,可以考虑业务下沉与合并 强一致性并且比较复杂场景...,考虑使用分布式事务中间件,例如TXC或者自己实现 业务场景复杂但是可以接受最终一致性(ACID中牺牲CI),可以考虑本地消息表,TCC模式,消息事务等 谢谢参读,如有不周可以直接联系本人或者留言!

    1.3K30

    服务分布式事务模式详细对比

    你可能需要以幂等方式实现服务操作,因为服务消费者必须要重试失败调用。 在本文中,我们将会使用一个很简单示例场景来评估在分布式事务中处理双重写入各种方法。...类似的,服务 B 可以使用分布式服务来消费消息,并在同一个事务中提交至数据库 B,这个过程中也不会出现任何重复数据。...或者,服务 B 也可以选择不使用分布式事务,而是使用本地事务并实现幂等消费者模式。...这种方式最大优点是,能够仅通过本地事务就能驱动那些可能不支持分布式事务异构服务达到一致状态。...并行管道优点和缺点 表 5:并行管道优点和缺点 如何选择分布式事务策略 从本文论述中,你可能已经猜到,在微服务架构中,处理分布式事务并没有正确或错误模式。每种模式都有其优点和缺点。

    75910

    .Net Core with 微服务 - 分布式事务 - TCC

    上一次我们讲解了分布式事务 2PC、3PC 。那么这次我们来理一下 TCC 事务。本次还是讲解 TCC 原理跟 .NET 其实没有关系。...TCC Try 准备阶段,尝试执行业务 Confirm 完成业务 Cancel 回滚准备阶段业务 TCC 事务其实是 2PC 一个扩展。上一次我们说了 2PC ,在二阶段进行事务提交。...Confirm 如果一阶段都提交成功了,那么所有的服务都开始进入 Confirm 阶段。订单服务把房间状态更改为“已预定”状态;积分服务把冻结积分清0。这样整个事务都成功完成了。...TCC 相对于 2PC 不再依赖于本地数据库事物能力,它可以使用于应用层面的事务。它把 2PC 提交跟回滚操作明确抽象成 Confirm 跟 Cancel 。TCC 事务在逻辑上是比较清晰。...微服务 - Consul 配置中心 .Net Core with 微服务 - Polly 熔断降级 .Net Core with 微服务 - 分布式事务 - 2PC、3PC

    1.4K20

    服务分布式事务Saga模式简介

    但是,2PC两段提交并不是微服务分布式架构选择,因为存在单点风险,因为锁也会降低吞吐量。...分布式事务如果不结合CAP定理是无法认识清楚,2PC其实只是选择了CAP中CA,虽然CA保证了可靠性,但是忽视网络通讯随时可能堵塞或失败,形成网络分区,反而不可靠,2PC带来可靠性在分布式环境中是虚幻...在分布式系统中,CAP定理是King,CAP定理无论是理论高度或是工程实施高度都是要高于传统事务,在CAP定理干预下,传统ACID事务走向了妥协,变成了BASE,也就是走向最终一致性柔性事务。...ACID是原子性 一致性 隔离性和持久性总称: 1.原子性是确保事务中所有步骤要么全部完成,要么全部撤销回滚。Saga可以在事务中任何一个步骤发生失败时,通过调用应用服务回滚接口实现撤销。...2.一致性其实是数据完整性,这个可以由一个应用服务内部本地事务通过数据库机制完成,跨服务完整性(Referential integrity)由应用完成。

    1.9K20

    服务架构下分布式事务方案

    而对于第二个问题,现在还没有通用方案很好解决微服务产生事务问题。分布式事务已经成为微服务落地最大阻碍,也是最具挑战性一个技术难题。...为此,本文将深入和大家探讨微服务架构下,分布式事务各种解决方案,并重点为大家解读阿里巴巴提出分布式事务解决方案----GTS。...该方案中提到GTS是全新一代解决微服务问题分布式事务互联网中间件。...4 GTS--分布式事务解决方案 GTS是一款分布式事务中间件,由阿里巴巴中间件部门研发,可以为微服务架构中分布式事务提供一站式解决方案。 更多GTS资料请访问研发团队微博。...单事务分支平均响应时间在2ms左右,3台服务器组成集群可以支撑3万TPS以上分布式事务请求。

    1.3K20

    服务架构下分布式事务方案

    而对于第二个问题,现在还没有通用方案很好解决微服务产生事务问题。分布式事务已经成为微服务落地最大阻碍,也是最具挑战性一个技术难题。...为此,本文将深入和大家探讨微服务架构下,分布式事务各种解决方案,并重点为大家解读阿里巴巴提出分布式事务解决方案----GTS。...该方案中提到GTS是全新一代解决微服务问题分布式事务互联网中间件。...4 GTS--分布式事务解决方案 GTS是一款分布式事务中间件,由阿里巴巴中间件部门研发,可以为微服务架构中分布式事务提供一站式解决方案。 更多GTS资料请访问研发团队微博。...单事务分支平均响应时间在2ms左右,3台服务器组成集群可以支撑3万TPS以上分布式事务请求。

    1.2K60

    服务化带来数据一致问题---分布式事务事务型消息

    本文我们聊聊分布式事务事务型消息解决思路,通过阅读本文,可以理解分布式事务事务型消息,并且能够应用到实际生产工作中。 服务化后单体系统被拆分成多个服务,各服务访问自己数据库。...TCC分布式事务 TCC(Try-Confirm-Cancel)是分布式事务一种模式,可以保证不同服务数据最终一致。...答案是肯定。没法保证数据一致性,也就是说不能保证这几步操作全部成功或者全部失败!因为这几步操作是在分布式环境下进行,每个操作分布在不同服务中,不同服务又对应不同数据库,本地事务已经用不上了!...cancel(各个服务内部TCC分布式事务框架会互相通信)。...以上是我个人对分布式事务事务型消息等一些总结,公众号近期文章菜单中还有关于服务化问题其他文章,如:服务雪崩,服务化过程数据迁移等文章,感谢关注和阅读! ?

    2.1K20

    域名在哪里比较好 购买域名时候有哪些要注意

    域名现在也被列入了一种无形资产,也被国家越来越重视,很多域名都不能随便使用了,那么我们在选择创办网站时候,服务器和域名是必不可少,域名在哪里比较好呢?在购买时候还需要注意哪些事项呢?...域名在哪里比较好 域名在哪里比较好,最好是选择那些大型靠谱交易平台,如果是注册域名的话就去那种大型域名注册商。...当然,在交易时候去专业正规交易平台购买域名,我们权益就会有所保证,而且在后期维护时候他们也会更加地负责。...购买域名时候有哪些要注意 在域名购买之前我们要考虑因素也有很多,首先就是域名长度。...以上就是域名在哪里比较好相关信息,我们在注册或购买域名时候需要注意一些内容,大家如果还有什么疑问的话,也可以上网自行搜索。

    26.7K20

    分布式事务之TCC服务设计和实现

    作者:绍辉 原文:https://yq.aliyun.com/articles/609854 一、TCC简介 TCC是一种比较成熟分布式事务解决方案,可用于解决跨库操作数据一致性问题; TCC是服务两阶段编程模型...如下图所示,业务实现TCC服务之后,该TCC服务将作为分布式事务其中一个资源,参与到整个分布式事务中;事务管理器分2阶段协调TCC服务,在第一阶段调用所有TCC服务Try方法,在第二阶段执行所有TCC...会出现分布式事务并发问题; 用户在实现TCC服务时,需要考虑业务数据并发控制,尽量将逻辑锁粒度降到最低,以最大限度提高分布式事务并发性; 三、总结 蚂蚁金服使用TCC有10年历史,在TCC应用方面积累了大量实践经验...;除了上述TCC服务设计注意事项外,我们在解决用户高并发、高可用需求方面也提供了解决方案,我们对分布式事务做了极致性能优化以支持双11等大促高并发需求,我们基于蚂蚁LDC架构高可用方案能使分布式事务服务达到...99.99%可用性; 蚂蚁金服大部分业务系统均采用TCC方式接入分布式事务,但设计TCC服务时要遵循大量设计规范,这无疑对用户提了非常高要求;为了简化用户接入分布式事务门槛,蚂蚁金服分布式事务框架

    1.6K20

    服务--分布式事务实现方法及替代方案

    这两天正在研究微服务架构中分布式事务处理方案, 做一个小小总结, 作为备忘. 如有错误, 欢迎指正!...如果业务场景需要强一致性, 那么尽量避免将它们放在不同服务中, 也就是尽量使用本地事务, 避免使用强一致性分布式事务....如果业务场景需要强一致性, 并且只能够进行分布式服务部署, 那么最好是使用TCC方案而不是2PC方案来解决. 注意: 以下每种方案都有不同适用场合, 需要根据实际业务场景来选择....异步确保型 通过将一系列同步事务操作变为基于消息执行异步操作, 避免了分布式事务同步阻塞操作影响. 这个方案真正实现了两个服务解耦, 解耦关键就是异步消息和补偿性事务....适用场景 执行周期较长 实时性要求不高 例如: 跨行转账/汇款业务(两个服务分别在不同银行中) 退货/退款业务 财务, 账单统计业务(先发送到消息中间件, 然后进行批量记账) 最大努力通知型 这是分布式事务中要求最低一种

    74930

    服务配置中心和分布式配置中心哪个比较好?各有什么优点?

    如果对网络配置文件有所了解的话,那么就应该知道服务配置中心和分布式配置中心两种概念,这两个配置中心拥有不同功能和性能,那么服务配置中心和分布式配置中心哪个比较好呢?分布式配置中心有哪些优点?...服务配置中心和分布式配置中心哪个比较好 不管是从性能优秀程度还是从功能全面程度来说,分布式配置中心都比服务配置中心要好。...服务配置中心更适合以前传统网络环境,而现在网络环境发生了变化,分布式技术成为了网络主流,所以分布式配置中心应运而生,分布式配置中心更适合现在网络环境。 分布式配置中心有哪些优点 1、高效率。...以上为大家简单介绍了服务配置中心和分布式配置中心哪个比较好?...分布式配置中心要比服务配置中心更优秀一些,因为分布式配置中心除了具有上面的优点以外,还能够和云计算云技术等新兴网络技术结合起来,所以成为了现在互联网世界中比较常用配置中心工具。

    74020

    如何在微服务中实现分布式事务变通?

    传统单体架构下分布式事务概念并不适合微服务,面临挑战很多(挑战问题点击标题见原文),想在微服务中进行分布式事务处理?...需要改变思路和视角: 组合,如果您认为您应该合并几个微服务或将事务集成到一个服务中,那么进行此练习永远不会晚。 为事务构建一致且有用审核,并确保您始终捕获审核,即使服务超时也是如此。...一个简单示例,比如有事务ID,实体ID结构化日志以及定义策略能力,这些策略使您能够跟踪失败事务并由数据操作团队进行修复(这是非常关键)。...在这里,您不必先编写分布式事务在两个数据库中来创建新产品,而是首先只能在供应商数据库中编写并运行批处理以挑选100个新产品并将其插入到消费者数据库中。...对于订单微服务和库存微服务之间需要实现分布式事务,您可以使用以下设计以批处理替代: 在这里,您仍然可以进行扩展,隔离和独立部署,但是批处理过程将使其更加一致。

    51420

    业务服务价值在哪里

    对于业务服务描述,我直接借用了描述用户故事格式。一方面,这一格式要素直接涵盖了业务服务角色与领域行为,另一方面还能促使编写人员思考它带来服务价值。 我之引入触发事件,与业务服务定义息息相关。...如此一来,对于业务服务流程而言,一定是在收到服务请求之后开始执行一系列连续业务过程。因此,在业务服务基本流程与替代流程中,根本不可能出现UI操作,更不可能出现线下流程。...按照我经验,业务服务执行流程第一步,往往是对服务请求验证。至于服务请求包含哪些内容,则可以认为是对应服务契约输入参数。...04 业务服务价值 在我领域驱动设计统一过程方法中,产生设计驱动力就是业务服务。...业务服务强调执行连续性,又突出了目标系统边界,并由限界上下文来响应角色发起服务请求,将其映射到解空间,站在服务设计视角,就是一个服务API,我将其称之为“服务契约”。

    1.9K20
    领券