云计算的设计模式(三)——补偿交易模式

云计算的设计模式(三)——补偿交易模式

撤消由一系列的步骤,它们共同限定了终于一致性操作中,假设一个或多个步骤失败运行的工作。依照终于一致性模型,业务实现复杂的业务流程和工作流的云托管的应用程序中非经常见。

背景和问题

在云中运行的应用程序频繁改动数据。

此数据可跨在各种地理位置的所保持的数据源的一个品种传播。

为了避免争用,并提高在分布式环境中,比如这种性能,应用程序不应该试图提供强事务一致性。相反,应用程序应该实现终于一致性。

在该模型中,一个典型的业务操作由一系列的独立的步骤。而正在运行这些步骤的系统状态的总体图可能是不一致的。可是,当操作完毕而且全部步骤都被运行。系统应该又一次变得一致。

注意:

数据的一致性提供了入门为什么分布式事务不能非常好地扩展很多其它的信息,而且巩固了终于一致性模型的原则。

在终于一致性模型的一个显著的挑战是怎样处理失败无可挽回的一步。在这样的情况下,可能须要撤消全部通过的操作中的前面的步骤完毕的工作。然而,数据不能简单地被回滚,由于应用程序的其他并发实例可能已经改变,由于它。即使在数据没有被通过一并发实例变更的情况下。撤消一个步骤可能不是简单地恢复原始状态的问题。可能须要应用不同的业务特定的规则(參见实施例部分中描写叙述的旅行站点)。

假设实现终于一致性操作跨越多个异构数据存储。解开在这种操作中的步骤将须要訪问的每个数据存储区中的转弯。在每个数据存储区运行的工作必须可靠地复原到防止系统其余不一致。

不受实现终于一致性的操作的全部数据可能会在数据库中进行。

在面向服务的架构(SOA)环境中的操作可能会调用一个服务动作,并导致由该服务保持状态的变化。

要撤消的操作,这样的状态的改变也必须是百废待兴。这可能涉及再次调用服务并运行该反转第一的影响还有一个动作。

解决方式

落实补偿事务。在一个补偿事务的步骤必须撤消的原始操作的步骤的影响。

补偿事务可能无法简单地与国家的制度在执行,由于这样的方法可能会覆盖由应用程序的其它并发实例所做的更改開始代替眼下的状态。

相反,它必须是一个聪明的过程中。考虑到并发情况下进行的不论什么工作。这个过程一般是应用程序特定的,由原始操作所执行的工作的性质来驱动。

一种常见的方法来实现的,终于一致的操作。须要补偿的是使用的工作流。因为原来的动作的进行。系统记录每一个步骤,以及怎样通过该步骤完毕的工作能够撤消信息。

假设操作失败,在不论什么时候,在工作流倒卷回通过它已经完毕的步骤。并运行反转每一个步骤的工作。注意。补偿事务可能没有撤消的原始操作的精确镜面相反的顺序工作,而且它可能会运行一些并行撤销步骤。

注意:

这样的方法类似于英雄传奇策略。

这一战略的描写叙述是克莱门斯Vasters的博客在网上提供。

补偿事务本身是一个终于一致的操作。它也可能会失败。该系统应可以恢复补偿事务在故障点并继续。

可能有必要反复发生问题的步骤,所以在补偿事务的步骤应该被定义为幂等的命令。有关幂等的具体信息,请參阅乔纳森·奥利弗的博客幂等模式??。

在某些情况下,可能无法从该已失败,除非通过人工干预的步骤中恢复。

在这样的情况下,系统应发出警报,并提供尽可能多的信息尽可能了解失败的原因。

问题和注意事项

在决定怎样实现这个模式时,请考虑下面几点:

?它可能不easy确定何时在实现终于一致性的动作的步骤已经失败。一个步骤可能不会马上失败,而是它能够阻止。

可能有必要实现某种形式的超时机制。

?补偿逻辑不easy推广。补偿事务是特定于应用程序;它依赖于具有足够的信息。以便可以撤消在一个失败的操作的每一个步骤的效果的应用。

?您应该定义的步骤在补偿事务的幂等命令。这使得,假设补偿事务本身不能被反复的步骤。

?处理中原始操作的步骤。以及所述补偿事务的基础设施。必须是有弹性的。它一定不能失去,以补偿发生问题的步骤所须要的信息,并且它必须可以可靠地监视补偿逻辑的进度。

?一个补偿事务并不一定在系统中返回数据的状态是在原操作的開始。

