在JBOSS应用程序服务器下运行的Java应用程序中的数据库连接池

时间:2015-10-14 15:40:42

标签: java java-ee jboss database-connection connection-pooling

我正在尝试了解在JBOSS下部署的java应用程序中的数据库连接池。顺便说一下,数据库连接没有问题。 在JBOSS应用程序服务器中设置数据库连接池,如下所示:

<datasource jta="false" jndi-name="java:/testDS" pool-name="testDS" enabled="true" use-java-context="true">
       <connection-url>jdbc:oracle:thin:@xxx</connection-url>
       <driver>oracle</driver>
       <pool>
             <min-pool-size>2</min-pool-size>
             <max-pool-size>15</max-pool-size>
             <prefill>true</prefill>
       </pool>
       <security>
             <user-name>admin</user-name>
             <password>admin</password>
       </security>
</datasource>

然后我的java代码获取连接如下所示:

String jndiName = "java:/testDS";
InitialContext jndiCntx = new InitialContext();
DataSource ds = (DataSource) jndiCntx.lookup(jndiName);
Connection connection = ds.getConnection();

以上代码是否使用了连接池?如果是,下面代码的目的是什么?我有点困惑。这两个代码片段之间有什么区别?

InitialContext jndiCntx = new InitialContext();
ConnectionPoolDataSource cpds = (ConnectionPoolDataSource) jndiCntx.lookup(jndiName);            
PooledConnection pc = cpds.getPooledConnection();
Connection connection = pc.getConnection();

1 个答案:

答案 0 :(得分:3)

如果你看看PooledConnection上的JavaDoc( 您可以阅读ConnectionPoolDataSource返回的http://docs.oracle.com/javase/7/docs/api/javax/sql/PooledConnection.html):

  

应用程序员不直接使用PooledConnection接口;相反,它由管理连接池的中间层基础结构使用。

     

当应用程序调用方法DataSource.getConnection时,它会得到   返回一个Connection对象。如果正在进行连接池,那就是   Connection对象实际上是PooledConnection对象的句柄,   这是一种物理连接。

数据源的典型用法如下所示:

@Stateless
public class MyBean {

    @Resource(lookup = "java:/testDS")
    private DataSource dataSource;

    public void testDatasource() {
        try (Connection connection = dataSource.getConnection()) {

            // use the connection 

        } catch (SQLException e) {
            throw new SomeRuntimeException(e);
        }
    }
}

重要的是您在使用后关闭连接。最好的方法是尝试自动关闭。否则你的服务器就会用尽连接。

使用“@Statless”启动交易。