您的位置 首页 java

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

  1. 简介

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

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

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

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

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

使用 apache Commons DBCP连接池:

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

使用 Tomcat JDBC连接池

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

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

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

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

3.连接池作用机制对比

在使用 Commons DBCP连接池机制时 ,Tomcat会获取Commons DBCP源(版本取决于Tomcat版本,例如Tomcat 7.0.27使用Commons DBCP 1.4),并执行包名替换( org.apache.commons – > org.apache.tomcat.dbcp )并将结果构建为 tomcat-dbcp.jar 。这样做是为了使内部Tomcat JDBC池永远不会与Commons DBCP类的可能应用程序使用发生冲突。这样就避免了许多潜在的类加载问题。“dbcp”包是关于数据源管理的。

同样, Tomcat JDBC连接池机制(org.apache.tomcat.jdbc.pool.*) 是与Apache Commons DBCP竞争的 数据库连接池 的替代升级实现。它是Tomcat的一个独立项目(在Tomcat模块 – > jdbc-pool下),但它在Tomcat 7(从2011年7月的7.0.19开始)中首次推出。这两种实现都有优点和缺点,但Apache Commons DBCP仍然在被广泛使用。

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

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

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

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

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

使用c3p0的 配置

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

使用 Apache Commons DBCP的配置

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

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

我们也可以用 hibernate.connection.provider_class 属性明确指定连接池提供者,不过通常不是必要的。

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

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

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

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

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

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

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

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

  1. C3P0

  2. Proxool

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

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

Java开发者必须掌握:数据库连接池技术Hibernate开发者:如何配置C3P0连接池?

文章来源:智云一二三科技

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

文章地址:https://www.zhihuclub.com/186035.shtml

关于作者: 智云科技

热门文章

网站地图