博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
基于母体思想的统一事务架构
阅读量:2268 次
发布时间:2019-05-09

本文共 1221 字,大约阅读时间需要 4 分钟。

    因为我最近需要在不大规模改变原应用代码情况下,将两个庞大的事务合并成一个统一事务,所以弄了个基于享元模式的母体架构。

 

    原两个事务分别在Matrix1Matrix2两个类中,每个类管理自己的完整业务和数据操作事务。即每个类有自己的属性对象ICommDataServer,这个类管理数据库连接、ORM、资源释放、与事务操作。而我必须在不破坏两个事务完整性的原则上做到统一事务。

 

    一、原应用中不同事务对象CommDataServer依赖不同业务对象Matrix

 

  

              

 

二、如果不考虑代码重构,这个统一事务架构可以设计为:

 

 

 

  MatrixManager统一事务管理类,控制业务调用、享元的创建、以及管理享元关联的事务生命周期。

 

  Matrix母体(业务类),实现自己的业务,并由享元RollbakMatrix实现事务管理。

 

  RollbakMatrix享元类,MatrixManager创建并以参数传递给各母体,并关联事务对象CommDataServer

 

 

     三、因为业务对象方法无法重载,所以我利用RollbakMatrix与业务类从依赖关系改成聚合关系。

 

  

   

 

       

 

    这样享元RollbakMatrix的创建和生命周期控制还是由MatrixManager控制。将享元以属性的形式聚合到业务类中。这样实现在享元模式(MatrixManager创建RollbakMatrik实例)与非享元模式(不创建实例)两种模式下主业务都是一致的。

 

    四、因为业务中各有各的事务对象CommDataServer,所以我增加CommDataServer与业务的双依赖关系,实现CommDataServer的虚构造(共享RollbakMatrix中的CommDataServer实例)。

 

   

 

                 

 

     原代码每个业务对象都有事务对象初始化引用(单依赖),这个架构不能变并且与新架构向违背。那就将这个业务对象也依赖事务对象好了。

CommDataServer构造时将母体参数传入,判断母体中是否有享元RollbakMatrix:如果有则标志着将使用统一事务处理,并返回享元中已关联的事务对象;如果没有则标志着不使用统一事务处理,保持原架构每个业务对象一个事务实例不变。

 

   

 

       

 

    五、重构后的关系图:

   

   

 

  

 

 

六、回顾整个架构

 

1、      事务对象CommDataServer成功地从各自业务对象中独立出来,并成为享元RollbakMatrix母体的寄体。

 

2、      RollbakMatrixMatrixManager,所有母体(业务对象)的享元;最终CommDataServer是多有母体的享元,并且也是MatrixManager享元,并由它控制生命周期。

 

3、      利用双向依赖,实现享元判断;而构造函数的重载,实现了CommDataServer在母体环境(作为享元)、非母体环境(作为独立事务对象)的复用;实际上整个架构也是利用RollbakMatrix这个即是母体有是寄体的享元来实现多业务(事务)的生命周期(事务)统一控制。

 

你可能感兴趣的文章
一篇文教你在 Java 中利用 redis 实现分布式全局唯一标识服务
查看>>
深入浅出数据库事务和4种隔离级别
查看>>
对限频限流的思考
查看>>
15天内4面阿里,成功拿下offer,分享个人面经
查看>>
万字长文,带你深入浅出五种负载均衡策略。
查看>>
看图搞懂微服务架构
查看>>
详解:java工具之解析yaml文件
查看>>
双非末流渣渣一本年初裸辞,5面阿里最终定级P7,扎心的辛酸历程
查看>>
包教包会:搭建RocketMQ双主双从同步集群,
查看>>
赞!期待已久的《架构解密:从分布式到微服务》终于出第2版了
查看>>
5年Java程序员,五面蚂蚁险拿offer定级P7,大厂面试不过如此?
查看>>
大厂面试必问!HashMap 怎样解决hash冲突?
查看>>
颠覆认知!阿里架构师居然是这样定义微服务、分布式构架构的
查看>>
面试屡屡碰壁,痛定思痛闭关修炼!半年后4面阿里成功拿offer
查看>>
幸亏阿里学长的这份Java多线程笔记,才能让我轻松拿下阿里一面
查看>>
最全的大厂最新面试249题与笔记总结:多线程+JVM +Spring+微服务+分布式+Redis+MySQL
查看>>
吊!设计模式全解:6大设计原则+23种设计模式+设计模式PK+设计模式混编
查看>>
服!看完阿里大牛手写的Java异步编程实战笔记,我惊呆了
查看>>
Java程序员跳槽,三面之后被拒,原因竟是“招不起”
查看>>
想要彻底搞懂微服务架构?必先学:SpringBoot+SpringCloud+docker
查看>>