atomikos JTA 源码解读

2024-03-03 12:48
文章标签 源码 解读 jta atomikos

本文主要是介绍atomikos JTA 源码解读,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一.DataSource


1.AbstractDataSourceBean  是抽象方法,统一实现了ConnectionPoolProperties接口,及HeuristicDataSource接口,用于设置数据源的属性及进行数据源连接(调用ConnectionPool)

除上面的功能外,他还可以进行数据源连接池的管理,主要的方法有:

intcom.atomikos.jdbc.AbstractDataSourceBean.poolAvailableSize()              连接池中可用(已创建空闲的)的连接数量

intcom.atomikos.jdbc.AbstractDataSourceBean.poolTotalSize()                    连接池中总连接数量(正在使用+空闲)

voidcom.atomikos.jdbc.AbstractDataSourceBean.refreshPool()                    刷新连接池,会把没有正在使用的连接销毁掉,如果销毁后的连接数小于最小连接池的数量,将新建连接到达到最小数量的要求

AtomikosDataSourceBean                       分布式数据源

AtomikosNonXADataSourceBean     非分布式数据源

 

2.相关属性:对应到美创CRM

<datasource>

         <id>default</id>

         <driver-class>oracle.jdbc.driver.OracleDriver</driver-class>

         <url>jdbc:oracle:thin:@192.168.1.201:1521:orcl</url>

         <user>xxx</user>

         <password>xxx</password>

         <min-pool-size>3</min-pool-size>

         <max-pool-size>10</max-pool-size>

         <max-lifetime>0</max-lifetime>                                                                      <!--连接最大存活时间,超过这个且没有正在使用的连接将自动销毁,0无限制,1000 =1000s,对于一些会自动中断连接的数据库如mysql,可以设置这个参数,在达到这个时间的时候会自动关闭连接,下次数据库调用的时候就会新建-->

         <borrow-connection-timeout>30</borrow-connection-timeout>  <!--获取连接失败重新获等待最大时间,在这个时间内如果有可用连接,将返回-->

         <!--default-isolation-level>-1</default-isolation-level--> 

         <login-timeout>0</login-timeout>                                                         <!--java数据库连接池,最大可等待获取datasouce的时间-->

         <maintenance-interval>60</maintenance-interval>                                  <!--连接回收时间-->

         <max-idle-time>60</max-pool-size>                                                               <!--最大闲置时间,超过最小连接池连接的连接将将关闭-->

         <reap-timeout>0</reap-timeout>                                                                   <!--最大获取数据时间,如果不设置这个值,Atomikos使用默认的5分钟,那么在处理大批量数据读取的时候,一旦超过5分钟,就会抛出类似 Resultset is close 的错误.-->

</datasource>         

 

 

 

二. com.atomikos.datasource.pool.ConnectionPool 连接池具体实现类

1.voidcom.atomikos.datasource.pool.ConnectionPool.launchMaintenanceTimer()连接池回收处理定时器,会根据maintenanceinterval设置的重复时间进行重复执行,每次执行会:

1)reapPool        是否有超过最大数据获取时间的连接,如果有,这抛出获取时间超时的异常

2)removeConnectionsThatExceededMaxLifetime  删除超过最大生命周期的没有正在使用的连接

3)addConnectionsIfMinPoolSizeNotReached           添加连接数达到最小连接

removeIdleConnectionsIfMinPoolSizeExceeded  删除连接数,如果超过最大连接

 

2. 获取连接

Reapablecom.atomikos.datasource.pool.ConnectionPool.borrowConnection(HeuristicMessagehmsg) throws CreateConnectionException, PoolExhaustedException,ConnectionPoolException

获取连接的时候首先调用

findExistingOpenConnectionForCallingThread 直接获取连接,如果获取失败将调用

findOrWaitForAnAvailableConnection根据borrowTimeout进行等待,如果在borrowTimeout时间内有连接处于可用(未超过最大连接将创建)将立即返回,否则将抛出异常

Connection pool exhausted - try increasing'maxPoolSize' and/or 'borrowConnectionTimeout' on the DataSourceBean

 

3.销毁连接

voidcom.atomikos.datasource.pool.ConnectionPool.destroyPooledConnection(XPooledConnectionxpc)

 

4. voidcom.atomikos.datasource.pool.ConnectionPool.growPool() throws CreateConnectionException

连接不足时创建连接

5. voidcom.atomikos.datasource.pool.ConnectionPool.refresh()

