python 中给文件加锁——fcntl模块python
import fcntlide
打开一个文件函数
f = open('./test') ##当前目录下test文件要先存在,若是不存在会报错。加密
对该文件加密:spa
fcntl.flock(f,fcntl.LOCK_EX)进程
这样就对文件test加锁了,若是有其余进程对test文件加锁,则不能成功,会被阻塞,但不会退出程序。it
解锁:fcntl.flock(f,fcntl.LOCK_UN)io
fcntl模块:class
flock() : flock(f, operation)test
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/python #coding:utf8 import os import sys import time import fcntl #导入模块 class FLOCK(ojbect): def __init__(self,name): """ :param name: 文件名 """ self.fobj = open(name,'w') self.fd = self.fobj.fileno() def lock(self): try: fcntl.lockf(sefl.fd,fcntl.LOCK_EX|fcntl.LOCK_NB) #给文件加锁,使用了fcntl.LOCK_NB print '给文件加锁,稍等 ... ...' time.sleep(20) return True except: print '文件加锁,没法执行,请稍后运行。' retrun 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 '没法执行,程序已锁定,请稍等'
执行结果:
# python suo.py test
test
file lock please waiting..... (在等待期间,在另外一个终端,运行此程序会有下面的结果)
文件已加锁
# python suo.py test
test
file no lock please check file...
没法执行,程序已锁定,请稍等
##程序中使用了fcntl.LOCK_NB 因此程序会直接退出,没有等待。