数据连接问题

最近项目上遇到一个问题

场景是:应用程序主机和数据库主机不在同一个网段(只能通过公网的方式进行访问),各自主机外围都有各自防护墙。此种情况,可能带来,数据库连接问题,而导致程序更新不成功。


1)方式一数据连接,采用tocmat的配置的数据源。(连接断,容易出错,导致数据库操作失败)

<Resource
      name="DS_TEST"
      type="javax.sql.DataSource"
      password="123456"
      driverClassName="oracle.jdbc.OracleDriver"
      maxIdle="10"
      maxWait="3000"
      validationQuery=""
      username="dbtest"
      url="jdbc:oracle:thin:@*.*.*.*:1521:TEST"
      maxActive="50"/>

2)方式二c3p0连接池的方式。(数据池,有尝试连接,建议采用)

<?xml version="1.0" encoding="UTF-8"?>
<c3p0-config>
<default-config>
<!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3 --> 
<property name="acquireIncrement">3</property>

<!--定义在从数据库获取新连接失败后重复尝试的次数。Default: 30 --> 
<property name="acquireRetryAttempts">30</property>

<!--两次连接中间隔时间,单位毫秒。Default: 1000 --> 
<property name="acquireRetryDelay">1000</property>

<!--当连接池用完时客户端调用getConnection()后等待获取新连接的时间,超时后将抛出 SQLException,如设为0则无限期等待。单位毫秒。Default: 0 -->
<property name="checkoutTimeout">1000</property>

<!--每60秒检查所有连接池中的空闲连接。Default: 0 --> 
<property name="idleConnectionTestPeriod">30</property>

<!--初始化时获取三个连接,取值应在minPoolSize与maxPoolSize之间。Default: 3 --> 
<property name="initialPoolSize">5</property>

<!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 --> 
<property name="maxIdleTime">60</property>

<!--连接池中保留的最大连接数。Default: 30 --> 
<property name="maxPoolSize">30</property>
</default-config>
</c3p0-config>


你可能感兴趣的:(数据连接问题)