NAME
KinoSearch::Store::Lock - Interprocess mutex lock.
SYNOPSIS
my $lock = $lock_factory->make_lock(
lock_name => 'commit',
timeout => 5000,
);
$lock->obtain or die "can't get lock on " . $lock->get_filename;
do_stuff();
$lock->release;
DESCRIPTION
The Lock class produces an interprocess mutex lock, using a lock "file". What exactly constitutes that "file" depends on the Folder implementation.
Each lock must have a name which is unique per resource to be locked. The filename for the lockfile will be derived from it, e.g. "write" will generate the file "write.lock".
Each lock also has an "agent id", a string which should be unique per-host; it is used to help clear away stale lockfiles.
CONSTRUCTOR
my $lock = KinoSearch::Store::Lock->new(
lock_name => 'commit', # required
timeout => 5000, # default: 0
folder => $folder, # required
agent_id => $hostname, # required
);
Create a Lock. Takes named parameters.
lock_name - String identifying the resource to be locked.
timeout - Time in milliseconds to keep retrying before abandoning the attempt to obtain() a lock.
folder - An object which isa KinoSearch::Store::Folder.
agent_id - An identifying string, usually the host name.
METHODS
obtain
$lock->obtain or die "Couldn't get lock";
Attempt to aquire lock once per second until the timeout has been reached. Returns true upon success, false otherwise.
release
$lock->release;
Release the lock.
is_locked
do_stuff() if $lock->is_locked;
Returns a boolean indicating whether the resource identified by this lock's lock_name string is currently locked.
clear_stale
$lock->clear_stale;
$lock->obtain or die "Can't get lock";
Release all locks that meet the following criteria:
lock_name
matches.agent_id
matches.The process id that the lock was created under no longer identifies an active process.
COPYRIGHT
Copyright 2005-2007 Marvin Humphrey
LICENSE, DISCLAIMER, BUGS, etc.
See KinoSearch version 0.20.