春季 - Hikari CP 在 DB2 上失败



我正在尝试使用基于 xml 的 bean 配置为我的基于 Spring 的应用程序使用 Hikari 连接池。下面是我的 Hikari 配置 bean,我使用 Db2 作为我的数据库。

<bean id="HikariConfig_UId_Primary" class="com.zaxxer.hikari.HikariConfig">
<property name="poolName" value="uidPrimaryCP" />
<property name="connectionTestQuery" value="select 1 from sysibm.systables fetch first row only with UR" />
<property name="dataSourceClassName" value="${Jdbc_DataSourceClassName}" />
<property name="maximumPoolSize" value="${Jdbc_MaxPoolSize}"/>
<property name="idleTimeout" value="${Jdbc_IdleTimeOut}" />
<property name="maxLifetime" value="${Jdbc_MaxLifeTime}" />
<property name="connectionTimeout" value="${Jdbc_ConnTimeOut}" />
<property name="dataSourceProperties">
<props>
<prop key="url">${Jdbc_UID_Primary}</prop>
<prop key="user">${Jdbc_UserId}</prop>
<prop key="password">${Jdbc_Password}</prop>
</props>
</property>
</bean>
<bean id="UID_Primary_DataSource" class="com.zaxxer.hikari.HikariDataSource" destroy-method="close">
<constructor-arg ref="HikariConfig_UId_Primary" />
</bean>

它无法注册 bean,表示数据库 url 属性 - url 在目标类 com.ibm.db2.jcc.DB2SimpleDataSource 上不存在。 以下是完整的堆栈跟踪。

com.ibm.ws.webcontainer.webapp.WebApp notifyServletContextCreated SRVE0283E: Exception caught while initializing context: {0}
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'UID_Primary_DataSource' defined in class path resource [config/SpringDbContext.xml]: Instantiation of bean failed; nested exception is org.springframework.beans.BeanInstantiationException: Could not instantiate bean class [com.zaxxer.hikari.HikariDataSource]: Constructor threw exception; nested exception is java.lang.RuntimeException: Property url does not exist on target class com.ibm.db2.jcc.DB2SimpleDataSource
at org.springframework.beans.factory.support.ConstructorResolver.autowireConstructor(ConstructorResolver.java:278)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.autowireConstructor(AbstractAutowireCapableBeanFactory.java:1114)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBeanInstance(AbstractAutowireCapableBeanFactory.java:1017)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:504)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:475)
at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:302)
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:228)
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:298)
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:193)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:703)
at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:760)
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:482)
at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:139)
at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:83)
at com.deere.u90.iafservice.unifieduser.application.ApplicationRegistry.loadSpringLdapContext(ApplicationRegistry.java:

任何帮助都非常感谢。

谢谢。。

我已经使用弹簧启动连接到Hikari,但没有使用xml配置。在这里查看我的帖子

我认为,在属性下方添加应该可以解决错误。

<property name="jdbcUrl" value="" />
<property name="username" value="" />
<property name="password" value="" />

你似乎有几件事不对劲。 您没有发布变量 ${Jdbc_DataSourceClassName} 的值,因为它似乎在运行时解析为 DB2SimpleDataSource。 根据此 IBM 知识中心主题,该数据源不可池化,并且由于您以"我正在尝试使用 Hikari 连接池"开始这篇文章,因此我假设您想要一个可池化的 DS,例如 com.ibm.db2.jcc.DB2ConnectionPoolDataSource,如此处所述。 第二个问题是 DB2 数据源类不支持 url 属性,只有 DB2 DriverManager 接口支持它。 DB2 数据源类的抽象基础 DB2BaseDataSource 的 KC 主题说

您可以在数据源上设置所有属性,也可以在 一个 DriverManager.getConnection 调用。

URL 不是列出的属性之一,因此您需要使用主机名、端口等属性建立与数据源的连接

最新更新