相反。它补偿了由该成功完毕操作失败之前的步骤中运行的工作。

?在补偿事务中的步骤的顺序并不一定是反射镜相反的,在原来的操作的步骤。比如。一个数据存储能够是不一致比还有一个更敏感,从而撤消更改到该商店中的补偿事务的步骤应首先发生。

?在完毕操作所需的每一个资源放置一个短期的基于超时的锁,并提前获得这些资源,能够帮助添加的可能性。总体活动将取得成功。这项工作应运行的全部资源都被收购之后。

全部操作必须完毕的锁到期之前。

?考虑使用重试逻辑比寻常很多其它的宽容。尽量降低触发补偿事务失败。假设一个操作步骤。实现终于一致性失败,请尝试处理故障为一过性异常,并重复上述步骤。仅仅有放弃操作。假设一个步骤重复或无可挽回地失败,启动补偿事务。

注意:

非常多的挑战和实施补偿事务的问题是一样关心实现终于一致性。请參见注意事项实现了数据的一致性入门终于一致性的很多其它信息。

当使用这个模式

使用此模式仅适用于假设他们失败。必须撤销的操作。

假设可能的话,设计解决方式,避免了须要补偿事务的复杂性(有关具体信息,请參阅数据一致性底漆)。

样例

一个旅游站点。使客户预订行程。

一个单一的行程可包含一系列航班和酒店的。一位顾客旅行从西雅图到伦敦及巴黎能够创建一个行程时,请运行下面步骤:

1.预订一个座位上的F1航班从西雅图飞往伦敦。

2.预订一个座位上的F2航班从伦敦到巴黎。

3.书本占座F3航班从巴黎飞往西雅图。

4.预订的房间在伦敦酒店H1。

5.预订在巴黎一间客房的酒店H2。

这些步骤构成了终于一致的操作,尽管每一步基本上是在自己的权利单独的原子操作。因此,以及在运行这些步骤时,系统还必须记录必要撤消各以防客户决定取消行程步骤计数器的操作。必要运行计数器操作步骤。然后能够作为一个补偿事务如有必要运行。

请注意,在补偿事务中的步骤可能不是原来的步骤全然相反,而且在补偿事务的每一个步骤必须考虑到不论什么特定于业务的逻辑规则。比如。“unbooking取消预订”座位上的飞行可能不是客户有权向支付不论什么款项完毕退款。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQveWFuZ3poZW5waW5n/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center">

图1 - 生成一个补偿事务撤消一个长时间执行的事务预订旅游行程

Note:

它可能会在并行运行的补偿事务的步骤。这取决于你怎样设计每一步的补偿逻辑。

在很多商业解决方式。在单步的故障不总是必要轧制系统背面用补偿事务。比如,具有在旅游站点的情况。客户是无法预订到酒店H1预订航班F1,F2和F3的话。以后。最好是提供客户在同一个城市的房间在不同的酒店而不是取消航班。客户仍然能够选择取消(在这样的情况下,补偿事务执行。并撤消作出关于航班F1,F2和F3中的预订)。但这个决定应该由客户而不是由系统进行。

本文翻译自MSDN:http://msdn.microsoft.com/en-us/library/dn589804.aspx

时间: 2024-08-26 13:21:36

云计算的设计模式(三)——补偿交易模式的相关文章

云计算设计模式(三)——补偿交易模式

云计算设计模式(三)--补偿交易模式 撤消由一系列步骤,它们共同限定了最终一致性操作中,如果一个或多个步骤失败执行的工作.按照最终一致性模型,业务实现复杂的业务流程和工作流的云托管的应用程序中很常见. 背景和问题 在云中运行的应用程序频繁修改数据.此数据可跨在各种地理位置的所保持的数据源的一个品种传播.为了避免争用,并提高在分布式环境中,例如这样的性能,应用程序不应该试图提供强事务一致性.相反,应用程序应该实现最终一致性.在该模型中,一个典型的业务操作由一系列的独立的步骤.而正在执行这些步骤的系

设计模式三—抽象工厂模式

设计模式三-抽象工厂模式 一.定义 抽象工厂模式是工厂方法模式的进一步抽象.如果产品簇中只有一种产品,则退化为工厂方法模式. 二.原理图 三.代码实例 * 苹果和土豆是园丁1的杰作 * 葡萄和西红柿是园丁2的杰作 1.Fruit.java public interface Fruit { /* * 生长 * 收获 * 栽种 */ public void grow(); public void harvest(); public void plant(); } 2.Apple.java publi

