对该文件加密:fcntl.flock(f,fcntl.LOCK_EX)
这样就对文件test加锁了,如果有其他进程对test文件加锁,则不能成功,会被阻塞,但不会退出程序。
解锁:fcntl.flock(f,fcntl.LOCK_UN)
fcntl模块:
flock() : flock(f, operation)
operation : 包括:
fcntl.LOCK_UN 解锁
fcntl.LOCK_EX 排他锁
fcntl.LOCK_SH 共享锁
fcntl.LOCK_NB 非阻塞锁
LOCK_SH 共享锁:所有进程没有写访问权限,即使是加锁进程也没有。所有进程有读访问权限。
LOCK_EX 排他锁:除加锁进程外其他进程没有对已加锁文件读写访问权限。
LOCK_NB 非阻塞锁:
如果指定此参数,函数不能获得文件锁就立即返回,否则,函数会等待获得文件锁。LOCK_NB可以同LOCK_SH或LOCK_NB进行按位或(|)运算操作。 fcnt.flock(f,fcntl.LOCK_EX|fcntl.LOCK_NB)
代码如下:
#!/usr/bin/env python2 # -*- coding: utf-8 -*- import os import sys import time import fcntl # 导入模块 class FLOCK(object): def __init__(self, name): """ :param name: 文件名 """ self.fobj = open(name, 'w') self.fd = self.fobj.fileno() def lock(self): try: fcntl.lockf(self.fd, fcntl.LOCK_EX | fcntl.LOCK_NB) # 给文件加锁,使用了fcntl.LOCK_NB print '给文件加锁,稍等 ... ...' time.sleep(20) return True except: print '文件加锁,无法执行,请稍后运行。' return False def unlock(self): self.fobj.close() print '已解锁' if __name__ == "__main__": print sys.argv[1] locker = FLOCK(sys.argv[1]) a = locker.lock() if a: print '文件已加锁' else: print '无法执行,程序已锁定,请稍等'
运行1: python text.py 1.txt
[root@localhost text]# python text.py 1.txt 1.txt 给文件加锁,稍等 ... ... 文件已加锁
运行2:python text.py 1.txt
[root@localhost text]# python text.py 1.txt 1.txt 文件加锁,无法执行,请稍后运行。 无法执行,程序已锁定,请稍等 [root@localhost text]# python text.py 1.txt 1.txt 给文件加锁,稍等 ... ... ^C文件加锁,无法执行,请稍后运行。 无法执行,程序已锁定,请稍等 [root@localhost text]#