前言
这是一篇用Spring和Jencks
实现的轻量级解决方案,不依赖于应用服务器。本文是方案实现的记录,不涉及理论探讨,有关理论资源请参见本文的《解读
》和参考资料。有关多数据库的分布式事务的实践,请参见Spring JTA应用
。
思路
- Jencks提供事务管理器(Transaction Manager)和连接管理器(ConnectionManager);
- Jackrabbit的jca包提供JCR的托管连接工厂(ManagedConnectionFactory);
- Jencks为Hibernate提供支持托管连接(ManagedConnenction)的数据源(DataSource);
- Spring提供JTA的集成。
Bean依赖关系图
XML配置片段
Hibernate片段
<!-- 数据源 -->
<bean id="jdbcManagedConnectionFactory" class="org.jencks.tranql.DataSourceMCF">
<property name="driverName" value="${jdbc.driverClassName}" />
<property name="url" value="${jdbc.url}" />
<property name="user" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
</bean>
<bean id="dataSource" class="org.jencks.factory.ConnectionFactoryFactoryBean">
<property name="managedConnectionFactory" ref="jdbcManagedConnectionFactory" />
<property name="connectionManager">
<bean parent="connectionManager" />
</property>
</bean>
<!-- 会话工厂 -->
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
<property name="jtaTransactionManager">
<bean factory-bean="transactionManager" factory-method="getTransactionManager" />
</property>
<property name="hibernateProperties">
<util:properties location="classpath:/hibernate.properties" />
</property>
<property name="packagesToScan" value="zhongl.demo.transaction" />
<property name="dataSource" ref="dataSource" />
</bean>
<!-- 数据访问编程模板 -->
<bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">
<property name="sessionFactory" ref="sessionFactory" />
</bean>
注:上面需要spring-util命名空间支持。
Jackrabbit片段
<!-- JCR模板 -->
<bean id="jcrTemplate" class="org.springmodules.jcr.JcrTemplate">
<property name="allowCreate" value="true" />
<property name="sessionFactory">
<ref local="jcrSessionFactory" />
</property>
</bean>
<!-- 会话工厂 -->
<bean id="jcrSessionFactory" class="org.springmodules.jcr.JcrSessionFactory">
<property name="credentials">
<bean class="zhongl.demo.transaction.CredentialsFactoryBean" />
</property>
<property name="repository">
<ref local="repository" />
</property>
</bean>
<!-- Jackrabbit库 -->
<bean id="repository"
class="org.springframework.jca.support.LocalConnectionFactoryBean">
<property name="managedConnectionFactory">
<ref local="repositoryManagedConnectionFactory" />
</property>
<property name="connectionManager">
<bean parent="connectionManager" />
</property>
</bean>
<bean id="repositoryManagedConnectionFactory"
class="zhongl.demo.transaction.JCAManagedConnectionFactoryFactoryBean">
<property name="homeDir" value="file:${repository.home}_jta" />
<property name="configFile" value="classpath:${repository.configuration}" />
</bean>
注:
CredentialsFactoryBean和JCAManagedConnectionFactoryFactoryBean是为了配置方便,自定义实现的。
JTA的片段
<!-- 事务管理器 -->
<bean id="transactionManager"
class="org.springframework.transaction.jta.JtaTransactionManager">
<property name="userTransaction">
<ref local="delegateTransactionManager" />
</property>
</bean>
<bean id="delegateTransactionManager" class="org.jencks.factory.TransactionManagerFactoryBean" />
<!-- 连接管理器 -->
<bean id="connectionManager" class="org.jencks.factory.ConnectionManagerFactoryBean" abstract="true">
<property name="transactionManager">
<ref local="delegateTransactionManager" />
</property>
<property name="transaction" value="xa" />
</bean>
Spring注解支持片段
<!-- 自动扫描装配组件 -->
<context:component-scan base-package="zhongl.demo.transaction" />
<!-- 加载参数文件 -->
<context:property-placeholder location="classpath:/jdbc.properties,classpath:/jackrabbit.properties" />
<!-- 注解驱动事务配置 ,transactionManager省略为默认配置 -->
<tx:annotation-driven />
注:关于注解细节请详细参见
Sping2.5的参考手册
。
上述配置所需的依赖包和版本如下:
- jcr 1.0
- jackrabbit-core 1.5.0
- jackrabbit-jca 1.5.0
- hibernate 3.2.0.ga
- hibernate-annotations 3.2.0.ga
- jencks 2.1
- tranql-connector 1.4
- spring 2.5.6
- spring-modules-jcr 0.9
完整示例代码
参考资料
-
事务服务浅析上
-
事务服务浅析下
-
理解JCA事务
-
理解 JTS ― 幕后魔术
- 大小: 68.9 KB
分享到:
相关推荐
哲克定律(Jencks' Law)在消毒中涉及的是不同类型的消毒剂对微生物的杀灭效率与剂量之间的关系。例如,氯消毒时,氯的浓度和接触时间决定了消毒效果。 二、氯消毒法 氯消毒是最常见的水处理消毒方法之一,因为氯...
Jencks,1972;Jensen,1973;Moos & Insel,1974;Schulman,1970;Walberg,1971 )。 环境研究综述(例如,Bloom, 1964; Dave, 1963; Marjoribanks, 1972a; Mosychuk, 1969; Plowden, 1967; Vernon
一些调查可能过于悲观(Jencks,1972),并且当黑人儿童获得非常早期的学前教育时,有希望的教育结果是可行的,前提是这些计划包括父母和社区资源参与和参与以及教育程序通过在丰富课程完成后与儿童一起工作的教师...
病人跟踪治疗信息管理系统采用B/S模式,促进了病人跟踪治疗信息管理系统的安全、快捷、高效的发展。传统的管理模式还处于手工处理阶段,管理效率极低,随着病人的不断增多,传统基于手工管理模式已经无法满足当前病人需求,随着信息化时代的到来,使得病人跟踪治疗信息管理系统的开发成了必然。 本网站系统使用动态网页开发SSM框架,Java作为系统的开发语言,MySQL作为后台数据库。设计开发了具有管理员;首页、个人中心、病人管理、病例采集管理、预约管理、医生管理、上传核酸检测报告管理、上传行动轨迹管理、分类管理、病人治疗状况管理、留言板管理、系统管理,病人;首页、个人中心、病例采集管理、预约管理、医生管理、上传核酸检测报告管理、上传行动轨迹管理、病人治疗状况管理,前台首页;首页、医生、医疗资讯、留言反馈、个人中心、后台管理、在线咨询等功能的病人跟踪治疗信息管理系统。在设计过程中,充分保证了系统代码的良好可读性、实用性、易扩展性、通用性、便于后期维护、操作方便以及页面简洁等特点。
liunx project 5
分享课程——PostgreSQL DBA实战视频教程(完整10门课程合集)
计算机科学基础期末考试试题
练习与巩固《C语言程序设计》理论知识,通过实践检验和提高实际能力,进一步培养自己综合分析问题和解决问题的能力。掌握运用C语言独立地编写调试应用程序和进行其它相关设计的技能。
1. 数据集资源 公开低光照数据集:用于模型训练的低光照图像数据集,这些数据集包含了多种低光照条件下的图像,并附有增强后的高质量图像。 合成数据:在不足数据的情况下,可以通过对高亮度图像进行暗化处理生成低光图像对,以增强数据量。 自建数据集:对于特定场景,如安防、医疗等,可以拍摄或收集特定条件下的低光照图像来创建数据集,满足特定应用需求。 2. 硬件资源 GPU:大规模模型训练需要高性能计算,以支持大规模图像处理和神经网络训练。 数据存储:由于图像数据较大,需要大容量的存储设备如HDD或SSD来存储数据集及中间结果。 3. 深度学习框架及工具 PyTorch:支持构建和训练神经网络模型,尤其适合卷积神经网络(CNN)和生成对抗网络(GAN)的实现。 CUDA和cuDNN:为GPU加速库,在模型训练时可显著提升运行效率。
双哥微服务
fb000f5e-12c5-a46b-102a-f08bdfa015f1.json
ASP.NET跑腿服务网站源码 开发环境 :Asp.net + VS2010 + C# + ACCESS 网站介绍: 适合人群:跑腿服务行业公司,服务资讯公司或者其他行业企业、 做服务行业建站的技术人员、技术人员学习参考都行。 技术特点:非常清爽大气的网站,界面华丽,工整,采用全div布局, 含flash图片切换功能,强大的后台信息管理功能。 功能介绍: 后台功能:系统参数设置(网站标题,关键字,内容,站长联系方式等)、系统栏目频道设置、新闻管 理、服务项目管理、公司介绍内容管、系统模版管理(可管理前台页面模版内容,具体到头部页面,底 部页面,首页,内容页,新网页等)、系统日志管理、系统管理员管理、频道管理(频道类型、频道内 容、内容发布以及编辑)。 后台地址:网址/admin/login.aspx 账户:admin 密码:admin888
c语言
环境说明: 开发语言:Java/php JDK版本:JDK1.8 数据库:mysql 5.7及以上 数据库工具:Navicat11及以上 开发软件:eclipse/idea 小程序框架:uniapp/原生小程序 开发工具:HBuilder X/微信开发者
人工智能(Artificial Intelligence,缩写为AI)是一种通过计算机程序模拟人类智能与行为的技术和理论。它可以用于各种领域,例如:自动驾驶、机器翻译、语音识别、图像识别、医疗诊断等。近年来,人工智能逐渐成为了技术界和商业领域的热门话题。
c语言
基于JAVA实现的离散数学题库管理系统
Matlab领域上传的视频均有对应的完整代码,皆可运行,亲测可用,适合小白; 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作
# 基于C++的MiniSQL数据库系统 ## 项目简介 MiniSQL是一个轻量级的关系型数据库管理系统,旨在提供基本的SQL解析和执行功能。该项目参考了CMU15445 BusTub框架,并在其基础上进行了修改和扩展,以兼容原MiniSQL实验指导的要求。MiniSQL支持缓冲池管理、索引管理、记录管理等核心功能,并提供了简单的交互式SQL解析和执行引擎。 ## 项目的主要特性和功能 1. 缓冲池管理实现了一个高效的缓冲池管理器,用于缓存磁盘上的数据页,以提高数据访问速度。 2. 索引管理支持B+树索引,提供高效的插入、删除和查找操作。 3. 记录管理实现了记录的插入、删除、更新和查询功能,支持持久化存储。 4. 元数据管理提供了表和索引的元数据管理功能,支持持久化存储和检索。 5. 并发控制实现了基本的锁管理器,支持事务的并发控制。 6. 查询执行提供了简单的查询执行引擎,支持基本的SQL语句解析和执行。 ## 安装使用步骤