博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
分布式事务系列(开篇)提出疑问和研究过程
阅读量:6552 次
发布时间:2019-06-24

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

hot3.png

#1 前言

系列目录

对于我们这种初学者,可能会使用spring带给我们的@Transactional,可能了解JTA,可能会使用jotm、atomikos,又会遇到一些名词XA,支持XA的数据库驱动等等诸多问题,然后就会愈加混乱,自然形成一个疑问,庞大的事务体系的全貌到底是什么样?

#2 需要解决的疑惑

下面就要具体列出一系列需要解决的问题

##2.1 对于事务模型

  • 三种事务模型是什么?各自的特点是什么?各自的缺陷是什么?

##2.2 spring对于事务模型的支持

  • spring自己的一系列接口设计:

    • PlatformTransactionManager 事务管理器
    • TransactionDefinition 事务定义
    • TransactionStatus 事务状态

    等等

  • 上述一系列接口的实现是如何对非分布式和分布式事务的支持的呢?

##2.3 针对分布式事务的规范

  • X/Open DTP模型是什么?几个重要的概念是什么?

  • XA规范是什么?

  • 2PC是什么?

##2.4 针对JTA

  • JTA是什么?JTS又是什么?

  • JTA与上述的规范又是什么关系?

  • JTA的接口都有哪些?分别是什么作用

  • JTA接口中有一个javax.transaction.TransactionManager,如何理解它与上述的PlatformTransactionManager呢?即它们各自的职责是什么?

##2.5 对于JTA实现

  • 分布式事务需要数据库和驱动程序支持的吗?还是使用一般的数据库和驱动程序也可以实现分布式事务?

  • XADataSource与DataSource、XAConnection与Connection等等接口

  • 某些应用服务器没有实现JTA,如tomcat,某些应用服务器实现了JTA,如JBoss,具体是怎么实现的呢?

  • jotm、atomikos又是怎么来实现JTA的呢?需不需要数据库和驱动程序对XA的支持?

  • 2PC对于初学者经常沦为一种概念,在代码中是如何体现的呢?如何模拟2PC呢?

#3 研究过程

先从非分布式事务开始,趁机理解Spring对于事务的支持原理,然后过渡到分布式事务,理解分布式事务的概念,源码分析分布式事务框架jotm、atomikos,理解它们实现分布式事务的原理。

##3.1 非分布式事务

  • 1 jdbc事务开发的缺点
  • 2 spring实现的编程式事务原理
  • 3 spring利用AOP实现的声明式事务的接口设计与实现原理,为后面与jotm、atomikos的集成做铺垫
  • 4 深刻理解了上面的例子后,再来看事务的三种模型,各自的特点、各自的缺陷

##3.2 分布式事务的一系列概念

  • 1 X/Open DTP模型、XA规范、2PC
  • 2 JTA、JTS概念
  • 3 JTA接口定义的理解

##3.3 JTA的实现

  • 1 jotm的例子,以及源码分析实现分布式事务的原理(如何体现2PC的过程)
  • 2 atomikos对非XADataSource和XADataSource的支持的例子,以及源码分析实现分布式事务的原理(如何体现2PC的过程)
  • 3 JBoss支持分布式事务的原理

#4 结束语

我也是最近才开始接触下分布式事务,很多内容也都没弄清楚,有些地方难免第一次认识错误,还请批评指正。像我一样对整个事务体系不是很了解的同学可以一起来研究讨论,共同进步。

转载于:https://my.oschina.net/pingpangkuangmo/blog/413518

你可能感兴趣的文章
使用python制作时间戳转换工具
查看>>
Drools实战系列(三)之eclipse创建工程
查看>>
Android利用Cookie实现码源登录效果
查看>>
****timeago.js插件:jquery实现几分钟前、几小时前、几天前等时间差显示效果的代码实例...
查看>>
我常用的命令
查看>>
tengine+tomcat+php安装
查看>>
第 45 章 HyperDex
查看>>
会议室预定系统实践(轻松解放开发) - PostgreSQL tsrange(时间范围类型) + 排他约束...
查看>>
Centos6安装SaltStack
查看>>
世纪互联发布全新云战略,打造混合IT服务平台
查看>>
关于在angular2及以上版本引入bootstrap 并有提示功能
查看>>
十三、rsync+inotify的使用
查看>>
浅说RAID和LVM
查看>>
Spring Cloud微服务分布式云架构-集成项目
查看>>
namenode与secondary namenode简要学习
查看>>
软件测试人员的进击
查看>>
10.26 unit介绍
查看>>
开源博客markdown插入表格语法
查看>>
Linux监控平台介绍,zabbix监控介绍,安装zabbix,忘记Admin密码如何做
查看>>
公众号消息会话开发
查看>>