什么是 BoneCP 什么是 BoneCP BoneCP 是一个快速、免费而且开源的 java 数据库连接池(JDBC Pool) 管理工具库。如果你曾经使用过 C3P0 或者 DBCP ,那你肯定知道上面这句话的意思;如果你没用过这些, 那简单的解释一下,它是一个能为你的应用管理数据库连接的工具。官方网站: / 为什么要学习 BoneCP 本着不重复发明轮子的原则,不应该在有了 C3P0 这种成熟的数据库连接池管理工具后再搞个新的出来,但是传说中 BoneCP 在快速这个特点上做到了极致,官方数据是 C3P0 等的 25 倍左右。不相信?其实我也不怎么信, 正找时间自己写测试类测试呢, 你也可以去试试看,在这里下载( 现在最新版本 , 如果你有困难, 下面会具体提到在项目中怎么配置) 好吧,先看一下官方给出的华丽数据: 1. 单线程( 1,000,000 获得及释放数据库连接请求,连接池大小 20-50 ) 2. 多线程( 500 线程分别获取释放 100 个链接,连接池大小 50-200 ) 3. Prepared Statement (multi-threaded) ( 500 个线程每个 100 次获得/释放,连接池大小 20-500 ) 这里只应用了部分,还有其他比较多的测试数据,有兴趣就去这里瞧瞧吧。个人还是建议自己写点代码测试一下,那样感受更深啊。在介绍怎么使用之前,先来看看 BoneCP 的特性( Features ): ?高度可扩展, :1) 不用 synchronized 关键字来处理多线程对资源的争用,而是使用 包中的锁机制; 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 plete Javadocs). 本人鸟语有限,有些翻译不是很好,请见谅好了,废话说的挺多的,看看到底怎么用吧。怎么使用 BoneCP 我是 Maven 的忠实拥护者,如果你也是,那就简单了: 你可以在你的 文件里加上下面一段,声明一个 Maven 仓库,如果你不想影响其他项目,那也可以在你项目的 文件里面加。[xhtml] view plaincopy 1.<repositories> 2. <repository> 3. <releases> 4. <enabled>true</enabled> 5. </releases> 6. <id>bonecp-repo</id> 7. <name>BoneCP Repository</name> 8. <url>/bon
BoneCP配置参数说明 来自淘豆网m.daumloan.com转载请标明出处.