1 .\" $NetBSD: shlock.1,v 1.10 2006/10/07 21:13:00 elad Exp $
3 .\" Copyright (c) 2006 The NetBSD Foundation, Inc.
4 .\" All rights reserved.
6 .\" This code is derived from software contributed to The NetBSD Foundation
9 .\" Redistribution and use in source and binary forms, with or without
10 .\" modification, are permitted provided that the following conditions
12 .\" 1. Redistributions of source code must retain the above copyright
13 .\" notice, this list of conditions and the following disclaimer.
14 .\" 2. Redistributions in binary form must reproduce the above copyright
15 .\" notice, this list of conditions and the following disclaimer in the
16 .\" documentation and/or other materials provided with the distribution.
18 .\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
19 .\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
20 .\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
21 .\" PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
22 .\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23 .\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24 .\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25 .\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26 .\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27 .\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28 .\" POSSIBILITY OF SUCH DAMAGE.
35 .Nd create or verify a lock file for shell scripts
45 command can create or verify a lock file on behalf of a shell or
47 When it attempts to create a lock file, if one already exists,
49 verifies that it is or is not valid.
52 will exit with a non-zero exit code.
55 will remove the lock file, and
61 system call to make the final target lock file, which is an atomic
62 operation (i.e. "dot locking", so named for this mechanism's original
63 use for locking system mailboxes).
64 It puts the process ID ("PID") from the command line into the
68 verifies that an extant lock file is still valid by
71 with a zero signal to check for the existence of the process that
78 to be verbose about what it is doing.
90 is given when the program is to create a lock file; when absent,
92 will simply check for the validity of the lock file.
98 to read and write the PID as a binary pid_t, instead of as ASCII,
99 to be compatible with the locks created by UUCP.
101 A zero exit code indicates a valid lock file.
106 lckfile=/tmp/foo.lock
107 if shlock -f ${lckfile} -p $$
109 # do what required the lock
112 echo Lock ${lckfile} already held by `cat ${lckfile}`
118 set lckfile=/tmp/foo.lock
119 shlock -f ${lckfile} -p $$
120 if ($status == 0) then
121 # do what required the lock
124 echo Lock ${lckfile} already held by `cat ${lckfile}`
128 The examples assume that the file system where the lock file is to
129 be created is writable by the user, and has space available.
132 was written for the first Network News Transfer Protocol (NNTP)
133 software distribution, released in March 1986.
134 The algorithm was suggested by Peter Honeyman,
135 from work he did on HoneyDanBer UUCP.
137 .An Erik E. Fair Aq fair@clock.org
139 Does not work on NFS or other network file system on different
140 systems because the disparate systems have disjoint PID spaces.
142 Cannot handle the case where a lock file was not deleted, the
143 process that created it has exited, and the system has created a
144 new process with the same PID as in the dead lock file.
145 The lock file will appear to be valid even though the process is
146 unrelated to the one that created the lock in the first place.
147 Always remove your lock files after you're done.