Linux文件锁flock

简介:

Linux文件锁flock

在多个进程同时操作同一份文件的过程中,很容易导致文件中的数据混乱,需要锁操作来保证数据的完整性,这里介绍的针对文件的锁,称之为“文件锁”-flock。

flock,建议性锁,不具备强制性。一个进程使用flock将文件锁住,另一个进程可以直接操作正在被锁的文件,修改文件中的数据,原因在于flock只是用于检测文件是否被加锁,针对文件已经被加锁,另一个进程写入数据的情况,内核不会阻止这个进程的写入操作,也就是建议性锁的内核处理策略。

flock主要三种操作类型:
LOCK_SH,共享锁,多个进程可以使用同一把锁,常被用作读共享锁;
LOCK_EX,排他锁,同时只允许一个进程使用,常被用作写锁;
LOCK_UN,释放锁;

进程使用flock尝试锁文件时,如果文件已经被其他进程锁住,进程会被阻塞直到锁被释放掉,或者在调用flock的时候,采用LOCK_NB参数,在尝试锁住该文件的时候,发现已经被其他服务锁住,会返回错误,errno错误码为EWOULDBLOCK。即提供两种工作模式:阻塞与非阻塞类型。

服务会阻塞等待直到锁被释放:
flock(lockfd,LOCK_EX)
服务会返回错误发现文件已经被锁住时:
ret = flock(lockfd,LOCK_EX|LOCK_NB)
同时ret = -1, errno = EWOULDBLOCK 

flock锁的释放非常具有特色,即可调用LOCK_UN参数来释放文件锁,也可以通过关闭fd的方式来释放文件锁(flock的第一个参数是fd),意味着flock会随着进程的关闭而被自动释放掉。

flock其中的一个使用场景为:检测进程是否已经存在;

复制代码
int checkexit(char* pfile)
{
    if (pfile == NULL)
    {   
        return -1; 
    }   
    int lockfd = open(pfile,O_RDWR);
    if (lockfd == -1) 
    {   
        return -2; 
    }   
    int iret = flock(lockfd,LOCK_EX|LOCK_NB);
    if (iret == -1) 
    {   
        return -3; 
    }   

    return 0;
}
复制代码

 



本文转自郝峰波博客园博客,原文链接:http://www.cnblogs.com/fengbohello/p/4262949.html,如需转载请自行联系原作者

相关文章
|
Linux C语言
Linux 中的文件锁定命令:flock、fcntl、lockfile、flockfile
Linux 中的文件锁定命令:flock、fcntl、lockfile、flockfile
542 0
|
Linux Shell C++
百度搜索:蓝易云【Linux 中的文件锁定命令:flock、fcntl、lockfile、flockfile 详细教程!】
以上是flock、fcntl、lockfile和flockfile这几个Linux中常用的文件锁定命令的简要介绍和使用教程。每个命令适用于不同的场景和编程环境,具体使用哪个命令取决于你的需求和所编写的应用程序或脚本。建议参考相关的文档和教程以获取更详细的信息和示例。
104 0
|
Linux
Linux下面Crontab文件锁实现进程互斥
Linux下面Crontab文件锁实现进程互斥
142 0
Linux下面Crontab文件锁实现进程互斥
|
Shell Linux 索引
Linux flock 原理(shell进阶)
flock申请的锁对象是处于 内核空间层的全局级别的open file table中的。
349 0
|
Linux Shell
Linux 基于flock命令实现多进程并发读写文件控制
Linux 基于flock命令实现多进程并发读写文件控制
670 0
|
Unix Linux Perl
Linux 下的文件锁
当进程想要修改文件的时候,申请独占锁(写锁),当进程想要读取文件数据的时候,申请共享锁(读锁)。
199 0
【Linux】Linux文件锁
【Linux】Linux文件锁
|
人工智能 安全 Linux
Linux 挖矿程序把病毒文件锁住了,删不了,怎么破?(chattr)
本文就讲讲,怎么把这些加了锁的只读文件去 i 取消只读!