Add debug logging to the lock manager.

Signed-off-by: Roberto Rosario <roberto.rosario.gonzalez@gmail.com>
This commit is contained in:
Roberto Rosario
2017-07-01 02:31:17 -04:00
parent 916c3497c4
commit c42a2c8a94
3 changed files with 27 additions and 3 deletions

View File

@@ -1,5 +1,9 @@
from __future__ import unicode_literals
import logging
logger = logging.getLogger(__name__)
class LockingBackend(object):
"""
@@ -8,8 +12,11 @@ class LockingBackend(object):
"""
@classmethod
def acquire_lock(cls, name, timeout=None):
raise NotImplementedError
logger.debug('acquiring lock: %s, timeout: %s', name, timeout)
@classmethod
def purge_locks(cls):
raise NotImplementedError
logger.debug('purging locks')
def release(self):
logger.debug('releasing lock: %s', self.name)

View File

@@ -31,6 +31,7 @@ class FileLock(LockingBackend):
@classmethod
def acquire_lock(cls, name, timeout=None):
super(FileLock, cls).acquire_lock(name=name, timeout=timeout)
instance = FileLock(
name=name, timeout=timeout or setting_default_lock_timeout.value
)
@@ -38,6 +39,7 @@ class FileLock(LockingBackend):
@classmethod
def purge_locks(cls):
super(FileLock, cls).purge_locks()
lock.acquire()
with open(cls.lock_file, 'r+') as file_object:
locks.lock(f=file_object, flags=locks.LOCK_EX)
@@ -92,6 +94,8 @@ class FileLock(LockingBackend):
lock.release()
def release(self):
super(FileLock, self).release()
lock.acquire()
with open(self.__class__.lock_file, 'r+') as file_object:
locks.lock(f=file_object, flags=locks.LOCK_EX)

View File

@@ -8,10 +8,23 @@ from .base import LockingBackend
class ModelLock(LockingBackend):
@classmethod
def acquire_lock(cls, name, timeout=None):
super(ModelLock, cls).acquire_lock(name=name, timeout=timeout)
Lock = apps.get_model(app_label='lock_manager', model_name='Lock')
return Lock.objects.acquire_lock(name=name, timeout=timeout)
return ModelLock(
model_instance = Lock.objects.acquire_lock(
name=name, timeout=timeout
)
)
@classmethod
def purge_locks(cls):
super(ModelLock, cls).purge_locks()
Lock = apps.get_model(app_label='lock_manager', model_name='Lock')
Lock.objects.select_for_update().delete()
def __init__(self, model_instance):
self.model_instance = model_instance
def release(self):
super(ModelLock, self).release()
self.model_instance.release()