- 浏览: 58196 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (50)
- 心情日志 (2)
- WebLogic (0)
- WebSphere (0)
- Sturts (0)
- Hibernate (0)
- Tomcat (0)
- J2ME (0)
- J2EE (0)
- JDBC (0)
- Oracle (1)
- 原创技术 (1)
- WebService (0)
- EJB (0)
- JPDL (0)
- Cassandra (0)
- Servlet (1)
- Jetty (1)
- 心情杂感 (0)
- Java (7)
- Mina (1)
- Kittle (0)
- Apache (1)
- Mobl (0)
- Html5 (0)
- MongoDB (4)
- OsCahe (0)
- MemCache (1)
- F5 (0)
- ActionMQ (3)
- EBS (0)
- 企业应用集成 (0)
- 财务软件 (0)
- CRM (0)
- KahaDB (0)
- EAI (0)
- 架构设计 (2)
- C++ (0)
- C (0)
- ApacheCommon (0)
- Flex (0)
- ActionScript (0)
- JqueryMobile (0)
- NIO (0)
- Hadoop (0)
- ZooKeeper (2)
- 分布式应用 (0)
- Guzz (0)
- DataBus-数据总线 (0)
- FlexAir (0)
- JavaTV (0)
- JavaFx (0)
- Lucene (3)
- Nginx (0)
- Linux (4)
- Rsync (0)
- FreeMarker (0)
- FireBird (0)
- MySQL (0)
- 项目目录 (0)
- Node.JS (0)
- Comeressor (0)
- 我关注的博客 (0)
- Hbase (2)
- Hive (1)
- Ehcache (0)
- Redis (2)
- Tair (0)
- XSocket (2)
- Tokyo Cabinet (3)
- OsCache (0)
- BoneCP (1)
- C3P0 (0)
- Apache Common (1)
- JQuery (1)
- SVN (1)
- 系统架构 (2)
- Berkeley DB (1)
最新评论
-
heping9574:
你这都什么啊,直接通过翻译软件翻译过来就能网上IBlockin ...
xSocket 教程
BoneCP是一个Java数据库连接池库,官方介绍它的速度非常快,测试值高出C3P0、DBCP很多,性能也非常出色,值得一用。
使用BoneCP有一些要求:
1)Google Guava library
2)The SLF4J logging library
3)JDK1.5 or higher
--------------------------------------------------------------------------------
1、在JDBC中直接使用。
1)classpath路径下log4j.properties文件
2)所需jar
bonecp-0.7.1.RELEASE.jar
guava-12.0.jar
mysql-connector-java-5.1.6-bin.jar
slf4j-api-1.6.6.jar
slf4j-log4j12-1.6.6.jar
log4j-1.2.17.jar
3)简单的测试代码
package cn.luxh.bonecp;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.SQLException;
import java.util.concurrent.TimeUnit;
import org.junit.Test;
import com.jolbox.bonecp.BoneCP;
import com.jolbox.bonecp.BoneCPConfig;
public class BoneCPTest {
@Test
public void testBoneCP() throws SQLException, ClassNotFoundException {
Class.forName("com.mysql.jdbc.Driver"); // load the DB driver
BoneCPConfig config = new BoneCPConfig(); // create a new configuration object
// set the JDBC url
config.setJdbcUrl("jdbc:mysql://localhost:3306/spring_struts_jpa?useUnicode=true&characterEncoding=UTF-8");
config.setUsername("root"); // set the username
config.setPassword("root"); // set the password
//一些参数设置
config.setPartitionCount(3);
config.setMaxConnectionsPerPartition(20);
config.setMinConnectionsPerPartition(10);
config.setAcquireIncrement(5);
config.setPoolAvailabilityThreshold(20);
config.setReleaseHelperThreads(2);
config.setIdleMaxAge(240,TimeUnit.MINUTES);
config.setIdleConnectionTestPeriod(60,TimeUnit.MINUTES);
config.setStatementsCacheSize(20);
config.setStatementReleaseHelperThreads(3);
BoneCP connectionPool = new BoneCP(config); // setup the connection pool
Connection connection = connectionPool.getConnection(); // fetch a connection
String sql = "INSERT INTO log4j(message) VALUES ('hello bonecp')";
PreparedStatement ps = connection.prepareStatement(sql);
ps.execute(sql);
ps.close();
connection.close(); // close the connection
connectionPool.shutdown(); // close the connection pool
}
}
2、和sring+Hibernate整合使用。
1)除了需要在JDBC中使用需要的jar包、Hibernate包和spring包外,
还需要两个很重要的jar:bonecp-provider-0.7.1-rc2.jar和bonecp-spring-0.7.1-rc1.jar
2)如果是配置SessionFactory,需要注意的是使用的是Hibernate3还是Hibernate4。
<bean id="sessionFactory" class="org.springframework.orm.hibernate.LocalSessionFactoryBean" autowire="autodetect">
<property name="hibernateProperties">
<props>
<!--如果用的是Hibernate3
<prop key="hibernate.connection.provider_class">com.jolbox.bonecp.provider.BoneCPConnectionProvider</prop>
-->
<!--如果用的是Hibernate4-->
<prop key="hibernate.service.jdbc.connections.spi.provider_class">com.jolbox.bonecp.provider.BoneCPConnectionProvider</prop>
<prop key="hibernate.connection.driver_class">com.mysql.jdbc.Driver</prop>
<prop key="hibernate.connection.url">jdbc:mysql://127.0.0.1/yourdb</prop>
<prop key="hibernate.connection.username">root</prop>
<prop key="hibernate.connection.password">abcdefgh</prop>
<prop key="bonecp.idleMaxAge">240</prop>
<prop key="bonecp.idleConnectionTestPeriod">60</prop>
<prop key="bonecp.partitionCount">3</prop>
<prop key="bonecp.acquireIncrement">10</prop>
<prop key="bonecp.maxConnectionsPerPartition">60</prop>
<prop key="bonecp.minConnectionsPerPartition">20</prop>
<prop key="bonecp.statementsCacheSize">50</prop>
<prop key="bonecp.releaseHelperThreads">3</prop>
</props>
</property>
</bean>
3)如果是配置数据源
<bean id="mainDataSource" class="com.jolbox.bonecp.BoneCPDataSource" destroy-method="close">
<property name="driverClass" value="com.mysql.jdbc.Driver" />
<property name="jdbcUrl" value="jdbc:mysql://127.0.0.1/yourdb" />
<property name="username" value="root"/>
<property name="password" value="abcdefgh"/>
<property name="idleConnectionTestPeriod" value="60"/>
<property name="idleMaxAge" value="240"/>
<property name="maxConnectionsPerPartition" value="30"/>
<property name="minConnectionsPerPartition" value="10"/>
<property name="partitionCount" value="3"/>
<property name="acquireIncrement" value="5"/>
<property name="statementsCacheSize" value="100"/>
<property name="releaseHelperThreads" value="3"/>
</bean>
3、和JPA整合使用
1)除了需要在JDBC中直接使用所需的jar包、JPA的jar包外,还需要一个很重要的jar:bonecp-provider-0.7.1-rc2.jar
2)jpa使用Hibernate提供的实现,persistent.xml配置文件如下,需要注意的是使用的是Hibernate3还是Hibernate4
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
<persistence-unit name="APP_JPA" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<properties>
<property name="javax.persistence.validation.mode" value="none"/>
<!--
如果是hibernte3,使用
<property name="hibernate.connection.provider_class" value="com.jolbox.bonecp.provider.BoneCPConnectionProvider"/>
-->
<!--hibernte4使用 -->
<property name="hibernate.service.jdbc.connections.spi.provider_class" value="com.jolbox.bonecp.provider.BoneCPConnectionProvider"/>
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect"/>
<property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver"/>
<property name="hibernate.connection.username" value="root"/>
<property name="hibernate.connection.password" value="root"/>
<property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/spring_struts_jpa?useUnicode=true&characterEncoding=UTF-8"/>
<property name="hibernate.max_fetch_depth" value="3"/>
<property name="hibernate.hbm2ddl.auto" value="update"/>
<property name="hibernate.jdbc.fetch_size" value="18"/>
<property name="hibernate.jdbc.batch_size" value="10"/>
<property name="hibernate.show_sql" value="true"/>
<property name="hibernate.format_sql" value="true"/>
<!-- BoneCP参数设置 -->
<!-- 设置分区个数.这个参数默认为1,建议3-4(根据特定应用程序而定) -->
<property name="bonecp.partitionCount" value="3"/>
<!-- 设置每个分区含有connection最大个数.这个参数默认为2.如果小于2,BoneCP将设置为50.
比如:partitionCount设置为3,maxConnectionPerPartition设置为5,你就会拥有总共15个connection.-->
<property name="bonecp.maxConnectionsPerPartition" value="20"/>
<!-- 设置每个分区含有连接最大小个数.这个参数默认为0 -->
<property name="bonecp.minConnectionsPerPartition" value="10"/>
<!-- 设置分区中的连接增长数量.这个参数默认为1 -->
<property name="bonecp.acquireIncrement" value="5"/>
<!-- 设置连接池阀值.这个参数默认为20.如果小于0或是大于100,BoneCP将设置为20.
连接池为每个分区至少维持20%数量的可用connection -->
<property name="bonecp.poolAvailabilityThreshold" value="20"/>
<!-- 设置connection助手线程个数.这个参数默认为3.如果小于0,BoneCP将设置为3. -->
<property name="bonecp.releaseHelperThreads" value="3"/>
<!-- 设置connection的空闲存活时间.这个参数默认为60,单位:分钟.设置为0该功能失效.
通过ConnectionTesterThread观察每个分区中的connection,如果这个connection距离最
后使用的时间大于这个参数就会被清除 -->
<property name="bonecp.idleMaxAge" value="240"/>
<!-- 设置测试connection的间隔时间.这个参数默认为240,单位:分钟.设置为0该功能失效.
通过ConnectionTesterThread观察每个分区中的connection, 如果这个connection距离最后
使用的时间大于这个参数并且距离上一次测试的时间大于这个参数就会向数据库发送一条测试语句,
如果执行失败则将这个connection清除. -->
<property name="bonecp.idleConnectionTestPeriod" value="60"/>
<!-- 设置statement助手线程个数.这个参数默认为3.如果小于0,BoneCP将设置为3. -->
<property name="bonecp.statementsCacheSize" value="20"/>
</properties>
</persistence-unit>
</persistence>
4、BoneCP官方网站:http://jolbox.com/
和BoneCP相关的一些jar下载地址:http://jolbox.com/bonecp/downloads/maven/com/jolbox/
相关推荐
使用BoneCP的xml配置文件进行java开发的使用全过程,使用这个例子的前提是你已经有了BoneCP所需要的那几个jar包,教你如何在java代码中加载BoneCP的xm配置文件
采用bonecp数据库连接池封装了Jdbc,当时也是网上下载了一份代码,发现不能用,只好自己修改代码,现在这个代码是可以直接运行的,测试用的Sql Server 2008,表很简单,就四个字段
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的相关参数
在用C3P0数据连接池的时候,一旦并发上来就坑不住了,因为C3P0存在...在Hibernate中使用BoneCP除了需要上面提到的jar包之外,还需要下载一个名为bonecp-provider-0.7.0.jar的bonecp-provider的jar包,它的下载位置是:...
bonecp-0.7.0.jar bonecp-0.7.0.jar bonecp-0.7.0.jar bonecp-0.7.0.jar bonecp-0.7.0.jar bonecp-0.7.0.jar bonecp-0.7.0.jar bonecp-0.7.0.jar
bonecp,Druid等連接池安裝和使用,還有一些問題的解決,適合初學者參考
bonecp-0.8.1-20131105.191813-1.jar bonecp-jdk-compat-0.8.1-20131105.191752-1.jar bonecp-provider-0.8.1-20131105.191842-1.jar slf4j-api-1.7.7.jar slf4j-log4j12-1.7.7.jar
bonecp.jar、bonecp-provider-0.7.0.jar、bonecp-spring-.jar、slf4j-api.jar、slf4j-log4j.jar
应该是JAVAA里面最好最稳定最快的数据库连接池库bonecp-0.8.0,大家可以下载使用使用
赠送jar包:bonecp-0.8.0.RELEASE.jar; 赠送原API文档:bonecp-0.8.0.RELEASE-javadoc.jar; 赠送源代码:bonecp-0.8.0.RELEASE-sources.jar; 赠送Maven依赖信息文件:bonecp-0.8.0.RELEASE.pom; 包含翻译后的API...
Bonecp的各个参数配置,以及各个参数的说明解释。
bonecp连接池所需的全部依赖包。。。bonecp连接池所需的全部依赖包。。。bonecp连接池所需的全部依赖包。。。bonecp连接池所需的全部依赖包。。。
bonecp-0.7.1-rc2.jar bonecp-0.7.1-rc2-sources.jar
bonecp数据库连接池很好用的例子 BoneCPDataSource.java bonecp-0.7.1-rc2.jar bonecp-provider-0.7.0.jar slf4j-api-1.6.1.jar slf4j-log4j12-1.6.1.jar guava-r07.jar oracle_jdbc_classes12.jar
Bonecp参数配置.pdf
bonecp-0.7.1.RELEASE.jar bonecp-provider-0.7.0.jar google-collections-1.0.jar bonecp-spring-0.7.1.RELEASE.jar slf4j-api-1.6.1.jar slf4j-log4j12-1.6.1.jar
BoneCP 连接池学习笔记 例子 代码
BoneCP(连接oracle例子+jar包)
数据库连接池BoneCP源码分析报告