Linux文件锁flock
-
多个进程同时操作同一文件时,容易导致文件中数据混乱。因此,需要锁操作保证数据的完整性。
-
flock,建议性锁,不具备强制性。
-
三种主要操作类型
- LOCK_SH 共享锁,多个进程可以使用同一把锁,常用作读共享锁。
- LOCK_EX 排他锁,同时只允许一个进程使用,常被用作写锁。
- LOCK_UN 释放锁。
-
进程使用flock尝试锁文件时,如果文件已被其他进程锁住,进程会被阻塞直到锁释放掉。
-
可以在调用flock时,采用LOCK_NB参数,在尝试锁住该文件时,发现已被其他进程锁住,会返回错误,errno错误码为EWOULDBLOCK。
-
因此提供两种工作模式:阻塞与非阻塞类型。
FILE* fp = fopen("xxx","xx");
int lockfd = fileno(fp);
// 服务会阻塞等待直到锁被释放
flock(lockfd,LOCK_EX);
// 发现文件已经被锁住时,服务会返回错误
// ret = -1, errno = EWOULDBLOCK
ret = flock(lockfd, LOCK_EX | LOCK_NB);
- 释放flock
- 使用LOCK_UN参数释放
flock(fd, LOCK_UN)
- 关闭fd释放
// fp 文件指针
flcose(fp);