首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Java开发者必须掌握:数据库连接池技术

简介

数据库连接池技术是一种提升应用程序性能的技术,核心作用是管理是连接到数据库的多个连接的打开和释放,即形成连接池管理。应用程序需要连接时使用它,使用完毕后又将其放回连接池中。当应用程序需要连接时,就绪连接一直保持可用状态。池管管理数据库连接的生命周期,这样开发人员实际上不需要等待连接建立,或者手动关闭连接。

连接池机制节省昂贵的操作及资源消耗,方便了应用程序运行时建立网络连接,并最终在后端初始化数据库会话。

2. Tomcat中的连接池的实现方式

我们最常用的应用程序服务器Tomcat与Commons DBCP Datasource打包为默认JNDI数据源,除非我们明确指定DataSourceFactory为 -

使用 Apache Commons DBCP连接池:

使用Tomcat JDBC连接池 :

工厂模式是必需的,类型是javax.sql.DataSource

DBCP的优点在于它可以与许多应用程序或框架一起使用,并且可以与市场上几乎所有的数据库一起使用。

3.连接池作用机制对比

无论哪种情况,都需要将相应的JAR(commons-dbcp.jar或tomcat-jdbc.jar)包含在构建路径中。

较早版本的Apache Commons DBCP(即1.2版本)在高负载条件下有一些令开发者烦恼的线程安全问题,使其不适合这种用法,这就是Tomcat JDBC连接池被重写的原因。

Tomcat JDBC连接池的使用也非常简单,对于已经熟悉DBCP的人来说,转换非常简单。

4.基于Hibernate的应用程序中的连接池

Hibernate根据你所配置的属性来确定要使用哪个连接池提供给程序使用。

使用c3p0的 配置

使用Apache Commons DBCP的配置

相应的JAR文件需要在lib目录中手动添加或使用Maven的POM文件配置。

如果我们不使用Hibernate配置连接池,则使用默认值。当我们启动应用程序时,它在日志或控制台输出中可见

Hibernate中的默认连接池实现不适合生产使用,主要是因为它的配置约束。

如果您使用的是应用程序服务器,则可能希望使用内置池(通常使用JNDI获得连接)。

要使用Hibernate使用JNDI配置来使用服务器的内置池,我们需要将以下属性设置为Hibernate配置文件

hibernate.connection.datasource=java:/comp/env/jdbc/TestDB

假设TestDB是Tomcat JDBC连接池数据源的JNDI名称。

如果您不能或不想使用应用程序服务器的内置连接池,Hibernate支持其他几个连接池,例如

C3P0

Proxool

在Apache DBCP之后,第二个最受欢迎的连接池实现是c3p0,它可以轻松地与Hibernate集成,一般认为它可以提供良好的性能。

5.可能对你有用的另一篇文章

Hibernate开发者:如何配置C3P0连接池?

  • 发表于:
  • 原文链接http://kuaibao.qq.com/s/20180303A0DUKM00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券