10.2.2 使用数据源连接池
如果你不能从 JNDI 中查找数据源,那么下一个选择就是直接在 Spring 中配置数据源连接池。尽管 Spring 并没有提供数据源连接池实现,但是我们有多项可用的方案,包括如下开源的实现:
这些连接池中的大多数都能配置为 Spring 的数据源,在一定程度上与 Spring 自带的 DriverManagerDataSource 或 SingleConnectionDataSource 很类似(我们稍后会对其进行介绍)。例如,如下就是配置 DBCP BasicDataSource 的方式:
如果你喜欢 Java 配置的话,连接池形式的 DataSource bean 可以声明如下:
前四个属性是配置 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