为什么Java JDBC连接池在部署时需要验证

4

为什么Java JDBC连接池需要在部署时进行验证?

我在部署我的Java EE应用(.ear文件)时遇到了问题。这个问题与我在应用中使用的JDBC连接池有关。我无法将应用部署到服务器上。控制台显示以下内容:

WARNING: RAR5038:Unexpected exception while creating resource for pool oracle_PROD_Pool. Exception : javax.resource.spi.ResourceAllocationException: Connection could not be allocated because: Wyjątek we-wy: The Network Adapter could not establish the connection
WARNING: RAR5117 : Failed to obtain/create connection from connection pool [ oracle_PROD_Pool ]. Reason : com.sun.appserv.connectors.internal.api.PoolingException: Connection could not be allocated because: Wyjątek we-wy: The Network Adapter could not establish the connection
WARNING: RAR5114 : Error allocating connection : [Error in allocating a connection. Cause: Connection could not be allocated because: Wyjątek we-wy: The Network Adapter could not establish the connection]
SEVERE: Local Exception Stack:
Exception [EclipseLink-4002] (Eclipse Persistence Services - 2.3.2.v20111125-r10461): org.eclipse.persistence.exceptions.DatabaseException
Internal Exception: java.sql.SQLException: Error in allocating a connection. Cause: Connection could not be allocated because: Wyjątek we-wy: The Network Adapter could not establish the connection
Error Code: 0...

然后我得到了SQLException堆栈跟踪,部署失败了。

我知道这是因为数据库服务器无法访问,无法创建连接,但我仍想部署应用程序并在“应用使用时间”时获取SQLException。 这是我的jdbc连接池定义:

<jdbc-connection-pool allow-non-component-callers="false" 
                          associate-with-thread="false" 
                          connection-creation-retry-attempts="0" 
                          connection-creation-retry-interval-in-seconds="10" 
                          connection-leak-reclaim="false" 
                          connection-leak-timeout-in-seconds="0" 
                          connection-validation-method="auto-commit" 
                          datasource-classname="oracle.jdbc.pool.OracleConnectionPoolDataSource" 
                          fail-all-connections="true" 
                          idle-timeout-in-seconds="300" 
                          is-connection-validation-required="true" 
                          is-isolation-level-guaranteed="true" 
                          lazy-connection-association="false" 
                          lazy-connection-enlistment="false" 
                          match-connections="false" 
                          max-connection-usage-count="0" 
                          max-pool-size="32" 
                          max-wait-time-in-millis="60000" 
                          name="oracle_PROD_Pool" 
                          non-transactional-connections="false" 
                          pool-resize-quantity="2" 
                          res-type="javax.sql.ConnectionPoolDataSource" 
                          statement-timeout-in-seconds="-1" 
                          steady-pool-size="8" 
                          validate-atmost-once-period-in-seconds="0" 
                          wrap-jdbc-objects="true">
        <property name="User" value="user"/>
        <property name="DatabaseName" value="PROD"/>
        <property name="Password" value="pass"/>
        <property name="DataSourceName" value="OracleConnectionPoolDataSource"/>
        <property name="ServerName" value="172.27.0.101"/>
        <property name="DriverType" value="thin"/>
        <property name="ExplicitCachingEnabled" value="false"/>
        <property name="MaxStatements" value="0"/>
        <property name="NetworkProtocol" value="tcp"/>
        <property name="ImplicitCachingEnabled" value="false"/>
        <property name="URL" value="jdbc:oracle:thin:@172.27.0.101:1521:PROD"/>
        <property name="PortNumber" value="1521"/>
        <property name="LoginTimeout" value="0"/>
    </jdbc-connection-pool>

以及相关的 JDBC 资源:

<jdbc-resource enabled="true" jndi-name="jdbc/oraclePROD" object-type="user" pool-name="oracle_PROD_Pool"/>

这个问题发生在我迁移到新版本的GlassFish服务器3.1.2.2之后。早先我一直使用GlassFish 3.1.1(build 12),部署时没有问题,我的意思是连接池在部署时没有被检查和填充,而是在我的应用程序尝试执行从所述jdbc连接池获取数据的代码时才占用。 我对此有点沮丧。有没有办法在部署时禁用创建和填充jdbc连接池?非常感谢任何帮助。--Jaroslaw
2个回答

0
一个连接池,正如你所理解的那样,不是一个API。它也不是一个可以按需初始化的bean。服务器正在尝试在服务器启动时创建一组连接池。这就像在服务器启动后创建线程池。对于任何使用数据库进行功能的应用程序,始终建议在服务器启动时创建和初始化池。
如果您真的需要将应用程序与DB连接池解耦,您需要将DB连接服务隔离在应用程序中作为API。也就是说,不要将DB连接用作服务,而是用作API。
这将使应用程序负责在适当时初始化服务。

我可能忽略了 glassfish 部分。请原谅我的疏忽。 - Farhan Syed

0
避免使用连接池来创建连接,可以通过将最小/初始连接池大小设置为零来实现。请查阅与连接池和应用服务器相关的文档。对于Apache Tomcat JDBC连接池,这个设置是“initialSize”,而对于Oracle通用连接池,可能是“minPoolSize”。有时很难跟踪到确切的设置,因为在某些情况下,连接池是通过 Web 管理控制台进行设置的。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接