您好,欢迎访问三七文档
当前位置:首页 > IT计算机/网络 > Java > JAVA框架数据库连接池比较(C3P0,DBCP和PROXOOL)1
Java框架数据库连接池比较(c3p0,dbcp和proxool)现在常用的开源数据连接池主要有c3p0,dbcp和proxool三种,其中:¨hibernate开发组推荐使用c3p0;¨spring开发组推荐使用dbcp(dbcp连接池有weblogic连接池同样的问题,就是强行关闭连接或数据库重启后,无法reconnect,告诉连接被重置,这个设置可以解决);¨hibernateinaction推荐使用c3p0和proxool;下面具体就每种连接池的调研结果进行说明:1.Apache-DBCPØBasicDataSource相关的参数说明dataSource:要连接的datasource(通常我们不会定义在server.xml)defaultAutoCommit:对于事务是否autoCommit,默认值为truedefaultReadOnly:对于数据库是否只能读取,默认值为falsedriverClassName:连接数据库所用的JDBCDriverClass,maxActive:可以从对象池中取出的对象最大个数,为0则表示没有限制,默认为8maxIdle:最大等待连接中的数量,设0为没有限制(对象池中对象最大个数)minIdle:对象池中对象最小个数maxWait:最大等待秒数,单位为ms,超过时间会丟出错误信息password:登陆数据库所用的密码url:连接数据库的URLusername:登陆数据库所用的帐号validationQuery:验证连接是否成功,SQLSELECT指令至少要返回一行removeAbandoned:是否自我中断,默认是falseremoveAbandonedTimeout:几秒后会自我中断,removeAbandoned必须为truelogAbandoned:是否记录中断事件,默认为falseminEvictableIdleTimeMillis:大于0,进行连接空闲时间判断,或为0,对空闲的连接不进行验证;默认30分钟timeBetweenEvictionRunsMillis:失效检查线程运行时间间隔,如果小于等于0,不会启动检查线程,默认-1testOnBorrow:取得对象时是否进行验证,检查对象是否有效,默认为falsetestOnReturn:返回对象时是否进行验证,检查对象是否有效,默认为falsetestWhileIdle:空闲时是否进行验证,检查对象是否有效,默认为falseØ在使用DBCP的时候,如果使用默认值,则数据库连接因为某种原因断掉后,再从连接池中取得连接又不进行验证,这时取得的连接实际上就会是无效的数据库连接。因此为了防止获得的数据库连接失效,在使用的时候最好保证:username:登陆数据库所用的帐号validationQuery:SELECTCOUNT(*)FROMDUALtestOnBorrow、testOnReturn、testWhileIdle:最好都设为trueminEvictableIdleTimeMillis:大于0,进行连接空闲时间判断,或为0,对空闲的连接不进行验证timeBetweenEvictionRunsMillis:失效检查线程运行时间间隔,如果小于等于0,不会启动检查线程ØPS:在构造GenericObjectPool[BasicDataSource在其createDataSource()方法中也会使用GenericObjectPool]时,会生成一个内嵌类Evictor,实现自Runnable接口。如果timeBetweenEvictionRunsMillis大于0,每过timeBetweenEvictionRunsMillis毫秒Evictor会调用evict()方法,检查对象的闲置时间是否大于minEvictableIdleTimeMillis毫秒(_minEvictableIdleTimeMillis小于等于0时则忽略,默认为30分钟),是则销毁此对象,否则就激活并校验对象,然后调用ensureMinIdle方法检查确保池中对象个数不小于_minIdle。在调用returnObject方法把对象放回对象池,首先检查该对象是否有效,然后调用PoolableObjectFactory的passivateObject方法使对象处于非活动状态。再检查对象池中对象个数是否小于maxIdle,是则可以把此对象放回对象池,否则销毁此对象Ø上述特性的可设置性已在代码中验证,具体性能是否能实现有待实际验证2.C3P0ØC3P0的官方example中使用的数据源为ComboPooledDataSource,网上一篇文章详细介绍了C3P0连接池配置中各项含义[这些配置项的含义在下载解压c3p0的压缩包之后目录的doc\index.html中的Configuration部分也有详细的介绍,这里偷下懒:P],现摘录如下:c3p0-configdefault-config!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default:3--propertyname=acquireIncrement3/property!--定义在从数据库获取新连接失败后重复尝试的次数。Default:30--propertyname=acquireRetryAttempts30/property!--两次连接中间隔时间,单位毫秒。Default:1000--propertyname=acquireRetryDelay1000/property!--连接关闭时默认将所有未提交的操作回滚。Default:false--propertyname=autoCommitOnClosefalse/property!--c3p0将建一张名为Test的空表,并使用其自带的查询语句进行测试。如果定义了这个参数那么属性preferredTestQuery将被忽略。你不能在这张Test表上进行任何操作,它将只供c3p0测试使用。Default:null--propertyname=automaticTestTableTest/property!--获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常。但是数据源仍有效保留,并在下次调用getConnection()的时候继续尝试获取连接。如果设为true,那么在尝试获取连接失败后该数据源将申明已断开并永久关闭。Default:false--propertyname=breakAfterAcquireFailurefalse/property!--当连接池用完时客户端调用getConnection()后等待获取新连接的时间,超时后将抛出SQLException,如设为0则无限期等待。单位毫秒。Default:0--propertyname=checkoutTimeout100/property!--通过实现ConnectionTester或QueryConnectionTester的类来测试连接。类名需制定全路径。Default:com.mchange.v2.c3p0.impl.DefaultConnectionTester--propertyname=connectionTesterClassName/property!--指定c3p0libraries的路径,如果(通常都是这样)在本地即可获得那么无需设置,默认null即可Default:null--propertyname=factoryClassLocationnull/property!--Stronglydisrecommended.Settingthistotruemayleadtosubtleandbizarrebugs.(文档原文)作者强烈建议不使用的一个属性--propertyname=forceIgnoreUnresolvedTransactionsfalse/property!--每60秒检查所有连接池中的空闲连接。Default:0--propertyname=idleConnectionTestPeriod60/property!--初始化时获取三个连接,取值应在minPoolSize与maxPoolSize之间。Default:3--propertyname=initialPoolSize3/property!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。Default:0--propertyname=maxIdleTime60/property!--连接池中保留的最大连接数。Default:15--propertyname=maxPoolSize15/property!--JDBC的标准参数,用以控制数据源内加载的PreparedStatements数量。但由于预缓存的statements属于单个connection而不是整个连接池。所以设置这个参数需要考虑到多方面的因素。如果maxStatements与maxStatementsPerConnection均为0,则缓存被关闭。Default:0--propertyname=maxStatements100/property!--maxStatementsPerConnection定义了连接池内单个连接所拥有的最大缓存statements数。Default:0--propertyname=maxStatementsPerConnection/property!--c3p0是异步操作的,缓慢的JDBC操作通过帮助进程完成。扩展这些操作可以有效的提升性能通过多线程实现多个操作同时被执行。Default:3--propertyname=numHelperThreads3/property!--当用户调用getConnection()时使root用户成为去获取连接的用户。主要用于连接池连接非c3p0的数据源时。Default:null--propertyname=overrideDefaultUserroot/property!--与overrideDefaultUser参数对应使用的一个参数。Default:null--propertyname=overrideDefaultPasswordpassword/property!--密码。Default:null--propertyname=password/property!--定义所有连接测试都执行的测试语句。在使用连接测试的情况下这个一显著提高测试速度。注意:测试的表必须在初始数据源的时候就存在。Default:null--propertyname=preferredTestQueryselectidfromtestwhereid=1/property!--用户修改系统配置参数执行前最多等待300秒。Default:300--propertyname=propertyCycle300/property!--因性能消耗大请只在需要的时候使用它。如果设为true那么在每个connection提交的时候都将校验其有效性。建议使用idleConnectionTestPeriod或automaticTestTable等方法来提升连接测试的性能。Default:false--propertyname=testConnectionOnCheckoutfalse/property!--如果设为true那么在取得连接的同时将校验连接的有效性。Default:false--propertyname=testConnectionOnCheckintrue/property!--用户名。Default:null--propertyname=u
本文标题:JAVA框架数据库连接池比较(C3P0,DBCP和PROXOOL)1
链接地址:https://www.777doc.com/doc-5892630 .html