Java数据库连接池技术的入门教程

池(Pool)技术在一定程度上可以明显优化服务器应用程序的性能,提高程序执行效率和降低系统资源开销。数据库连接池负责分配、管理和释放数据库连接,它允许应用程序重复使用一个现有的数据库连接,而不是再重新建立一个;

数据库连接池技术

基本概念:

数据库连接池:其实就是一个容器(集合),存放数据库连接的容器。 当系统初始化好后,容器被创建,容器中会申请一些连接对象,当用户来访问数据库时,从容器中获取连接对象,用户访问完之后,会将连接对象归还给容器。

使用池化技术的好处:

1. 节约资源

2. 用户访问高效

3.提高程序性能和降低系统资源开销

Java中定义的接口—DataSource接口提供激活框架与数据的任意集合的抽象。
常用方法:

获取连接:getConnection()

归还连接:Connection.close()。如果连接对象Connection是从连接池中获取的,那么调用Connection.close()方法,则不会再关闭连接了。而是归还连接

常用的数据库连接池技术

C3P0

步骤:
            1. 导入jar包 (两个)

c3p0-0.9.5.2.jar、mchange-commons-java-0.2.12.jar ,

2. 定义配置文件:

名称: c3p0.properties 或者 c3p0-config.xml

路径:直接将文件放在src目录下即可。

3. 创建核心对象 数据库连接池对象 ComboPooledDataSource

4. 获取连接: getConnection

代码:

<c3p0-config>
 <!-- 使用默认的配置读取连接池对象 -->
 <default-config>
 	<!-- 连接参数 -->
 <property name="driverClass">com.mysql.jdbc.Driver</property>
 <property name="jdbcUrl">jdbc:mysql://localhost:3306/db4</property>
 <property name="user">root</property>
 <property name="password">root</property>

 <!-- 连接池参数 -->
 <!--初始化申请的连接数量-->
 <property name="initialPoolSize">5</property>
 <!--最大的连接数量-->
 <property name="maxPoolSize">10</property>
 <!--超时时间-->
 <property name="checkoutTimeout">3000</property>
 </default-config>

</c3p0-config>
public static void main(String[]args)throws SQLException{
	//1.获取数据库连接池对象
	DataSource ds=new ComboPooledDataSource();
	//2.获取连接对象
	Connection conn=ds.getConnection();
	//3.打印
	System.out.println(conn);
	//4.归还资源
	conn.close();
}

Druid:由阿里巴巴提供

步骤:
              1. 导入jar包 druid-1.0.9.jar

2. 定义配置文件:

是properties形式的

可以叫任意名称,可以放在任意目录下

3. 加载配置文件。Properties

4. 获取数据库连接池对象:通过工厂来来获取  DruidDataSourceFactory

5. 获取连接:getConnection

代码:

driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql:///db3
username=root
password=root
# 初始化连接数量
initialSize=5
# 最大连接数
maxActive=10
# 最大等待时间
maxWait=3000
 public static void main(String[] args) throws Exception {
 //1.导入jar包
 //2.定义配置文件
 //3.加载配置文件
 Properties pro = new Properties();
 InputStream is = DruidDemo.class.getClassLoader().getResourceAsStream("druid.properties");
 pro.load(is);
 //4.获取连接池对象
 DataSource ds = DruidDataSourceFactory.createDataSource(pro);
 //5.获取连接
 Connection conn = ds.getConnection();
 System.out.println(conn);

}

总结

