10.2.2 使用数据源连接池

如果你不能从 JNDI 中查找数据源,那么下一个选择就是直接在 Spring 中配置数据源连接池。尽管 Spring 并没有提供数据源连接池实现,但是我们有多项可用的方案,包括如下开源的实现:

这些连接池中的大多数都能配置为 Spring 的数据源,在一定程度上与 Spring 自带的 DriverManagerDataSource 或 SingleConnectionDataSource 很类似(我们稍后会对其进行介绍)。例如,如下就是配置 DBCP BasicDataSource 的方式:

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
      p:driverClassName="org.h2.Driver"
      p:url="jdbc:h2:tcp://localhost/~/spitter"
      p:username="sa"
      p:password=""
      p:initialSize="5"
      p:maxActive="10" />

如果你喜欢 Java 配置的话,连接池形式的 DataSource bean 可以声明如下:

@Bean
public BasicDataSource dataSource() {
  BasicDataSource ds = new BasicDataSource();
  ds.setDriverClassName("org.h2.Driver");
  ds.setUrl("jdbc:h2:tcp://localhost/~/spitter");
  ds.setUsername("sa");
  ds.setPassword("");
  ds.setInitialSize(5);
  ds.setMaxActive(10);
  return ds;
}

前四个属性是配置 BasicDataSource 所必需的。属性 driverClassName 指定了 JDBC 驱动类的全限定类名。在这里我们配置的是 H2 数据库的数据源。属性 url 用于设置数据库的 JDBC URL。最后,username 和 password 用于在连接数据库时进行认证。

以上四个基本属性定义了 BasicDataSource 的连接信息。除此以外,还有多个配置数据源连接池的属性。表 10.3 列出了 DBCP BasicDataSource 最有用的一些池配置属性:

池配置属性

所指定的内容

initialSize

池启动时创建的连接数量

maxActive

同一时间可从池中分配的最多连接数。如果设置为 0,表示无限制

maxIdle

池里不会被释放的最多空闲连接数。如果设置为 0,表示无限制

maxOpenPreparedStatements

在同一时间能够从语句池中分配的预处理语句 (prepared statement)的最大数量。如果设置为 0,表示无限制

maxWait

在抛出异常之前,池等待连接回收的最大时间(当没有可用连接时)。如果设置为 -1,表示无限等待

minEvictableIdleTimeMillis

连接在池中保持空闲而不被回收的最大时间

minIdle

在不创建新连接的情况下,池中保持空闲的最小连接数

poolPreparedStatements

是否对预处理语句(prepared statement)进行池管理 (布尔值)

在我们的示例中,连接池启动时会创建 5 个连接;当需要的时候,允许 BasicDataSource 创建新的连接,但最大活跃连接数为 10。

Last updated