python中给程序加锁之fcntl模块的使用

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 因此程序会直接退出,没有等待。

相关文章
相关标签/搜索