[Zodb-checkins] CVS: ZODB4/src/zodb/storage - bdbminimal.py:1.9
Barry Warsaw
barry@wooz.org
Mon, 27 Jan 2003 11:26:04 -0500
Update of /cvs-repository/ZODB4/src/zodb/storage
In directory cvs.zope.org:/tmp/cvs-serv23033
Modified Files:
bdbminimal.py
Log Message:
_dostore(): Close another race condition, which can occur if a store
occurs between the mark and sweep phases.
=== ZODB4/src/zodb/storage/bdbminimal.py 1.8 => 1.9 ===
--- ZODB4/src/zodb/storage/bdbminimal.py:1.8 Fri Jan 24 13:54:50 2003
+++ ZODB4/src/zodb/storage/bdbminimal.py Mon Jan 27 11:26:00 2003
@@ -270,6 +270,12 @@
self._serials.put(oid, newserial, txn=txn)
self._pickles.put(oid+newserial, data, txn=txn)
self._oids.put(oid, PRESENT, txn=txn)
+ # If we're in the middle of a pack, we need to add these objects to
+ # the packmark, so a specific race condition won't collect them.
+ # E.g. we do a mark, then we do a store, then we sweep. The objects
+ # stored between the mark and sweep would get collected away.
+ if self._packing:
+ self._packmark.put(oid, PRESENT, txn=txn)
# Return the new serial number for the object
if conflictresolved:
return ResolvedSerial
@@ -360,7 +366,7 @@
#
def pack(self, t):
- self.log('classic pack started')
+ self.log('pack started')
# A simple wrapper around the bulk of packing, but which acquires a
# lock that prevents multiple packs from running at the same time.
self._packlock.acquire()
@@ -377,7 +383,7 @@
finally:
self._packing = False
self._packlock.release()
- self.log('classic pack finished')
+ self.log('pack finished')
def _dopack(self):
# Do a mark and sweep for garbage collection. Calculate the set of