2015-05-13 13:00:23 +08:00
|
|
|
"""
|
|
|
|
Interprocess mutex based on file locks
|
|
|
|
"""
|
|
|
|
|
|
|
|
import fcntl
|
|
|
|
import os
|
|
|
|
|
2016-09-07 04:57:50 +08:00
|
|
|
|
2015-05-13 13:00:23 +08:00
|
|
|
class Lock:
|
|
|
|
|
|
|
|
def __init__(self, filename):
|
|
|
|
self.filename = filename
|
|
|
|
# This will create it if it does not exist already
|
2015-05-22 03:09:29 +08:00
|
|
|
unbuffered = 0
|
|
|
|
self.handle = open(filename, 'a+', unbuffered)
|
2015-05-13 13:00:23 +08:00
|
|
|
|
|
|
|
def acquire(self):
|
|
|
|
fcntl.flock(self.handle, fcntl.LOCK_EX)
|
|
|
|
|
2015-05-22 03:09:29 +08:00
|
|
|
# will throw IOError if unavailable
|
|
|
|
def try_acquire(self):
|
|
|
|
fcntl.flock(self.handle, fcntl.LOCK_NB | fcntl.LOCK_EX)
|
|
|
|
|
2015-05-13 13:00:23 +08:00
|
|
|
def release(self):
|
|
|
|
fcntl.flock(self.handle, fcntl.LOCK_UN)
|
|
|
|
|
|
|
|
def __del__(self):
|
|
|
|
self.handle.close()
|