summaryrefslogtreecommitdiff
path: root/doc/src
diff options
context:
space:
mode:
Diffstat (limited to 'doc/src')
-rw-r--r--doc/src/faq.rst7
-rw-r--r--doc/src/index.rst1
-rw-r--r--doc/src/pool.rst62
3 files changed, 67 insertions, 3 deletions
diff --git a/doc/src/faq.rst b/doc/src/faq.rst
index 00501d7..9041ead 100644
--- a/doc/src/faq.rst
+++ b/doc/src/faq.rst
@@ -85,14 +85,15 @@ When should I save and re-use a cursor as opposed to creating a new one as neede
suggestion is to almost always create a new cursor and dispose old ones as
soon as the data is not required anymore (call :meth:`~cursor.close` on
them.) The only exception are tight loops where one usually use the same
- cursor for a whole bunch of INSERTs or UPDATEs.
+ cursor for a whole bunch of :sql:`INSERT`\s or :sql:`UPDATE`\s.
When should I save and re-use a connection as opposed to creating a new one as needed?
Creating a connection can be slow (think of SSL over TCP) so the best
practice is to create a single connection and keep it open as long as
required. It is also good practice to rollback or commit frequently (even
- after a single SELECT statement) to make sure the backend is never left
- "idle in transaction".
+ after a single :sql:`SELECT` statement) to make sure the backend is never
+ left "idle in transaction". See also :mod:`psycopg2.pool` for lightweight
+ connection pooling.
What are the advantages or disadvantages of using named cursors?
The only disadvantages is that they use up resources on the server and
diff --git a/doc/src/index.rst b/doc/src/index.rst
index 247b501..064d13b 100644
--- a/doc/src/index.rst
+++ b/doc/src/index.rst
@@ -38,6 +38,7 @@ PostgreSQL arrays.
advanced
extensions
tz
+ pool
extras
errorcodes
faq
diff --git a/doc/src/pool.rst b/doc/src/pool.rst
new file mode 100644
index 0000000..1be2c6a
--- /dev/null
+++ b/doc/src/pool.rst
@@ -0,0 +1,62 @@
+`psycopg2.pool` -- Connections pooling
+======================================
+
+.. sectionauthor:: Daniele Varrazzo <daniele.varrazzo@gmail.com>
+
+.. index::
+ pair: Connection; Pooling
+
+.. module:: psycopg2.pool
+
+Creating new PostgreSQL connections can be an expensive operation. This
+module offers a few pure Python classes implementing simple connection pooling
+directly into the client application.
+
+.. class:: AbstractConnectionPool(minconn, maxconn, \*args, \*\*kwargs)
+
+ Base class implementing generic key-based pooling code.
+
+ New *minconn* connections are created automatically. The pool will support
+ a maximum of about *maxconn* connections. *\*args* and *\*\*kwargs* are
+ passed to the :func:`~psycopg2.connect` function.
+
+ The following methods are expected to be implemented by subclasses:
+
+ .. method:: getconn(key=None)
+
+ Get a free connection and assign it to *key* if not ``None``.
+
+ .. method:: putconn(conn, key=None)
+
+ Put away a connection.
+
+ .. method:: closeall
+
+ Close all the connections handled by the pool.
+
+ Notice that all the connections are closed, including ones
+ eventually in use by the application.
+
+
+The following classes are :class:`AbstractConnectionPool` subclasses ready to
+be used.
+
+.. autoclass:: SimpleConnectionPool
+
+ .. note:: This pool class is useful only for single-threaded applications.
+
+
+.. index:: Multithread; Connection pooling
+
+.. autoclass:: ThreadedConnectionPool
+
+ .. note:: This pool class can be safely used in multi-threaded applications.
+
+
+.. autoclass:: PersistentConnectionPool
+
+ .. note::
+
+ This pool class is mostly designed to interact with Zope and probably
+ not useful in generic applications.
+