简介
数据库连接池技术是一种提升应用程序性能的技术,核心作用是管理是连接到数据库的多个连接的打开和释放,即形成连接池管理。应用程序需要连接时使用它,使用完毕后又将其放回连接池中。当应用程序需要连接时,就绪连接一直保持可用状态。池管管理数据库连接的生命周期,这样开发人员实际上不需要等待连接建立,或者手动关闭连接。
连接池机制节省昂贵的操作及资源消耗,方便了应用程序运行时建立网络连接,并最终在后端初始化数据库会话。
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连接池?
领取专属 10元无门槛券
私享最新 技术干货