c3p0 is a mature, highly concurrent JDBC Connection pooling library, with
support for caching and reuse of PreparedStatement
objects.
c3p0 is available as managed dependency on Maven Central,
[groupId: com.mchange, artifactId: c3p0]
For available versions, look here.
Please see the documentation for more.
From the current development snapshot, here is the latest CHANGELOG.
Please address comments and questions to the library author.
However, please keep in mind he is an abysmal correspondent and basically an asshole.
Despite that, your feedback is very much appreciated. Pull requests are gratefully accepted. You may also open issues.
Thank you for your interest in c3p0. I do hope that you find it useful!
For now (v0.10.0), c3p0 is built under a Java 11 VM, targetting JDK 7 classfiles for continued compatibility with legacy apps.
In order to remind me to switch to Java 11, the build will fail with an Exception if it detects an unexpected version.
You can comment this requirement out of build.sc
if you like. It's the line that looks like
require( sys.props("java.runtime.version").startsWith("11"), s"Bad build JVM: ${sys.props("java.runtime.version")} -- We currently expect to build under Java 11. (We generate Java $JvmCompatVersion compatible source files.)" )
c3p0 relies on the excellent build tool mill
.
Install mill
. Then, within this repository direcory, run
$ mill jar
You'll find the raw as library out/jar.dest/out.jar
.
If you maintain a local ivy repository, You can customize publishVersion
in build.sc
, then run
$ mill publishLocal
To build the documentation
$ mill doc.docroot
You can then open in your browser out/doc/docroot.dest/index.html
By default the tests expect to find a database at jdbc:postgresql://localhost:5432/c3p0
.
As you can see, I usually test against a local postgres database. You can change this in
the forkArgs
function of build.sc
.
c3p0's testing is, um, embarrassingly informal. There is a junit test suite, but it covers a very small fraction of c3p0 functionality. To run that, it's just
$ mill test.test
Mostly c3p0 is tested by running a few test applications, and varying config ad hoc to see how things work.
If you think c3p0 could/should be tested more professionally and automatically, me too! I'd love a pull request.
build.sc
contains a lot of test applications, but the most important are
$ mill test.c3p0Benchmark
This is c3p0 most basic, common, test-of-first-resort. It runs through and times a bunch of different c3p0 operations, and puts the library through pretty good exercise
$ mill test.c3p0Load
This one puts c3p0 under load of a 100 thread performing 1000 database operations each, then terminates.
$ mill test.c3p0PSLoad
This one puts c3p0 under load of a 100 thread performing database operations indefinitely.
It uses PreparedStatement
for its database operations, so is a good way of exercising the
statement cache.
You can observe (most of) the config of your c3p0 DataSource
when you test, because c3p0 logs it at INFO
upon the first Connection
checkout attempt. When testing, verify that you are working with the configuration
you expect!
Tests are configured by command-line arguments and by a c3p0.properties
file.
To play with different configurations, edit test/resources-local/c3p0.properties
.
Also check the forkArgs()
method in build.sc
Sometimes you want to put the library through its paces with pathological configuration.
A baseline pathological configuration is defined in test/resources-local-rough/c3p0.properties
.
To give this effect, temporarily edit build.sc
:
override def runClasspath : T[Seq[PathRef]] = T{
super.runClasspath() ++ localResources()
// super.runClasspath() ++ localResourcesRough()
}
- Comment out
super.runClasspath() ++ localResources()
- Uncomment in
super.runClasspath() ++ localResourcesRough()
Then of course you can edit test/resources-local-rough/c3p0.properties
.
Often you will want to focus logging on a class or feature you are testing. By default, c3p0 tests
are configured to use java.util.logging.
, and be configured by the file test/conf-logging/logging.properties
.
Of course you can change the config (in c3p0.properties
) to use another logging library if you'd like,
but you may need to modify the build to bring third-party logging libraries in, and configure those libraries
in their own ways.
Because c3p0 currently builds under Java 11, but c3p0-loom requires Java 21, c3p0 loom is a separate project.
It is just a parallel mill project.
The instructions above apply (except c3p0-loom
does not have independent documentation to build).
c3p0 is licensed under LGPL v.2.1 or EPL v.1.0, at your option. You may also opt to license c3p0 under any version of LGPL higher than v.2.1.
Note: c3p0 has had a good experience with reporting of a security vulnerability via Sonatype's Central Security Project. If you find a c3p0 security issue, do consider reporting it via https://hackerone.com/central-security-project