最近在使用数据库的一些操作,就顺便想仔细了解·一下JDBC连接池,和驱动程序(没有读懂,就不献丑了)
常见的数据源有dbcp,c3p0,网上资料一大把,这里就讲述BONECP,其实官网(http://www.jolbox.com/)上也有比较简单的示例,API,文档和一些常见问题,这里就写几个简单的例子,和一些我的看法
我的一个例子
package bonecptest;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import com.jolbox.bonecp.BoneCP;
import com.jolbox.bonecp.BoneCPConfig;
import com.jolbox.bonecp.ConnectionHandle;
public class TestCp {
public static void main(String[] args) {
// TODO Auto-generated method stub
try {
Class.forName("org.gjt.mm.mysql.Driver");
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
System.err.println("驱动加载失败");
}
try {
BoneCPConfig config= new BoneCPConfig();
config.setJdbcUrl("jdbc:mysql://localhost/book");
config.setUsername("root");
config.setPassword("root");
config.setMaxConnectionsPerPartition(10);
config.setMinConnectionsPerPartition(5);
//config.setPartitionCount(2);//连接池内部连接池组数
//config.setAcquireIncrement(5);
BoneCP pool=new BoneCP(config);
ConnectionHandle connection=(ConnectionHandle) pool.getConnection();
PreparedStatement pre=connection.prepareStatement("select * from admin");
ResultSet set= pre.executeQuery();
while(set.next()) {
System.out.println(set.getString("admin_name"));
}
//connection.close();
for(int i=1;i<=13;i++){
ConnectionHandle c=(ConnectionHandle) pool.getConnection();
System.out.println(i+":"+c.getCatalog());
c.close();//使用完之后要释放,类似于对象池里面的returnobject(object o),但是这里面的close(),只是将connection返回到连接池里面,而不是像jdbc原生connection真正关闭(如果是一样的话,那就相当与重新创建,没有重用connection,那就毫无意义,而且你可以注释掉c.close()方法,就会发现创建到第十个程序就不会继续运行,你想嘛,这里需要创建从连接池获取,但是连接池去没有空闲的连接*****前提是此连接池不进行扩容操作),而且这里的connection其实本身还是conenctionhandle,提供的close()并没有进行原生close()调用,而是释放,回归到连接池里面
}
System.out.println(pool.getTotalCreatedConnections()+";"+pool.getTotalFree()+";"+pool.getTotalLeased());//查看连接池总归创建了多少连接,空闲连接,已使用连接
pool.shutdown();
}
catch(Exception e) {
}
}
}
这是一个非常简单的测试程序,没有什么特别的,就用来进行简单的获取connection,然后进行连数据库操作。
对于数据库操作,现在感觉是这样的
数据库->数据库驱动->获取元数据->数据库连接->数据库连接池(亦成为连接池,数据源)
而在数据库框架中配置datasource其实配置就是连接池,因为本身jdbc是一个连接方式也提供一个获取connection,像是一套java连接数据库的规范示例,而不是说针对某个数据源,所以配置dbcp,c3p0其实和数据hi有jdbc connection没有什么区别,没有其他人说什么数据源就特别之处,就是提供connection,至于怎么操作,事务管理,回滚那些就跟数据源没什么关系,嗯哪,他就是对象池,makeobject() return connection。
我所理解的数据源就是连接池,有现成的数据源框架,也可以我们自定义实现,我觉得需要满足一些要求可以称之为一个好的连接池
1.满足基本提供connection等基本功能,即对象池,体现复用性
2.能够应对并发
3.能保证并发现象安全
4.使用多线程进行管理,使用线程池。
c3p0,dbcp数据源已经非常成熟,至于bonecp还存在,官网有解释,看了一下bonecp的源码是满足以上4个条件,前两者使用过没看源代码,但是应该也是满足的,不然大家也不会接受。
bonecp关键类有BoneCPConfig(配置数据库),BoneCP(提供操作的连接池,内附线程池),ConnectionPartition(进行具体管理连接的对象池),ConnectionHandle(继承与conenction的连接),StatementReleaseHelperThread(衔接连接操作),
这里是close()方法源代码
}
之后释放具体行为
}
具体上没有看懂,但肯定是回收connection,而且绝对没有对原生connection进行close(),个人对于源代码没有看懂,初测为是将blockingqueue中connection对象进行了标记,尽管是使用消费-生产,但是使用标记应该有其他的用途
相关推荐
BoneCP使用了连接池的预分配策略,预先创建并维护一定数量的数据库连接,从而减少了创建和销毁连接的开销。 2. **0.7.1-rc2版本**:这是BoneCP的一个发布候选版本,rc2意味着它是第二个候选版本,可能在正式发布...
这样,即使BoneCP使用了SLF4J,也可以通过这个绑定将日志输出到Log4j的配置中定义的地方。 在使用这些依赖构建应用时,通常会将它们添加到项目的类路径中,确保BoneCP和其他相关组件能够正确地找到并使用它们。同时...
2. **线程局部化**:BoneCP使用线程局部存储(Thread Local)来管理连接,减少了锁竞争,提高了并发性能。 3. **连接池分割**:BoneCP允许将连接池分割成多个独立的连接池,每个连接池服务于一个特定的数据库操作,...
BoneCP 使用分段锁和公平调度算法来管理连接,确保并发访问的高效性和公平性。在连接返回到池时,会进行一系列检查,如验证连接有效性、执行预定义的 SQL 语句来保持连接的活动状态等。 通过上述分析,我们可以...
在这个实例中,我们将学习如何通过XML配置文件来使用BoneCP,以及如何在Java代码中加载这个配置。 首先,我们需要理解BoneCP的配置文件`bonecp-config.xml`。这个文件是 BoneCP 连接池的核心,用于定义数据库连接的...
在Java的Web开发中,数据源(DataSource)和ORM框架如Hibernate是不可或缺的部分。...因此,在对数据库性能有较高要求,或者需要深入分析 SQL 执行细节的项目中,使用 BoneCP 可能会是一个更好的选择。
下面将详细介绍BoneCP数据源的配置和使用方法。 首先,要使用BoneCP,你需要下载相关的jar包。这些包包括bonecp-0.7.0.jar、bonecp-provider-0.7.0.jar、bonecp-spring-0.7.0.jar、google-collections-1.0.jar、slf...
本篇将详细介绍BoneCP连接池的使用和核心概念,以及如何通过提供的示例代码进行配置和集成。 BoneCP的主要特点包括: 1. **线程安全**:BoneCP采用预分配的连接策略,确保每个线程都可以快速获取到已建立的数据库...
Spring是一个广泛使用的Java应用框架,骨CP通过这个JAR文件可以与Spring无缝集成,使得在Spring环境中配置和使用BoneCP变得更加简单。 4. **slf4j-api.jar**:Simple Logging Facade for Java (SLF4J) 是一个日志...
然后,使用该配置创建 ` BoneCP ` 实例,并通过 ` getConnection ` 方法获取数据库连接。 **示例代码** ```java // 配置 BoneCP BoneCPConfig config = new BoneCPConfig(); config.setJdbcUrl("jdbc:mysql://...
BoneCP使用了线程局部变量(ThreadLocal)来减少锁竞争,提高了并发性能。不过,由于维护更新已经停止,新的项目可能不再推荐使用。 在Spring+MyBatis+maven环境下,这些连接池可以通过配置XML或Java配置类的方式...
BoneCP 是一个高性能的 JDBC 连接池,它在 Java 应用中被广泛使用,以提高数据库连接的效率和管理。在这个压缩包中,包含了 BoneCP 的所有必需的 JAR 包,以及一个连接示例(demo),帮助开发者快速理解和使用 ...
采用bonecp数据库连接池封装了Jdbc,当时也是网上下载了一份代码,发现不能用,只好自己修改代码,现在这个代码是可以直接运行的,测试用的Sql Server 2008,表很简单,就四个字段
本资料提供了使用BoneCP连接Oracle数据库的实例以及所需的jar包,帮助开发者快速理解和应用BoneCP。 首先,我们需要了解数据库连接池的基本概念。数据库连接池在初始化时会创建一定数量的数据库连接,并将这些连接...
使用BoneCP时,你需要在你的项目中配置相关的连接池参数,如最小连接数、最大连接数、超时时间等。以下是一个简单的配置示例: ```properties # BoneCP配置示例 bonecp.minPoolSize=5 bonecp.maxPoolSize=20 bonecp...
bonecp数据库连接池jar包0.7.1: bonecp-0.7.1.RELEASE.jar bonecp-provider-0.7.1-rc2.jar bonecp-spring-0.7.1.RELEASE.jar
### BoneCP参数配置详解 BoneCP,全称Bone Connection Pool,是Java环境下一款高效、轻量级的数据库连接池解决方案,特别适用于高并发环境。它通过优化连接管理和资源分配策略,能够显著提升数据库访问效率,降低...
在使用BoneCP时,我们需要配置相关的参数,如最小连接数、最大连接数、连接超时时间等。配置完成后,可以通过DataSource获取数据库连接。以下是一个简单的使用示例: ```java Properties props = new Properties();...
这意味着BoneCP可以通过SLF4J接口使用Log4j进行日志输出,方便调试和监控数据库连接池的运行状态。 5. **bonecp-provider-0.7.0.jar**:这个文件可能是BoneCP的一个扩展或补充,提供了额外的服务或功能。0.7.0版本...