需求是从sql2005读取数据,然后写到另外一个oracle库中,尝试过jotm和atomikos两种,很多人都说atomikos好些,但它对sql2005的支持好像不太好,配置后有些报错,官方文档所sql2005配置起来比较麻烦,需要在数据库端作配置的。
所以使用jotm,使用的版本是xapool-1.5.0。过程中遇到了一些问题,由于需要数据库遇到断网、数据库重启等情况后能自动重连,所以需要配置checkLevelObject,但配置了<property name="checkLevelObject"><value>3</value></property>之后,oracle端就遇到游标溢出的bug和数据库连接数一直增长的情况,要等很久才会释放的情况。
通过在网上的搜索,最后修改了源代码的2个地方:
org.enhydra.jdbc.standard.StandardConnectionPoolDataSource里的
public static final int DEFAULT_PREPAREDSTMTCACHESIZE = 16;
将16改为0,不缓存。
org.enhydra.jdbc.pool.GenericPool里的
public static final long DEFAULT_SLEEPTIME = 300000; // 5 minutes
将300000(5分钟)改为30000(30秒),DEFAULT_SLEEPTIME设置的是清除无用连接的间隔时间,30秒清除一次,那样连接数就不会一直增长而要等5分钟才释放。另外在配置文件里配置SLEEPTIME属性似乎无效,只能手工改源码的这个地方。
在附件里上传了一份我修改过后的1.5.0版本的xapool.jar
分享到:
相关推荐
在Spring中,Java Transaction API (JTA) 和 JOTM(Java Open Transaction Manager)是实现分布式事务管理的关键组件。 **Spring 框架** Spring 是一个开源的Java平台,它提供了一个全面的编程和配置模型,用于现代...
2.Spring+Jotm整合实现JTA分布式事务,应用场景如转账等,同一事务内完成db1用户加100元、db2用户减100元。 3.Spring+Junit4单元测试,优点:不会破坏数据库现场,等等。 (特别注意:Spring3.0里不在提供对jotm的...
本篇文章将详细讲解如何利用Spring+iBatis+JOTM来实现JTA事务。 首先,我们需要理解JTA的核心概念。JTA定义了一组接口和规范,允许应用程序在不同的事务边界之间进行协调,确保原子性和持久性。JOTM作为JTA的一个...
本教程将深入探讨如何使用Spring框架、Java Transaction API (JTA) 和 Java Open Transaction Manager (JOTM) 来实现这样的分布式事务管理。 首先,我们来了解一下JTA。JTA是Java平台的标准事务API,它允许应用程序...
本文将深入探讨如何使用Spring、Java Transaction API (JTA) 和 Java Object Transaction Manager (JOTM) 实现多数据源更新的解决方案。 首先,让我们理解什么是多数据源。在传统的单数据源环境中,应用程序通常...
本项目“spring+jotm+ibatis+mysql实现JTA分布式事务”旨在利用这些技术来确保在分布式环境中的数据一致性。下面将详细介绍这个项目所涉及的知识点。 首先,Spring框架是Java开发中最常用的应用框架之一,它提供了...
本文将深入探讨如何在Tomcat应用服务器上集成JTA,并使用JOTM(Java Open Transaction Manager)或Atomikos作为事务管理器来实现分布式事务。 首先,我们需要理解JTA的核心概念。JTA是Java EE平台的一部分,提供了...
小结 通过以上步骤,你已经在Spring中成功配置了JTA事务管理。无论是集成JOTM还是引用Tomcat内置的JTA支持,都能实现跨数据库的事务一致性。这在处理分布式系统或多数据源的应用中至关重要,因为它确保了即使在异常...
标题中的“spring 3.0.5 + jotm 实现的的spring mvc 的例子”表明这是一个关于使用Spring 3.0.5版本与JOTM(Java Open Transaction Manager)结合构建Spring MVC应用的示例项目。这个项目可能旨在演示如何在Spring ...
Spring框架作为一个广泛使用的Java应用程序开发框架,提供了多种支持事务管理的解决方案,其中包括集成JOTM(Java Open Transaction Manager)来处理分布式事务。本文将深入探讨Spring与JOTM结合使用的知识点,帮助...
在没有JOTM的情况下,Spring的`PlatformTransactionManager`接口通常会由`HibernateTransactionManager`实现。这个事务管理器会自动管理和协调Hibernate会话与事务之间的关系。 然而,要在Spring中引入JOTM,我们...
在本篇文章中,我们将深入探讨如何利用Spring框架结合JOTM(Java Open Transaction Manager)来实现多数据源下的分布式事务管理。我们将通过具体实例展示如何在Tomcat服务器环境下配置并使用这些技术。 #### 一、...
NULL 博文链接:https://onlyor.iteye.com/blog/1483289
JOTM是Java事务API(JTA)的一个开源实现,用于管理跨多个资源(如数据库和消息队列)的分布式事务。在Spring中,JOTM可以作为全局事务管理器,处理跨越不同数据源的事务。当应用程序需要在多个数据库或者服务之间...
1. **添加依赖**:首先,需要在项目的类路径中包含Hibernate、JTA和相关的库文件,比如JOTM(Java Open Transaction Manager),这是一个开源的JTA实现。 2. **配置JTA**:在Tomcat的server.xml或context.xml文件中...
总结来说,Spring分布式事务实现主要依赖于Spring框架的事务管理能力、JOTM作为JTA实现的事务管理器,以及相关的JDBC驱动来连接数据库。通过声明式事务管理,开发者可以在不深入事务管理细节的情况下,编写出可靠的...