Commit 115e08fd authored by Barry Warsaw's avatar Barry Warsaw

Backported from ZODB4, use the lock_file.LockFile class to

encapsulation the storage lock file.
parent d295c4b8
...@@ -28,7 +28,7 @@ from BDBStorage import db, ZERO ...@@ -28,7 +28,7 @@ from BDBStorage import db, ZERO
# BaseStorage provides primitives for lock acquisition and release, and a host # BaseStorage provides primitives for lock acquisition and release, and a host
# of other methods, some of which are overridden here, some of which are not. # of other methods, some of which are overridden here, some of which are not.
from ZODB.lock_file import lock_file from ZODB.lock_file import LockFile
from ZODB.BaseStorage import BaseStorage from ZODB.BaseStorage import BaseStorage
from ZODB.referencesf import referencesf from ZODB.referencesf import referencesf
import ThreadLock import ThreadLock
...@@ -401,10 +401,8 @@ class BerkeleyBase(BaseStorage): ...@@ -401,10 +401,8 @@ class BerkeleyBase(BaseStorage):
# can't hurt and is more robust. # can't hurt and is more robust.
self._env.txn_checkpoint(0, 0, db.DB_FORCE) self._env.txn_checkpoint(0, 0, db.DB_FORCE)
self._env.txn_checkpoint(0, 0, db.DB_FORCE) self._env.txn_checkpoint(0, 0, db.DB_FORCE)
lockfile = os.path.join(self._env.db_home, '.lock')
self._lockfile.close() self._lockfile.close()
self._env.close() self._env.close()
os.unlink(lockfile)
# A couple of convenience methods # A couple of convenience methods
def _update(self, deltas, data, incdec): def _update(self, deltas, data, incdec):
...@@ -468,15 +466,7 @@ def env_from_string(envname, config): ...@@ -468,15 +466,7 @@ def env_from_string(envname, config):
# This is required in order to work around the Berkeley lock # This is required in order to work around the Berkeley lock
# exhaustion problem (i.e. we do our own application level locks # exhaustion problem (i.e. we do our own application level locks
# rather than rely on Berkeley's finite page locks). # rather than rely on Berkeley's finite page locks).
lockpath = os.path.join(envname, '.lock') lockfile = LockFile(os.path.join(envname, '.lock'))
try:
lockfile = open(lockpath, 'r+')
except IOError, e:
if e.errno <> errno.ENOENT: raise
lockfile = open(lockpath, 'w+')
lock_file(lockfile)
lockfile.write(str(os.getpid()))
lockfile.flush()
try: try:
# Create, initialize, and open the environment # Create, initialize, and open the environment
env = db.DBEnv() env = db.DBEnv()
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment