[Zope-Checkins] CVS: ZODB3/ZEO - StorageServer.py:1.74.2.14

Jeremy Hylton jeremy at zope.com
Wed Aug 27 12:09:00 EDT 2003


Update of /cvs-repository/ZODB3/ZEO
In directory cvs.zope.org:/tmp/cvs-serv1940

Modified Files:
      Tag: ZODB3-3_1-branch
	StorageServer.py 
Log Message:
Log a message about the number of objects and size of a transaction.

Need to pass a log method to the DelayedCommitStrategy.  Rename the
self.log attribute, which holds the CommitLog, to self.clog.


=== ZODB3/ZEO/StorageServer.py 1.74.2.13 => 1.74.2.14 ===
--- ZODB3/ZEO/StorageServer.py:1.74.2.13	Wed Aug 27 10:23:46 2003
+++ ZODB3/ZEO/StorageServer.py	Wed Aug 27 11:08:59 2003
@@ -483,7 +483,8 @@
         # (This doesn't require a lock because we're using asyncore)
         self.strategy = self.DelayedCommitStrategyClass(self.storage,
                                                         self.wait,
-                                                        self.queue)
+                                                        self.queue,
+                                                        self.log)
 
         t = Transaction()
         t.id = id
@@ -748,12 +749,13 @@
 class DelayedCommitStrategy:
     """The storage is unavailable, so log to a file."""
 
-    def __init__(self, storage, block, queue):
+    def __init__(self, storage, block, queue, logmethod):
         # the block argument is called when we can't delay any longer
         self.storage = storage
         self.block = block
         self.queue = queue
-        self.log = CommitLog()
+        self.clog = CommitLog()
+        self.log = logmethod
 
         # Store information about the call that blocks
         self.name = None
@@ -765,7 +767,7 @@
         self.status = status
 
     def store(self, oid, serial, data, version):
-        self.log.store(oid, serial, data, version)
+        self.clog.store(oid, serial, data, version)
 
     def tpc_abort(self):
         pass # just forget about this strategy
@@ -812,7 +814,9 @@
         # whether to use another thread.  The real work is done in
         # _prepare().
         assert isinstance(new_strategy, ImmediateCommitStrategy)
-        if self.log.stores > 25:
+        self.log("Preparing to commit transaction: %d objects, %d bytes" %
+                 (self.clog.stores, self.clog.size()), level=zLOG.BLATHER)
+        if self.clog.stores > 25:
             # If there are a lot of stores, fire off a separate thread
             # to avoid blocking other clients.
             return run_in_thread(self._prepare, new_strategy, delay=delay)
@@ -826,7 +830,7 @@
     def _prepare(self, new_strategy):
         # The new strategy will always be an ImmediateCommitStrategy.
         new_strategy.tpc_begin(self.txn, self.tid, self.status)
-        loads, loader = self.log.get_loader()
+        loads, loader = self.clog.get_loader()
         for i in range(loads):
             oid, serial, data, version = loader.load()
             if not new_strategy.store(oid, serial, data, version):




More information about the Zope-Checkins mailing list