UNIX 文件锁与文件管理全解析
1. 资源死锁避免
在文件操作中, lockf(2)
函数可能会返回 EDEADLK
错误,这意味着如果不返回错误,当前尝试的操作将会被无限期阻塞。这种情况通常发生在两个进程锁定了重叠的资源集,并且每个进程都在等待对方释放资源。
当遇到 EDEADLK
错误时,应用程序应释放已获取的所有锁,然后再次尝试操作。最终,进程将获取所需的所有锁。为避免死锁,所有进程最好按相同顺序锁定记录,例如先锁定偏移量最小的记录。若涉及多个文件,可先锁定 i - 节点号最小的文件。
2. 建议性锁
在未启用强制锁的情况下, lockf(2)
函数仅提供建议性锁。建议性锁要求所有访问同一文件的进程自愿使用 lockf(2)
函数。若有进程不遵循此约定,它可以无视已有的锁进行操作。
3. 使用 fcntl(2)
进行 POSIX 锁操作
POSIX 标准使用 fcntl(2)
应用程序接口来进行文件锁定,其函数原型如下:
#include <fcntl.h>
int fcntl(int fd, int cmd, struct flock *lck);
cmd:
F_GETLK, F_SETLK, or F_SETLKW
struct flock