diff options
author | Mike Bayer <mike_mp@zzzcomputing.com> | 2006-12-13 20:45:34 +0000 |
---|---|---|
committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2006-12-13 20:45:34 +0000 |
commit | 8061aaaed94924067122dc7568e8cb0e55eda329 (patch) | |
tree | 8bd4a1b641e24ff0529053faf3a6ae1f4765837a /lib/sqlalchemy | |
parent | ee99f8d58cd283a9557631cdaefddebc7549a6c4 (diff) | |
download | sqlalchemy-8061aaaed94924067122dc7568e8cb0e55eda329.tar.gz |
- fixed QueuePool bug whereby its better able to reconnect to a database
that was not reachable, also fixed dispose() method
Diffstat (limited to 'lib/sqlalchemy')
-rw-r--r-- | lib/sqlalchemy/pool.py | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/lib/sqlalchemy/pool.py b/lib/sqlalchemy/pool.py index d13c83cac..08fe45f8c 100644 --- a/lib/sqlalchemy/pool.py +++ b/lib/sqlalchemy/pool.py @@ -363,8 +363,9 @@ class QueuePool(Pool): except Queue.Empty: if self._max_overflow > -1 and self._overflow >= self._max_overflow: raise exceptions.TimeoutError("QueuePool limit of size %d overflow %d reached, connection timed out" % (self.size(), self.overflow())) + con = self.create_connection() self._overflow += 1 - return self.create_connection() + return con def dispose(self): while True: @@ -373,6 +374,9 @@ class QueuePool(Pool): conn.close() except Queue.Empty: break + + self._overflow = 0 - self.size() + self.log("Pool disposed. " + self.status()) def status(self): tup = (self.size(), self.checkedin(), self.overflow(), self.checkedout()) |