[Zodb-checkins] CVS: ZODB3/ZEO - simul.py:1.12.8.2.18.9

Jeremy Hylton cvs-admin at zope.org
Thu Dec 4 01:52:44 EST 2003


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

Modified Files:
      Tag: Zope-2_6-branch
	simul.py 
Log Message:
Add a bunch of hacks to prevent ARC from getting hung or failing.

I need to think more carefully about why it's getting hung up like
this, but not tonight.  Just want to get some ballpark numbers before
turning in.


=== ZODB3/ZEO/simul.py 1.12.8.2.18.8 => 1.12.8.2.18.9 ===
--- ZODB3/ZEO/simul.py:1.12.8.2.18.8	Thu Dec  4 01:29:43 2003
+++ ZODB3/ZEO/simul.py	Thu Dec  4 01:52:43 2003
@@ -716,6 +716,8 @@
         self.total_evicts += 1
         if self.fifoT_size > self.p or (lruB and self.fifoT_size == self.p):
             node = self.fifoT.next
+            if node is self.fifoT:
+                return 0
             assert node is not self.fifoT, self.stats()
             node.linkbefore(self.fifoB)
             self.fifoT_len -= 1
@@ -724,6 +726,8 @@
             self.fifoB_size += node.size
         else:
             node = self.lruT.next
+            if node is self.lruT:
+                return 0
             assert node is not self.lruT, self.stats()
             node.linkbefore(self.lruB)
             self.lruT_len -= 1
@@ -763,7 +767,7 @@
             # If fifo is full, we'll need to evict something to make
             # room for it.
 
-            need = size
+            prev = need = size
             while need > 0:
                 if size + self.fifoT_size + self.fifoB_size >= self.cachelimit:
                     if need + self.fifoT_size >= self.cachelimit:
@@ -790,6 +794,8 @@
                                   + self.lruB_size)
                     if total_size >= self.cachelimit * 2:
                         node = self.lruB.next
+                        if node is self.lruB:
+                            break
                         assert node is not self.lruB
                         node.unlink()
                         del self.cache[node.oid]
@@ -799,6 +805,10 @@
                         need -= self.replace()
                     else:
                         break
+                if need == prev:
+                    # XXX hack, apparently we can't get rid of anything else
+                    break
+                prev = need
 
             node = Node2Q(oid, size)
             node.linkbefore(self.fifoT)
@@ -845,7 +855,10 @@
                 need = node.size
                 if self.lruT_size + self.fifoT_size + need > self.cachelimit:
                     while need > 0:
-                        need -= self.replace()
+                        r = self.replace()
+                        if not r:
+                            break
+                        need -= r
                         
             elif node.kind is lruB:
                 node.linkbefore(self.lruT)
@@ -864,7 +877,10 @@
                 need = node.size
                 if self.lruT_size + self.fifoT_size + need > self.cachelimit:
                     while need > 0:
-                        need -= self.replace(lruB=True)
+                        r = self.replace(lruB=True)
+                        if not r:
+                            break
+                        need -= r
                 
     def inval(self, oid):
         pass




More information about the Zodb-checkins mailing list