使用 fcntl 对文件进行写操作的时候加锁
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)
同一时刻只有一个程序对text.txt 文件获得锁
测试程序 ceshi1.py
from time import sleep import fcntl with open('text.txt', 'w') as fd: fcntl.flock(fd, fcntl.LOCK_EX | fcntl.LOCK_NB) fd.write('coco') sleep(10)
测试程序 ceshi2.py
from time import sleep import fcntl with open('text.txt', 'w') as fd: fcntl.flock(fd, fcntl.LOCK_EX | fcntl.LOCK_NB) fd.write('coco')
在终端运行 ceshi1.py hang住10s 并获得锁
在终端运行 ceshi2.py 没有获得锁,会报错