Java经典23结构模型的设计模式(三)------附加代理模式、适配器型号、Facade模式的差异

本文介绍了7样的结构模型中的其余2种:轻量级.代理模式. 一.享元模式FlyWeight 享元模式比較简单且重要,在非常多场合都被用到.仅仅只是封装起来了用户看不到.其概念:运用共享内存技术最大限度的支持大量细粒度的对象. 这个概念给的有些抽象,说白了就是假设内存中存在某个对象A.假设再次须要使用对象A的时候假设内存中有A这个对象就直接使用它,不要再次new了.假设没有,则又一次new一个.基于这个特点,享元模式使用时通常会给待訪问对象传递一个Tag,用来标识这个对象,并且要同一时候使用抽象工厂

设计模式—三种工厂模式(JAVA)

一:简单工厂: 有一个实际工厂,这个工厂只能造一类的产品,这一类产品就是一个产品接口,会有多个具体产品实现这个接口,例 如,一个手机厂,生产苹果手机,三星手机: 缺点:在工厂类中集中了所有实例的创建逻辑,违反了高内聚责任分配原则,将全部创建逻辑集中到了一个工厂类中:对系统的维护和扩展不利: 使用场景:负责创建的对象比较少:客户只知道传入工厂类的参数,对于如何创建对象的逻辑不关心:容易违反高内聚责任分配原则,所以只在很简单的情况下应用: package com.designPattern.simp

再战设计模式(三)之建造者模式

建造者模式 他的本质主要是: 分离了组件的构造(由builder来负责),和装配(由Director负责),从而构造出复杂的对象,这个模式使用于:某个对象构建过程复杂的情况下使用 建造模式可以将一个产品的内部表象(internal representation)与产品的生产过程分割开来,从而可以使一个建造过程生成具有不同的内部表象的产品对象. 由于实现了构建和装配的解耦.不同的构建器和不同的装配器 可以组合成很多不同的对象.也就是实现了构建算法.装配 算法的解耦,实现了更好的复用 场景: 在日常

云计算三种服务模式SaaS、PaaS和IaaS及其之间关系(顺带CaaS、MaaS)

云计算架构图 很明显,这五者之间主要的区别在于第一个单词,而aaS都是as-a-service(即服务)的意思,这五个模式都是近年来兴起的,且这五者都是云计算的落地产品,所以我们先来了解一下云计算是什么. 1.云计算是什么?云计算(cloud computing)是基于互联网的相关服务的增加.使用和交付模式,通常涉及通过互联网来提供动态易扩展且经常是虚拟化的资源.云是网络.互联网的一种比喻说法.云计算甚至可以让你体验每秒10万亿次的运算能力,拥有这么强大的计算能力可以模拟核爆炸.预测气候变化和市

初识云计算的三种服务模式 (IaaS SaaS PaaS)

最近公司在使用其他云服务的同时,要封装自己的云服务,下面作为开发产品前的热身,来了解云计算中的三种服务模式,笔者也是从网络上查找,进行综合总结.请拍.. 三种服务模式 根据现在最常用,也就是比较权威的NIST(National Institute of Standard and Technology)美国国家标准技术研究院定义,云计算主要分为三种服务模式,而且这三层的分法重要是从用户体验的角度出发的: IaaS IaaS全拼是Infrastructure as a Service,基础设置即服务

js架构设计模式——你对MVC、MVP、MVVM 三种组合模式分别有什么样的理解?

你对MVC.MVP.MVVM 三种组合模式分别有什么样的理解? MVC(Model-View-Controller)MVP(Model-View-Presenter)MVVM(Model-View-ViewModel)请大家谈一谈各自的理解吧,对比之下更能明确特征和适用的范围,菜鸟们畅所欲言,老鸟大牛们请多多指点! 2 条评论 按投票排序 按时间排序 10 个回答 王韦恩卑鄙,我编程序,我约. 知乎用户.里德.jogen 等人赞同 只是一点浅见啊 折叠也活该... M-V- X 本质都是一样的

Java经典23种设计模式之行为型模式(三)

本文接着介绍11种行为型模式里的备忘录模式.观察者模式.状态模式. 一.备忘录模式 在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态.这样以后就可以将该对象恢复到原先保存的状态.还是比较好理解的. 1.Memento 备忘录存储原发器对象的内部状态,这个类就是要存储的对象的状态.状态需要多少个变量,在Memento里就写多少个变量. public class Memento { private String state; public Meme*to(String st