Atomic lock file creation


 
Thread Tools Search this Thread
Top Forums Programming Atomic lock file creation
# 1  
Old 01-07-2009
Atomic lock file creation

Hello,
I need to implement a locking system in C. My problem is how to make the check if the lock file exist and locking it atomic operation.
I want to make something like this:
Code:
FILE* lock_fname;
lock_fname = fopen ( "file.lock", "r");
/*check if file exsists*/
if (lock_fname)
{
  fclose (lock_fname);
  lock_fname = fopen ( "file.lock", "w");
  /* file is now locked */
}
else
{
  /* looks like file is locked */
}

But this is not very good solution. How can make the check and the creation of lock file atomic operation?
Also there is a good chance that my code may have to run on Windows so I have to stick to standard C functions.
Have you got any suggestions?
Thank you!

EDIT:
This is a good solution, but it won't compile on windows I think:
Code:
#include <fcntl.h> // for open()
#include <cerrno> // for errno 
#include <cstdio> // for perror()
int fd;
fd=open("password.lck", O_WRONLY | O_CREAT | O_EXCL)


Last edited by tsurko; 01-07-2009 at 07:03 AM..
# 2  
Old 01-07-2009
sig_atomic_t is a datatype which guarantees atomic operations when basic arithmetic operations, like + -, are involved. This is because the operation takes only one uninterruptible cpu instruction.

That's pretty much all there is for atomic operations defined by the C standard.

fopen fclose, etc, are all part of the C library and are hundreds of cpu instructions long, as well as requiring disk i/o. None of these functions could ever be atomic. They are never guaranteed to be atomic. In UNIX, none of the file I/O system calls like read, write are atomic either. The C library sits on top of these system calls.
# 3  
Old 01-07-2009
How about opening a TCP socket at a specific port on 127.0.0.1? UNIX won't let more than one program bind the same port, and though Windows sometimes will, I think it can be configured not to.
# 4  
Old 01-07-2009
There are lots of file operation system calls with absolute guarantees of atomicity. The link system call is the one most often used in locking techniques. First create a temporary file in a well known directory. Then attempt to link() it to a well known name. If two processes try this at the same time, one will succeed and the other fail. If the link works, you own the lock.

For file updates, you can link the file to a lock file. Programs that update /etc/passwd and /etc/shadow often use this technique. They try to link /etc/passwd to /etc/opasswd and /etc/shadow to /etc/oshadow. Using truss and strace, I see that redhat linux and Solaris 8 are still doing that. This was the original way to lock files between cooperating processes.
# 5  
Old 01-13-2009
Hi

Hi,

Maybe this is that you want. I will try to do an example.
By the time, try reading this http://www.gnu.org/software/libtool/manual/libc/File-Locks.html
# 6  
Old 01-13-2009
code

I think this could work. I extracted the comment from open function man page.

Code:
#include <stdio.h>
#include <sys/stat.h>
#include <fcntl.h>

int main(void)
{
        int fd;

 /*           O_EXCL:

              If O_CREAT and O_EXCL are set, open() shall fail  if  the  file
              exists.  The  check  for the existence of the file and the cre-
              ation of the file if it does not exist  shall  be  atomic  with
              respect to other threads executing open() naming the same file-
              name in the same directory with  O_EXCL  and  O_CREAT  set.  If
              O_EXCL  and  O_CREAT  are  set, and path names a symbolic link,
              open() shall fail and set errno to [EEXIST], regardless of  the
              contents  of the symbolic link. If O_EXCL is set and O_CREAT is
              not set, the result is undefined.
*/


        if ( (fd = open("./test.txt", O_RDWR|O_CREAT|O_EXCL)) < 0 )
        {
                perror("open");
        }
        else
        {
                /*here you can use fcntl in order to lock the file*/
        }

        return 0;
}

# 7  
Old 01-13-2009
lagigliaivan, this works, but it won't compile on windows I think. Actually I've solved my problem with windows specific functions Smilie
Many thanks to everyone about the replies!
Login or Register to Ask a Question

Previous Thread | Next Thread

9 More Discussions You Might Find Interesting

1. Shell Programming and Scripting

Help using Flock (file lock)

Hello, I have been working on using "flock"/file lock to prevent two instances of a bash script from being executed. Below is a simplified version of what I have to illustrate the flock part. It works as it is set up there below however the piece I am trying to figure out is how to get it to... (2 Replies)
Discussion started by: infrared013
2 Replies

2. Shell Programming and Scripting

Lock file creation

Hi, Please let me know how these steps are creating a lock file using echo " ". LOCK_FILE=${LOG_DIR}/${DBNAME}_MD.lock # create lock file if then echo "Another process is running already. Will terminate this one." >> ${LOG_FILE} 2>&1 echo "If the lock file is not needed, please... (5 Replies)
Discussion started by: sandy162
5 Replies

3. UNIX for Advanced & Expert Users

Testing privileges -lock lockfile /var/lock/subsys/..- Permission denied

Hi all, I have to test some user priviliges. The goal is to be sure that an unauthorized user can't restart some modules (ssh, mysql etc...). I'm trying to automate it with a shell script but in same cases I got the syslog broadcast message. Is there any way to simply get a return code... (3 Replies)
Discussion started by: Dedalus
3 Replies

4. Red Hat

Security Question: Lock after invalid login, Session Lock and Required Minimum Password Length

Hello all, If anyone has time, I have a few questions: How do I do the following in Linux. We are using Red Hat and Oracle Enterprise Linux, which is based on Red Hat too. 1. How to lock the account after a few (like 3) invalid password attempts? 2. How do you lock a screen after 30... (1 Reply)
Discussion started by: nstarz
1 Replies

5. UNIX for Advanced & Expert Users

file lock

I have an Essbase installation on Solaris 10 and need to get the backups configured. Unfortunately several key files are locked and Essbase (OLAP application) is not releasing the locks when the Essbase or the applications within stop running. It appears I can use chmod to unlock the files but I... (0 Replies)
Discussion started by: JavaBrian
0 Replies

6. UNIX for Dummies Questions & Answers

Lock File

Hi, We have a lock file being created called lck8c0001 created in Unixware 2.1.2. This is locking a printer. According to some websites, 8c0001 relates to the device name. How does one link 8c0001 to those devices listed in the /dev folder? I have done a ps -lp for all printers and have... (4 Replies)
Discussion started by: canman
4 Replies

7. UNIX for Dummies Questions & Answers

how to lock keyboard without using lock command

how can I lock my keyboard while I'm away from the computer without using lock command. What other commands gives me the option to lock keyboard device? thanks (7 Replies)
Discussion started by: dianayun
7 Replies

8. UNIX for Dummies Questions & Answers

lock file!

I found a lock file like this lrwxrwxr-x 1 sskb apollo 16 Oct 22 22:00 lock -> hostname:2747 (pl. note that hostname is a number like 123.4.5.6) but this was not shown in the file manager eventhough I had selected to show the hidden files. I could not even read the... (4 Replies)
Discussion started by: sskb
4 Replies

9. UNIX for Dummies Questions & Answers

How to lock a file in unix?

We wish to keep a sequence number in a file. When someone wants to get the next sequence number we need to lock the file, get the next number and increment it by one. How do you do that? I know how to get the number and increment it but how do I lock the file and test that it is locked or not... (1 Reply)
Discussion started by: tammy_schmuki
1 Replies
Login or Register to Ask a Question