diff options
author | Nick Sieger <nick@nicksieger.com> | 2008-06-07 16:39:37 -0500 |
---|---|---|
committer | Nick Sieger <nick@nicksieger.com> | 2008-08-29 14:12:10 -0500 |
commit | 51349ec8733a3b96ef4757d14ed9b9e2facf023f (patch) | |
tree | 87ddcf621ff13a05bffaab767c8e1615928b0ac2 | |
parent | 72d959d9b5255a449a554a1f011386d3c7a568cf (diff) | |
download | rails-51349ec8733a3b96ef4757d14ed9b9e2facf023f.tar.gz rails-51349ec8733a3b96ef4757d14ed9b9e2facf023f.tar.bz2 rails-51349ec8733a3b96ef4757d14ed9b9e2facf023f.zip |
Add readme stating intentions of the work
-rw-r--r-- | README.rdoc | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/README.rdoc b/README.rdoc new file mode 100644 index 0000000000..15b909a159 --- /dev/null +++ b/README.rdoc @@ -0,0 +1,34 @@ +== About + +This is Nick's connection pool branch, wherein he attempts to rewrite Rails' connection handling code to +be more thread-safe, and to add connection pooling features. + +== Goals + +- Preserve Rails' lazy connection acquisition and caching strategy behavior as it exists prior to this work. +- Add ability to configure a connection pool to limit the number of connections made to a database in multiple-thread scenarios. +- Threads will block for a configurable timeout if the pool is exhausted until a connection is available. +- If none is available during the timeout period, an exception will be raised. +- Add a checkout/checkin API to reserve and release a connection to/from the pool. +- Add several different connection handling/pooling classes to serve different needs: + - proper fixed-size connection pool + - connection-per-thread with no maximum on the number of connections + - single thread cached connection + - pass-through to external connection pool (JRuby/JNDI data source connection pool) + +== TODO + +Remaining tasks: + +- Fixed-size connection pool +- Add checkin/checkout API +- Add a #with_connection API that allows checkin/checkout of a connection outside of a provided block. + + Model.with_connection do |conn| + Thread.new { + Model.connection = conn + # do something with conn + } + Model.connection.select .... + end +- Look at whether existing clear_* or verify_* methods can be deprecated or removed. |