返回介绍

10.2.2 使用数据源连接池

发布于 2024-08-17 00:45:49 字数 2329 浏览 0 评论 0 收藏 0

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

Apache Commons DBCP (http://jakarta.apache.org/commons/dbcp);

c3p0 (http://sourceforge.net/projects/c3p0/) ;

BoneCP (http://jolbox.com/) 。

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

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


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

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

表10.3 BasicDataSource的池配置属性

池配置属性

所指定的内容

initialSize

池启动时创建的连接数量

maxActive

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

maxIdle

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

maxOpenPreparedStatements

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

maxWait

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

minEvictableIdleTimeMillis

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

minIdle

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

poolPreparedStatements

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

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

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文