刷新连接池,同AbstractDataSourceBean.refreshPool()     

6.intcom.atomikos.datasource.pool.ConnectionPool.availableSize()

可用的连接数

7.intcom.atomikos.datasource.pool.ConnectionPool.totalSize()

总连接数

 

三、事务超时管理:

com.atomikos.icatch.imp.CoordinatorImp在这个里面会启用的一个定时器,后台管理事务

voidcom.atomikos.icatch.imp.ActiveStateHandler.onTimeout()事务超时的时候会执行这个方法进行回滚

 

更多atomikos 分析请参考豆蔻网上的文章:http://exception.handlecode.com/share/1038187.html


四、属性加载方法:

Properties com. atomikos. icatch. config. UserTransactionServiceImp.findProperties()

五、同一个tomcat 不同的应用需要修改配置,否则出现异常

Caused by: com.atomikos.persistence.LogException: Old file could not be deleted
at com.atomikos.persistence.imp.FileLogStream.writeCheckpoint(FileLogStream.java:168)
... 48 more


解决方法,设置属性:
com.atomikos.icatch.console_file_name = tm_api.out
com.atomikos.icatch.log_base_name = tmlog_api

属性可以是 jta.properties 放置到classpath,或者设置一个环境变量

System.setProperty("com.atomikos.icatch.file", sc.getRealPath("WEB-INF/config/atomikos-jta.properties"));





这篇关于atomikos JTA 源码解读的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/769668

相关文章

解读GC日志中的各项指标用法

《解读GC日志中的各项指标用法》:本文主要介绍GC日志中的各项指标用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、基础 GC 日志格式(以 G1 为例)1. Minor GC 日志2. Full GC 日志二、关键指标解析1. GC 类型与触发原因2. 堆

Java设计模式---迭代器模式(Iterator)解读

《Java设计模式---迭代器模式(Iterator)解读》:本文主要介绍Java设计模式---迭代器模式(Iterator),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录1、迭代器(Iterator)1.1、结构1.2、常用方法1.3、本质1、解耦集合与遍历逻辑2、统一

MySQL之InnoDB存储页的独立表空间解读

《MySQL之InnoDB存储页的独立表空间解读》:本文主要介绍MySQL之InnoDB存储页的独立表空间,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、独立表空间【1】表空间大小【2】区【3】组【4】段【5】区的类型【6】XDES Entry区结构【

MySQL主从复制与读写分离的用法解读

《MySQL主从复制与读写分离的用法解读》:本文主要介绍MySQL主从复制与读写分离的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、主从复制mysql主从复制原理实验案例二、读写分离实验案例安装并配置mycat 软件设置mycat读写分离验证mycat读

Python的端到端测试框架SeleniumBase使用解读

《Python的端到端测试框架SeleniumBase使用解读》:本文主要介绍Python的端到端测试框架SeleniumBase使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全... 目录SeleniumBase详细介绍及用法指南什么是 SeleniumBase?SeleniumBase

Nacos注册中心和配置中心的底层原理全面解读

《Nacos注册中心和配置中心的底层原理全面解读》:本文主要介绍Nacos注册中心和配置中心的底层原理的全面解读,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录临时实例和永久实例为什么 Nacos 要将服务实例分为临时实例和永久实例?1.x 版本和2.x版本的区别

C++类和对象之默认成员函数的使用解读

《C++类和对象之默认成员函数的使用解读》:本文主要介绍C++类和对象之默认成员函数的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、默认成员函数有哪些二、各默认成员函数详解默认构造函数析构函数拷贝构造函数拷贝赋值运算符三、默认成员函数的注意事项总结一

MySQL的ALTER TABLE命令的使用解读

《MySQL的ALTERTABLE命令的使用解读》:本文主要介绍MySQL的ALTERTABLE命令的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、查看所建表的编China编程码格式2、修改表的编码格式3、修改列队数据类型4、添加列5、修改列的位置5.1、把列

Linux CPU飙升排查五步法解读

《LinuxCPU飙升排查五步法解读》:本文主要介绍LinuxCPU飙升排查五步法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录排查思路-五步法1. top命令定位应用进程pid2.php top-Hp[pid]定位应用进程对应的线程tid3. printf"%

解读@ConfigurationProperties和@value的区别

《解读@ConfigurationProperties和@value的区别》:本文主要介绍@ConfigurationProperties和@value的区别及说明,具有很好的参考价值,希望对大家... 目录1. 功能对比2. 使用场景对比@ConfigurationProperties@Value3. 核