# 10.2.2　使用数据源连接池

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

* [Apache Commons DBCP](http://jakarta.apache.org/commons/dbcp)
* [c3p0](http://sourceforge.net/projects/c3p0/)
* [BoneCP](http://jolbox.com/)

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

```markup
<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 可以声明如下：

```java
@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。
