BoneCP 是一个快速、免费而且开源的java数据库连接池(JDBC Pool)管理工具库。如果你曾经使用过C3P0或者DBCP,那你肯定知道上面这句话的意思;如果你没用过这些,那简单的解释一下,它是一个能为你的应用管理数据库连接的工具。
官方网站:http://jolbox.com/
本着不重复发明轮子的原则,不应该在有了C3P0这种成熟的数据库连接池管理工具后再搞个新的出来,但是传说中BoneCP在快速这个特点上做到了极致,官方数据是C3P0等的25倍左右。不相信?其实我也不怎么信,正找时间自己写测试类测试呢,你也可以去试试看, 在这里下载 (现在最新版本0.6.7.2,如果你有困难,下面会具体提到在项目中怎么配置)
好吧,先看一下官方给出的华丽数据:
这里只应用了部分,还有其他比较多的测试数据,有兴趣就去这里 瞧瞧吧。个人还是建议自己写点代码测试一下,那样感受更深啊。
本人鸟语有限,有些翻译不是很好,请见谅
好了,废话说的挺多的,看看到底怎么用吧。
我是Maven的忠实拥护者,如果你也是,那就简单了:
你可以在你的settings.xml文件里加上下面一段,声明一个Maven仓库,如果你不想影响其他项目,那也可以在你项目的pom.xml文件里面加。
<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>
然后你就可以像引用其他jar包一样引用bonecp了,下面应该很熟悉
<dependency> <groupId>com.jolbox</groupId> <artifactId>bonecp</artifactId> <version>0.6.7.2</version> </dependency>
如果你的项目直接用类似Hibernate的东东,没有配置dataSource的话,你很牛,那就加上下面这个吧
<dependency> <groupId>com.jolbox</groupId> <artifactId>bonecp-provider</artifactId> <version>0.6.7.2</version> </dependency>
如果这些都没有满足你,那参考这里 吧。
如果你不用Spring,那应该是这样写吧:
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
主要讲一下在Spring下面怎么配置,其实更简单,只要配置dataSrouce就可以搞定。如下,具体含义见注释。
<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>
其他还有些不是很常用的包括:
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
Spring里面怎么用这个dataSource就不说了吧,今天重点在BoneCP。
初始化的时候打印出BoneCP的配置参数,很清楚,关闭的时候也有日志输出。
2010-08-02 15:10:22,457 [BoneCPDataSource.java:121] [com.jolbox.bonecp.BoneCPDataSource] DEBUG com.jolbox.bonecp.BoneCPDataSource :: JDBC URL = jdbc:mysql://10.249.128.109:3306/ali_library, Username = root, partitions = 3, max (per partition) = 3, min (per partition) = 3, helper threads = 3, idle max age = 240 min, idle test period = 30 min 2010-08-02 15:10:22,457 [BoneCPDataSource.java:121] [com.jolbox.bonecp.BoneCPDataSource] DEBUG com.jolbox.bonecp.BoneCPDataSource :: JDBC URL = jdbc:mysql://10.249.128.109:3306/ali_library, Username = root, partitions = 3, max (per partition) = 3, min (per partition) = 3, helper threads = 3, idle max age = 240 min, idle test period = 30 min 2010-08-02 15:10:45,958 [BoneCP.java:129] [com.jolbox.bonecp.BoneCP] INFO com.jolbox.bonecp.BoneCP :: Shutting down connection pool... 2010-08-02 15:10:45,958 [BoneCP.java:129] [com.jolbox.bonecp.BoneCP] INFO com.jolbox.bonecp.BoneCP :: Shutting down connection pool... 2010-08-02 15:10:45,973 [BoneCP.java:145] [com.jolbox.bonecp.BoneCP] INFO com.jolbox.bonecp.BoneCP :: Connection pool has been shutdown. 2010-08-02 15:10:45,973 [BoneCP.java:145] [com.jolbox.bonecp.BoneCP] INFO com.jolbox.bonecp.BoneCP :: Connection pool has been shutdown.
接下去会写点代码横向对比一下C3p0与BoneCP的相关点。