`
sunxboy
  • 浏览: 2878126 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

BoneCP的使用

 
阅读更多

在介绍怎么使用之前,先来看看BoneCP的特性(Features ):

  • 高度可扩展, 快速的连接池.    注:1)不用synchronized 关键字来处理多线程对资源的争用,而是使用 java.util.concurrent 包中的锁机制;2)首次使用分区机制来分开管理数据库连接;或许还有其他原因.
  • Callback (hook interceptor) mechanisms on a change of connection state.
  • 利用分区技术提高性能
  • 允许直接访问一个连接或者语句
  • 智能调整连接池大小
  • SQL语句缓存支持
  • 支持异步获取数据库连接 (通过返回Future<Connection>的形式)
  • 通过释放连接助理进程来释放数据库连接,提高性能.
  • 通过initSQL参数在每次获取连接的时候执行SQL
  • 支持数据库热切换
  • 自动重试失败的数据库操作(当数据库或者网络挂掉的时候)
  • JMX support
  • 延迟初始化能力(Lazy initialization capable)
  • 自动检测连接可用性 (keep-alives 等)
  • 允许直接通过数据源而不是通过驱动来获取一个新的数据库连接(Allow obtaining of new connections via a datasource rather than via a Driver)
  • Datasource/Hibernate support capable
  • Debug支持准确地高亮那些已经得到但是还没有关闭的链接(Debugging hooks to highlight the exact place where a connection was obtained but not closed)
  • Debug支持展示那些被关闭两次的链接地址堆栈信息(Debugging support to show stack locations of connections that were closed twice. )
  • 支持自定义连接池名称.
  • 干净的代码结构,TestCase代码覆盖率达到100% (over 125 JUnit tests).
  • 免费的,开源的而且都是用java干的,最重要的是有很完整的javadocs支持。(Free, open source and written in 100% pure Java with complete Javadocs).

1.Maven引用库文件

<repositories>
	<repository>
		<releases>
			<enabled>true</enabled>
		</releases>
		<id>bonecp-repo</id>
		<name>BoneCP Repository</name>
		<url>http://jolbox.com/bonecp/downloads/maven</url>
	</repository>
</repositories>

pom.xml

<dependency>
	<groupId>com.jolbox</groupId>
	<artifactId>bonecp</artifactId>
	<version>0.6.7.2</version>
</dependency>

 

2.手动初始化:

Class.forName("org.hsqldb.jdbcDriver"); 	// load the DB driver
BoneCPConfig config = new BoneCPConfig();	// create a new configuration object
config.setJdbcUrl("jdbc:hsqldb:mem:test");	// set the JDBC url
config.setUsername("sa");			// set the username
config.setPassword("");				// set the password
config.setXXXX(...);				// (other config options here)
BoneCP connectionPool = new BoneCP(config); 	// setup the connection pool
Connection connection;
connection = connectionPool.getConnection(); 	// fetch a connection

...  do something with the connection here ...

connection.close();				// close the connection
connectionPool.shutdown();			// close the connection pool

 

3.Spring配置

<bean id="dataSource" class="com.jolbox.bonecp.BoneCPDataSource"
		destroy-method="close">
		<!-- 数据库驱动 -->
		<property name="driverClass" value="${aliLibrary.db.driverClass}" />
		<!-- 相应驱动的jdbcUrl,你懂的 -->
		<property name="jdbcUrl" value="${aliLibrary.db.jdbcUrl}" />
		<!-- 数据库的用户名 -->
		<property name="username" value="${aliLibrary.db.username}" />
		<!-- 数据库的密码 -->
		<property name="password" value="${aliLibrary.db.password}" />
		<!-- 检查数据库连接池中空闲连接的间隔时间,单位是分,默认值:240,如果要取消则设置为0 -->
		<property name="idleConnectionTestPeriod" value="${aliLibrary.db.idleConnectionTestPeriod}" />
		<!-- 连接池中未使用的链接最大存活时间,单位是分,默认值:60,如果要永远存活设置为0 -->
		<property name="idleMaxAge" value="${aliLibrary.db.idleMaxAge}" />
		<!-- 每个分区最大的连接数 -->
		<property name="maxConnectionsPerPartition" value="${aliLibrary.db.maxConnectionsPerPartition}" />
		<!-- 每个分区最小的连接数 -->
		<property name="minConnectionsPerPartition" value="${aliLibrary.db.minConnectionsPerPartition}" />
		<!-- 分区数 ,默认值2,最小1,推荐3-4,视应用而定-->
		<property name="partitionCount" value="${aliLibrary.db.partitionCount}" />
		<!-- 每次去拿数据库连接的时候一次性要拿几个,默认值:2 -->
		<property name="acquireIncrement" value="${aliLibrary.db.acquireIncrement}" />
		<!-- 缓存prepared statements的大小,默认值:0 -->
		<property name="statementsCacheSize" value="${aliLibrary.db.statementsCacheSize}" />
		<!-- 每个分区释放链接助理进程的数量,默认值:3,除非你的一个数据库连接的时间内做了很多工作,不然过多的助理进程会影响你的性能 -->
		<property name="releaseHelperThreads" value="${aliLibrary.db.releaseHelperThreads}" />
	</bean>

 

4.其它功能

connectionTestStatement:在做keep-alive的时候的SQL语句。
statementsCachedPerConnection:No of statements that can be cached per connection,反正源码中不推荐使用,就别用了.
initSQL:在每次到数据库取连接的时候执行的SQL语句,只执行一次。
closeConnectionWatch:如果设置为true,则会增加一个线程监控关闭连接时的情况,如果关闭时出现异常,则打出错误日志,主要用于debug。上线后记得关掉。
logStatementsEnabled:如果设置为true,就会打印执行的SQL语句,如果你用了其他能打印SQL语句的框架,那就不必了。
acquireRetryDelay:在获取连接失败后,第二次参试前的延迟时间,默认为7000毫秒。
acquireRetryAttempts:在获取连接失败后的重试次数,默认为5次。
lazyInit:如果设置为true,那么连接池不会自动创建最小连接数的链接,而是保持为空,直到有需求要获取连接。
transactionRecoveryEnabled:如果设置为true,则会保存该链接上的所有活动,以备下次重试的时候使用,这里指的活动是数据库操作。
connectionHookClassName:Connection hook class name.没看懂…
poolName:上面特性中说到的自定义连接池名称。
disableJMX:控制JMX的支持开关。
connectionTimeout:获取连接的时候最大的等待时间,默认值为:Long.MAX_VALUE

 

 

分享到:
评论

相关推荐

    bonecp 0.7.1 jar包以及源码

    BoneCP使用了连接池的预分配策略,预先创建并维护一定数量的数据库连接,从而减少了创建和销毁连接的开销。 2. **0.7.1-rc2版本**:这是BoneCP的一个发布候选版本,rc2意味着它是第二个候选版本,可能在正式发布...

    BoneCP所需依赖包

    这样,即使BoneCP使用了SLF4J,也可以通过这个绑定将日志输出到Log4j的配置中定义的地方。 在使用这些依赖构建应用时,通常会将它们添加到项目的类路径中,确保BoneCP和其他相关组件能够正确地找到并使用它们。同时...

    BoneCp连接池详解及和Hibernate配置(当今最快的连接池)

    2. **线程局部化**:BoneCP使用线程局部存储(Thread Local)来管理连接,减少了锁竞争,提高了并发性能。 3. **连接池分割**:BoneCP允许将连接池分割成多个独立的连接池,每个连接池服务于一个特定的数据库操作,...

    数据库连接池BoneCP源码分析报告.doc

    BoneCP 使用分段锁和公平调度算法来管理连接,确保并发访问的高效性和公平性。在连接返回到池时,会进行一系列检查,如验证连接有效性、执行预定义的 SQL 语句来保持连接的活动状态等。 通过上述分析,我们可以...

    BoneCP的xml使用实例

    在这个实例中,我们将学习如何通过XML配置文件来使用BoneCP,以及如何在Java代码中加载这个配置。 首先,我们需要理解BoneCP的配置文件`bonecp-config.xml`。这个文件是 BoneCP 连接池的核心,用于定义数据库连接的...

    BoneCP数据源记录SQl比hibernate的show sql好用.docx

    在Java的Web开发中,数据源(DataSource)和ORM框架如Hibernate是不可或缺的部分。...因此,在对数据库性能有较高要求,或者需要深入分析 SQL 执行细节的项目中,使用 BoneCP 可能会是一个更好的选择。

    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连接池demo

    本篇将详细介绍BoneCP连接池的使用和核心概念,以及如何通过提供的示例代码进行配置和集成。 BoneCP的主要特点包括: 1. **线程安全**:BoneCP采用预分配的连接策略,确保每个线程都可以快速获取到已建立的数据库...

    bonecp-0.8.0.RELEASE.jar

    Spring是一个广泛使用的Java应用框架,骨CP通过这个JAR文件可以与Spring无缝集成,使得在Spring环境中配置和使用BoneCP变得更加简单。 4. **slf4j-api.jar**:Simple Logging Facade for Java (SLF4J) 是一个日志...

    BoneCP 连接池学习笔记

    然后,使用该配置创建 ` BoneCP ` 实例,并通过 ` getConnection ` 方法获取数据库连接。 **示例代码** ```java // 配置 BoneCP BoneCPConfig config = new BoneCPConfig(); config.setJdbcUrl("jdbc:mysql://...

    JAVA数据库连接池(C3P0,Druid,JNDI ,DBCP,Proxool,BoneCP)

    BoneCP使用了线程局部变量(ThreadLocal)来减少锁竞争,提高了并发性能。不过,由于维护更新已经停止,新的项目可能不再推荐使用。 在Spring+MyBatis+maven环境下,这些连接池可以通过配置XML或Java配置类的方式...

    bonecp 相关所有jar包以及连接demo

    BoneCP 是一个高性能的 JDBC 连接池,它在 Java 应用中被广泛使用,以提高数据库连接的效率和管理。在这个压缩包中,包含了 BoneCP 的所有必需的 JAR 包,以及一个连接示例(demo),帮助开发者快速理解和使用 ...

    bonecp数据库连接池使用Demo

    采用bonecp数据库连接池封装了Jdbc,当时也是网上下载了一份代码,发现不能用,只好自己修改代码,现在这个代码是可以直接运行的,测试用的Sql Server 2008,表很简单,就四个字段

    BoneCP(连接oracle例子+jar包)

    本资料提供了使用BoneCP连接Oracle数据库的实例以及所需的jar包,帮助开发者快速理解和应用BoneCP。 首先,我们需要了解数据库连接池的基本概念。数据库连接池在初始化时会创建一定数量的数据库连接,并将这些连接...

    bonecp0.7 所有jar包

    使用BoneCP时,你需要在你的项目中配置相关的连接池参数,如最小连接数、最大连接数、超时时间等。以下是一个简单的配置示例: ```properties # BoneCP配置示例 bonecp.minPoolSize=5 bonecp.maxPoolSize=20 bonecp...

    bonecp数据库连接池jar包

    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参数配置.doc

    ### BoneCP参数配置详解 BoneCP,全称Bone Connection Pool,是Java环境下一款高效、轻量级的数据库连接池解决方案,特别适用于高并发环境。它通过优化连接管理和资源分配策略,能够显著提升数据库访问效率,降低...

    Bonecp实例

    在使用BoneCP时,我们需要配置相关的参数,如最小连接数、最大连接数、连接超时时间等。配置完成后,可以通过DataSource获取数据库连接。以下是一个简单的使用示例: ```java Properties props = new Properties();...

    bonecp相关所有jar包

    这意味着BoneCP可以通过SLF4J接口使用Log4j进行日志输出,方便调试和监控数据库连接池的运行状态。 5. **bonecp-provider-0.7.0.jar**:这个文件可能是BoneCP的一个扩展或补充,提供了额外的服务或功能。0.7.0版本...

Global site tag (gtag.js) - Google Analytics