到此这篇关于Java数据库连接池技术的文章就介绍到这了,更多相关Java数据库连接池内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Java使用MySQL实现连接池代码实例

    官方:数据库连接池(Connection pooling)是程序启动时建立足够的数据库连接,并将这些连接组成一个连接池,由程序动态地对连接池中的连接进行申请,使用,释放. 理解:创建数据库连接池是一个很耗时的操作,也容易对数据库造成安全隐患.所以,在程序初始化的时候,集中创建多个数据库连接池,并把他们集中管理,供程序使用,可以保证较快的数据库读写速度,还更加的安全可靠. 手动配置连接池: /** * 手动设置连接池 */ public void demo1(){ // 获得连接: Connect

  • Java中Druid连接池连接超时获取不到连接的解决

    错误内容: com.alibaba.druid.pool.GetConnectionTimeoutException: wait millis 30000, active 600, maxActive 600, creating 0 detail: Service Error:Cannot find a proper coonection from STDB 错误日志截图: 解决过程: 1.添加了三个参数 作用是如果超过3分钟,连接未释放,那么关闭连接,并报错. 2.进行请求,并查看日志 确认获

  • Java 模拟数据库连接池的实现代码

    前面学习过等待 - 通知机制,现在我们在其基础上添加一个超时机制,模拟从连接池中获取.使用和释放连接的过程.客户端获取连接的过程被设定为等待超时模式,即如果在 1000 毫秒内无法获取到可用连接,将会返回给客户端一个 null.设定连接池的大小为 10 个,然后通过调节客户端的线程数来模拟无法获取连接的场景 由于 java.sql.Connection 只是一个接口,最终实现是由数据库驱动提供方来实现,考虑到本例只是演示,我们通过动态代理构造一个 Connection,该 Connection

  • 如何解决线程太多导致java socket连接池出现的问题

    这篇文章主要介绍了如何解决线程太多导致socket连接池出现的问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 线程太多导致socket连接池爆满,进程启动不了 问题: 某部机上跟其它机器的连接有问题,ping可以通,telnet端口不通,可以其它机器可以连接到该机器上的进程. java应用启动不起来,产生以下错误. java.net.SocketException: No buffer space available (maximum co

  • Java数据库连接池连接Oracle过程详解

    第一步:导入tomcat\lib 下的一个tomcat-dbcp.jar包 第二步:在web\META-INF下新建一个context.xml文件,文件内容如下: <?xml version="1.0" encoding="UTF-8"?> <Context> <Resource name="jdbc/lwl" auth="Container" type="javax.sql.DataS

  • Java FTPClient连接池的实现

    最近在写一个FTP上传工具,用到了Apache的FTPClient,为了提高上传效率,我采用了多线程的方式,但是每个线程频繁的创建和销毁FTPClient对象势必会造成不必要的开销,因此,此处最好使用一个FTPClient连接池.仔细翻了一下Apache的api,发现它并没有一个FTPClientPool的实现,所以,不得不自己写一个FTPClientPool.下面就大体介绍一下开发连接池的整个过程,供大家参考. 关于对象池 有些对象的创建开销是比较大的,比如数据库连接等.为了减少频繁创建.销毁

  • Java数据库连接池c3p0过程解析

    首先下载c3p0的jar包 https://mvnrepository.com/search?q=c3p0 导入jar包到eclipse 将c3p0的jar包放到eclipse中,单击右键,选择build path ,在选择 add jars 创建连接池对象 ComboPooledDataSource cpd= new ComboPooledDataSource(); 设置连接参数 方法一 使用静态代码块来初始化参数(不推荐)如果数据库发生改变,源文件需要重新编写编译,项目需要重新部署 stat

  • Java 如何快速实现一个连接池

    什么是 ACP? ACP 库提供了一整套用于实现对象池化的 API,以及若干种各具特色的对象池实现.目前最常用的版本是 2.0 版本,相对于 1.x 版本而言,并不是简单升级.2.0 版本是对象池实现的完全重写,显著的提升了性能和可伸缩性,并且包含可靠的实例跟踪和池监控. Apache Commons Pool 的官网地址为:Pool – Overview,想翻找相关文档资料,到这里去是最权威.最全面的. 如何使用 ACP? 要使用 ACP 实现一个线程池,首先需要先引入 ACP 的依赖包,这里

  • 浅谈常用Java数据库连接池(小结)

    概述 在这里所谓的数据库连接是指通过网络协议与数据库服务之间建立的TCP连接.通常,与数据库服务进行通信的网络协议无需由应用程序本身实现,原因有三: 1.实现复杂度大,需要充分理解和掌握相应的通信协议. 2.代码难以复用,每个应用程序都需要独立实现一套对应的网络协议(不同公司之间,同一公司的不同技术栈之间难以复用实现相同协议的代码) 3.性能难以保证,不同的网络协议实现可能存在巨大的性能差距 正因为如此,所以现实的实现方式是: 首先,定义网络协议标准,这样只要支持这个标准协议的数据库就可以使用相

  • Java dbcp连接池基本使用方法详解

    1.依赖api的使用 导入jar包 <!-- https://mvnrepository.com/artifact/org.apache.commons/commons-dbcp2 --> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-dbcp2</artifactId> <version>2.7.0</version&g

随机推荐