Java中的BoneCP数据库连接池用法

在2006年8月的时候我在项目中使用过Proxool这个Java数据库连接池,在当时的使用过程中遇到了一些问题,为此曾写过一篇名为《关于Proxool使用的一点问题》的博客,网站空间,网址是,博文发布以后有很多朋友在博文下面留言,因为它们也遇到了类似的问题。我记得我在2006年使用Proxool的时候版本就已经是0.8.3了,最近在Hibernate中发现它也带了这个Java数据库连接池实现,它的版本依然是0.8.3,应该是这些年来没有更新了。前些天研究一个项目的时候发现了项目中使用了BoneCP这个Java的数据库连接池,抱着好奇的态度学习了一下,觉得还不错,所以写了这篇博文跟大家分享一下。BoneCP也是一个开源的Java数据库连接池,它的官方网站网址是:。据BoneCP网站官方报告称,BoneCP比性能排名第二的Java数据库连接池性高高25倍以上,并且支持Hibernate和DataNucleus这样的数据持久框架(当然支持JDBC这种直接方式了)。

使用BoneCP的必备条件

使用BoneCP需要如下类库支持:被连接的数据库的JDBC驱动程序,网站空间,这个可以到该数据库厂商网站下载;Google的集合框架Guava,它的网址是:,这个需要说明的是BoneCP官方网站说的必备框架是Google Collect框架,但是这个框架已经不再支持了,而是转为新的集合框架Guava;SLF4J日志类库(在早期的BoneCP版本中直接使用了Log4J类库);JDK1.5及更高版本。下面是测试项目中的类库截图:

也就是需要了如下Jar包:bonecp-0.7.0.jarmysql-connector-java-5.1.13-bin.jarslf4j-log4j12-1.6.1.jarslf4j-api-1.6.1.jarlog4j-1.2.16.jarguava-r07.jar为了得到比较详细的运行过程信息,需要添加一个log4j的配置文件log4j.properties,log4j.properties的文件位置如上图,文件内容如下:

在JDBC中使用BoneCP

在JDBC中使用BoneCP相当简单,设置一些关于数据库连接池的参数信息,比如连接池的最大、最小连接数等。下面是一个简单的例子:

这个例子相当简单,但是是利用BoneCP提供的连接池而不是直接使用JDBC来管理连接的。

使用DataSource

使用DataSource的话,香港虚拟主机,代码如下:

在Hibernate中使用BoneCP

在Hibernate中使用BoneCP除了需要上面提到的jar包之外,还需要下载一个名为bonecp-provider-0.7.0.jar的bonecp-provider的jar包,它的下载位置是:。除此之外,还需要做如下配置:

这样就可以在Hibernate中使用BoneCP了。

周公没有真实去测试BoneCP的性能,个人觉得它的用法确实比较简单,并且和不再维护的Proxool相比至少它还在一直更新和维护,不失为一个不错的备选方案。附件是本文提到的一些必备的jar包。

广告:本人现在正在参加“2010年度十大杰出IT博客大赛”,欢迎大家前去捧场投下您宝贵的一票!网址是:

本文出自 “周公(周金桥)的专栏” 博客,请务必保留此出处

只有一条路不能拒绝——那就是成长的路。

Java中的BoneCP数据库连接池用法

相关文章:

你感兴趣的文章:

标签云: