c3p0数据库连接池说明
c3p0是什么?
(1) C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展。
(2) 它是Hibernate官方推荐的数据连接池。
(3) c3p0是异步操作的,缓慢的JDBC操作是通过帮助进程完成的,扩展这些操作可以有效的提升性能。
(4)c3p0是一个成熟的,高并发的JDBC数据库连接池。但是因为历史悠久的原因,代码极其负责,不利于维护,同时还存在deadlock(死锁)的潜在风险。
配置详解
###########################
#c3p0相关配置
#当连接池用完时,客户端调用getConnection()后,等待获取新连接的时间
#超时后将抛出SQLException,单位未毫秒,默认为:0
c3p0.checkoutTimeout=100
#当连接池中的连接耗尽的时候,一次性获取的连接数,default=3
c3p0.acquireIncrement=10
#从数据库获取新连接失败以后,重复尝试的次数,default=30
c3p0.acquireRetryAttempts=30
#两次连接中间间隔时间,单位:毫秒。default=3000
c3p0.acquireRetryDelay=3000
#连接关闭时,默认将所有未提交的操作回滚。default=false
c3p0.autoCommitOnClose=false
#通过实现ConnectionTester或QueryConnectionTester的类来测试连接。#类名需制定全路径。
#Default: com.mchange.v2.c3p0.impl.DefaultConnectionTester
c3p0.connectionTesterClassName=com.mchange.v2.c3p0.impl.DefaultConnectionTester
#忽略未解决的事务。原文档作者强烈建议不使用的一个属性。defau=false
c3p0.forceIgnoreUnresolvedTransactions=false
#设置间隔多是时间查询一次所有连接池中的空闲连接,单位:秒。default=0
c3p0.idleConnectionTestPeriod=60
#连接池中保存的最大连接数。default=15
c3p0.maxPoolSize=15
#连接池中保存的最小连接数。default=3
c3p0.minPoolSize=1
#初始化获取的连接数,取值应该在minPoolSize和MaxPoolsize之间。default=3
c3p0.initialPoolSize=3
#连接池中连接的最大空闲时间,单位:秒。default=0
c3p0.maxIdleTime=60
#JDBC的标准参数,用以控制数据源内加载的PreparedStatements数量。
#但由于预缓存的statements属于单个connection而不是整个连接池。
#所以设置这个参数需要考虑到多方面的因素。
#如果maxStatements与maxStatementsPerConnection均为0,则缓存被关闭。
#Default: 0
c3p0.maxStatements=100
#连接池内单个连接所拥有的最大缓存statements数。Default: 0
c3p0.maxStatementsPerConnection=100
#用户修改系统配置参数,执行前最多等待时间,单位:秒。default=300
c3p0.propertyCycle=300
#获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常。
#但是数据源仍有效保留,并在下次调用getConnection()的时候继续尝试获取#连接。
#如果设为true,那么在尝试获取连接失败后该数据源将申明已断开并永久关闭。Default: false
c3p0.breakAfterAcquireFailure=false
#-因性能消耗大,请只在需要的时候使用它。
#如果设为true那么在每个connection提交的时候都将校验其有效性。
#建议使用idleConnectionTestPeriod或automaticTestTable等方法来提升连接测试的性能。
#Default: false
c3p0.testConnectionOnCheckout=false
#如果设为true那么在取得连接的同时将校验连接的有效性。default=false
c3p0.testConnectionOnCheckin=true
#早期的c3p0版本对JDBC接口采用动态反射代理。在早期版本用途广泛的情况下这个参数允许用户恢复到动态反射代理以解决不稳#定的故障。
#最新的非反射代理更快并且已经开始广泛的被使用,所以这个参数未必有用。
#现在原先的动态反射与新的非反射代理同时受到支持,但今后可能的版本可能不支持动态反射代理。
#Default: false
c3p0.usesTraditionalReflectiveProxies=false
#定义所有连接测试都执行的测试语句。在使用连接测试的情况下这个一显著提高测试速度。
#注意:测试的表必须在初始数据源的时候就存在。default=null
c3p0.preferredTestQuery=select id from test where id=1
#c3p0将构建一张名为Test的空表,并使用自带的查询语句进行测试。
#如果定义了参数,那么属性preferredTestQuery将被忽略。
#你不能对这张表做任何操作,它只提供c3p0测试使用。default=null
c3p0.automaticTestTable=Test
#指定c3p0 libraries的路径,如果(通常都是这样)在本地即可获得那么无#需设置,
#default=null
c3p0.factoryClassLocation=null