[Zope-Checkins] CVS: Zope/lib/python/ZODB - ConnectionPolicy.py:1.1.2.1 ZApplication.py:1.13.24.1

Chris McDonough chrism at zope.com
Wed Oct 1 00:35:26 EDT 2003


Update of /cvs-repository/Zope/lib/python/ZODB
In directory cvs.zope.org:/tmp/cvs-serv22765

Modified Files:
      Tag: chrism-zserver-connection-policies-branch
	ZApplication.py 
Added Files:
      Tag: chrism-zserver-connection-policies-branch
	ConnectionPolicy.py 
Log Message:
Experimental branch which allows ZServer servers to specify a different
thread pool than the default thread pool, and a ZODB 'connection policy'.

The advantages of this include:

- Thread resource exhaustion will not effect servers which specify
  a different thread pool.

- The connection policy can be used for many purposes (including,
  for instance, specifying in the future, whether MVCC should be used for a i
  particular connection), but its main purpose in this context is             
  to allow us to define a 'temporary' connection policy which obtains
  a connection outside of a (possibly exhausted) database connection
  pool.



=== Added File Zope/lib/python/ZODB/ConnectionPolicy.py ===
##############################################################################
#
# Copyright (c) 2001, 2002 Zope Corporation and Contributors.
# All Rights Reserved.
#
# This software is subject to the provisions of the Zope Public License,
# Version 2.0 (ZPL).  A copy of the ZPL should accompany this distribution.
# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
# WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
# FOR A PARTICULAR PURPOSE
#
##############################################################################
""" ZODB connection policies """

class SimpleConnectionPolicy:
    """ A class which encapsulates a simple ZODB connection policy
    by using replaceable keyword arguments to db.open against a supplied
    ZODB.DB object """
    def __init__(self, **default_kw):
        self.default_kw = default_kw

    def getConnection(self, db, **update_kw):
        print self, self.default_kw, update_kw
        kw = self.default_kw.copy()
        if update_kw is not None:
            kw.update(update_kw)
        return db.open(**kw)

# a registry of connection policies, with typical initial entries
connection_policy_registry = {
    # the default connection policy
    'default':SimpleConnectionPolicy(version='',
                                     transaction=None,
                                     temporary=0,
                                     force=None,
                                     waitflag=1),
    # temporary connections can be used when the thread pool is exhausted
    'temporary':SimpleConnectionPolicy(version='',
                                       transaction=None,
                                       temporary=1,
                                       force=None,
                                       waitflag=1),
    }


=== Zope/lib/python/ZODB/ZApplication.py 1.13 => 1.13.24.1 ===
--- Zope/lib/python/ZODB/ZApplication.py:1.13	Tue Apr  8 14:48:22 2003
+++ Zope/lib/python/ZODB/ZApplication.py	Wed Oct  1 00:35:26 2003
@@ -20,6 +20,7 @@
 
 StringType=type('')
 connection_open_hooks = []
+from ZODB.ConnectionPolicy import connection_policy_registry
 
 class ZApplicationWrapper:
 
@@ -44,8 +45,12 @@
         db, aname, version_support = self._stuff
         if version_support is not None and REQUEST is not None:
             version=REQUEST.get(version_support,'')
-        else: version=''
-        conn=db.open(version)
+        else:
+            version=''
+
+        policy_name = getattr(REQUEST, '_connection_policy', 'default')
+        policy = connection_policy_registry[policy_name]
+        conn = policy.getConnection(db, version=version)
 
         if connection_open_hooks:
             for hook in connection_open_hooks:
@@ -72,10 +77,13 @@
     def __call__(self, connection=None):
         db, aname, version_support = self._stuff
 
+        # XXX we don't have a request to get the policy from here
+        policy = connection_policy_registry['default']
+
         if connection is None:
-            connection=db.open()
+            connection = policy.getConnection(db)
         elif type(connection) is StringType:
-            connection=db.open(connection)
+            connection = policy.getConnection(db, version=connection)
 
         return connection.root()[aname]
 




More information about the Zope-Checkins mailing list