Java数据库连接池C3P0-0.9.2-pre3 发布
jopen 13年前
<p>C3P0是一个开放源代码的JDBC连接池,Hibernate的发行包中默认使用此连接池。<span style="font-weight:bold;">传</span><span style="color:#ff0000;"><strong>说</strong></span>性能最好。<br /> <br /> C3P0在沉寂了多年之后,终于迎来了更新,目前常用的稳定版是:0.9.1.2,现在最新版本: 0.9.2-pre2(开发版 0.9.2-pre3),C3P0的最新代码已经迁移到GitHub上了:<a href="/misc/goto?guid=4958342294625112423">https://github.com/swaldman/c3p0</a></p> <p><img style="width:588px;height:395px;" alt="Java数据库连接池C3P0-0.9.2-pre3 发布" src="https://simg.open-open.com/show/47e0cde93eec21ed008463a157bcbab1.jpg" width="644" height="433" /></p> <p>0.9.2-pre2下载地址:<a href="/misc/goto?guid=4958342295494718052">http://sourceforge.net/projects/c3p0/files/c3p0-bin/</a></p> <p>0.9.3-pre3下载地址:<a href="/misc/goto?guid=4958342296281742048">https://oss.sonatype.org/content/repositories/snapshots/com/mchange/c3p0/0.9.2-pre3-SNAPSHOT/</a></p> <p><img style="width:572px;height:347px;" alt="Java数据库连接池C3P0-0.9.2-pre3 发布" src="https://simg.open-open.com/show/ac62fc418064addabe0bc7cd20e14f3c.jpg" width="954" height="580" /></p> <p><strong> Changelog:</strong></p> <p> </p> <pre class="brush:html; toolbar: true; auto-links: false;">c3p0-0.9.2-pre3 Some highlights: + Some JDBC drivers freeze up if cached Statements are close()ed while their parent Connections are in use. Previously users of these drivers (Oracle, JTDS) generally had to forego Statement caching to avoid deadlocks. C3P0's statement cache can now be set to cautiously close Statements only when the parent Connections are known to be idle. If you experience "APPARENT DEADLOCKS" due to StatementCloseTasks, set c3p0.statementCacheNumDeferredCloseThreads=1 and they should go away! + There are some other minor improvements and fixes: -- the more granular and efficient "scattered" Connection acquisition algorithm that was "experimental" in the previous release is enabled by default -- unreturned Connections that are timed out (bad! bad!) are either rolled back (default) or committed before close(), respecting your unresolved transaction configuration. (see config parameter unresolvedConnectionTimeout in docs). + You must now include two jar files (c3p0 and mchange-commons-java) in your CLASSPATH rather than just one. Both can be found in the lib directory of the binary distribution. (Please provide feedback; if this is very inconvenient I can bundle it all up into a unified jar.) Some structural changes: + Development of c3p0 and mchange-commons-java have migrated to github: https://github.com/swaldman/c3p0 https://github.com/swaldman/mchange-commons-java Note that c3p0 depends (heavily) on the mchange-commons library. c3p0-0.9.2-pre2 -- Added support for deployment to Maven central repository to build.xml, and noted this version's coordinates in the repository. -- Added a src directory to the distribution, containing jarred java sources (including codegenerated sources) intended for debuggers/IDEs. As a convenience, mchange-commons-java sources are included as well. -- Fixed issue where idle Connections being tested by the pool were not properly marked with the statement cache as "in-use". -- Updated the build file to make it easy to update versions and dates on source code headers. -- ResultSets are now automatically closed and their proxies dereferenced as soon as parent Statements are closed, rather than waiting for the parent Connection to close as we did before. Thanks to jo-hennig and soronthar for calling attention to this issue. -- Modified (in mchange commons library) ThreadPoolAsynchronousRunner to occasionally (stochastically) call Timer.purge() when maxAdministrativeTaskTime settings leads to frequent cancellations of TimerTasks. Thanks to Kevin Conaway, who observed memory issues from the piling up of canceled but unpurged TimerTasks. -- Modified (in mchange commons library) VersionUtils to be more tolerant of unusual version Strings. Thanks to martyhu for the suggestion. -- When a ProxyConnection is marked closed, we now fire a connectionClosed event even if an Exception occurred during cleanup, to be sure that proxies detach. We still fire a connectionErrorOccurred prior to connectionClosed, so that listeners (especially C3P0PooledConnectionPool) can invalidate the can't-be-cleaned-up PooledConnection. -- Modified GooGooStatementCache to call clearBatch on PreparedStatement checkin, so that stale batches from prior use of Statements are never visible to new users. Many thanks to David Carr for pointing out the problem and the fix. -- getWarnings and clearWarnings no longer set the txn_known_resolved flag to false. Thanks to Manuel Darveau for pointing out the unnecessary caution. -- Gave C3P0PooledConnectionPoolManager's timer a name. Thanks to Matt Kusnierz for the suggestion. -- Fixed an infinite loop in ComboPooledDataSource, which occurred following some Exceptions, which provoked calls to toString() to build the Exception message, which call itself provoked an Exception, ad infinitum. All potentially Exception-provoking attribute lookups are now excluded from toString(). Many thanks to Svante v. Erichsen for calling attention to this problem and suggesting a fix. -- Modified the build so that JDK 1.4 compatible versions of c3p0-0.9.2 can be generated easily. (c3p0-0.9.2 will be the last version of c3p0 to support JDK 1.4 builds.) -- Moved development onto github. See https://github.com/swaldman/c3p0, with a dependency against https://github.com/swaldman/mchange-commons-java c3p0-0.9.2-pre1 -- Rationalized management of the ConnectionEventListener that checks in PooledConnections on proxy Connection close(). Now added on check-out and removed on check-in, rather than being always present but temporarily removed during administrative tasks. -- Implemented asynchronous Statement destroyer, hopefully completing the task of making the statement cache robust to drivers that cannot deal with Statements being closed underneath Connections still in use (e.g. Oracle, JTDS). Note that this implementation requires at least one dedicated Thread for statement destruction (if we used the common Thread pool, there will be deadlocks as Statement close tasks await not-in-use Connections, while Connection-related tasks can't be completed because the Thread pool is saturated with Statement close tasks. Stats about the asynchronous Statement destroyer are available via the JMX MBean, prefixed statementDestroyer. Setting the new config parameter c3p0.statementCacheNumDeferredCloseThreads enables the fix. -- Resolved a potential race condition that could lead to pool freezes, especially when acquisitions occasionally fail and acquireIncrement is set to 1. [Many thanks to Brendan Dougherty for carefully describing this issue.] -- Added a guard to BasicResourcePool.doAcquire() to ensure that the pool has not been closed or broken before assimilating a task [Many thanks to Sean Rohead for tracking down this issue and suggesting the fix.] -- Made SCATTERED_ACQUIRE_TASK default to true. This provides much better overall performance for Connection acquisition from potentially unreliable sources -- Modifed to ensure that unresolved transaction settings apply to expired unreturned Connections. (see config params autoCommitOnClose and forceIgnoreUnresolvedTransactions) [Thanks to Matthew Lieder for calling attention to this issue.] -- Cleaned up Statement cache fix that ensures no statements are closed while their parent Connection is in use. By default, the fix is not enabled, because it's extra work that most databases don't need. [Most drivers support Statement close() while a parent Connection is in use, so the extra work is unnecessary.] -- Separated traditional build into two libraries, mchange-commons and c3p0. -- Modified GooGooStatementCache and C3P0PooledConnectionPool to ensure that 1) the Statement cache knows which Connections are currently in use by outside clients; and 2) the Statement cache refuses to cull Statements belonging to Connections in use. Theoretically, drivers should support asynchronous statement close. In practice, some drivers don't do so nicely, or block pending completion of other (potentially long) operations, leading to APPARENT DEADLOCKS. (Oracle users in particular have reported deadlocks in which all pool threads are blocked on Statement close tasks.) [Many, many thanks to Ovidiu Feodorov for a very detailed account of problems that occur under c3p0 when very long queries are executed under Oracle!] -- Defined a NullMLogger, and modified Log4jMLog to use that, instead of a broken log4j MLogger, if c3p0's logging library fails to acquire a non-null Log4j logger. Thanks to Oli Glimmer for calling attention to this issue. (Strange NPEs due to apparently null log4j loggers have been encountered before, and previous attempts to resolve apparently weren't adequate.) -- Fixed a problem whereby ThreadPoolAsynchronousRunner was not robust to Errors provoked during task execution. [Thanks to George Khoshy for reporting this issue.] -- Made VersionUtils more robust to cases where some components of the java.version system property are non-integral [Thanks to Dirk Weigenand for calling attention to this problem, and suggesting a solution!]</pre> <p> </p> <p> </p> <p> 虽然C3P0-0.9.2 还不是稳定版,但是很值得期待,希望性能更好,更稳定。</p>