Linux 下的文件锁

简介: 当进程想要修改文件的时候,申请独占锁(写锁),当进程想要读取文件数据的时候,申请共享锁(读锁)。
本文内容为 Linux 系统通用,各个语言实现可能稍有不同,但原理相同。

当多个进程或多个程序都想要修同一个文件的时候,如果不加控制,多进程或多程序将可能导致文件更新的丢失。

例如进程 1 和进程 2 都要写入数据到 a.txt 中,进程 1 获取到了文件句柄,进程 2 也获取到了文件句柄,然后进程 1 写入一段数据,进程 2 写入一段数据,进程 1 关闭文件句柄,会将数据 flush 到文件中,进程 2 也关闭文件句柄,也将 flush 到文件中,于是进程 1 的数据被进程 2 保存的数据覆盖了。

所以,多进程修改同一文件的时候,需要协调每个进程:

  • 保证文件在同一时间只能被一个进程修改,只有进程 1 修改完成之后,进程 2 才能获得修改权
  • 进程 1 获得了修改权,就不允许进程 2 去读取这个文件的数据,因为进程 2 可能读取出来的数据是进程 1 修改前的过期数据

这种协调方式可以通过文件锁来实现。

文件锁分类

文件锁分两种,

  • 独占锁(写锁)
  • 共享锁(读锁)

当进程想要修改文件的时候,申请独占锁(写锁),当进程想要读取文件数据的时候,申请共享锁(读锁)。

独占锁和独占锁、独占锁和共享锁都是互斥的。

只要进程 1 持有了独占锁,进程 2 想要申请独占锁或共享锁都将失败(阻塞),也就保证了 这一时刻只有进程 1 能修改文件,只有当进程 1 释放了独占锁,进程 2 才能继续申请到独占锁或共享锁。

但是共享锁和共享锁是可以共存的,这代表的是两个进程都只是要去读取数据,并不互相冲突。

文件锁:flock 和 lockf

Linux 上的文件锁类型主要有两种:flock 和 lockf。后者是 fcntl 系统调用的一个封装。它们之间有些区别:

  • flock 来自 BSD,而 fcntl 或 lockf 来自 POSIX,所以 lockf 或 fcntl 实现的锁也称为 POSIX 锁
  • flock 只能对整个文件加锁,而 fcntl 或 lockf 可以对文件中的部分加锁,即粒度更细的记录锁
  • flock 的锁是劝告锁,lockf 或 fcntl 可以实现强制锁。所谓劝告锁,是指只有多进程双方都遵纪守法地使用 flock 锁才有意义,某进程使用 flock,但另一进程不使用 flock,则 flock 锁对另一进程完全无限制
  • flock 锁是附加在(关联在)文件描述符上的(见下文更深入的描述),而 lockf 是关联在文件实体上的。本文后面将详细分析 flock 锁在文件描述符上的现象

参考文献

目录
相关文章
|
Linux
Linux下面Crontab文件锁实现进程互斥
Linux下面Crontab文件锁实现进程互斥
142 0
Linux下面Crontab文件锁实现进程互斥
【Linux】Linux文件锁
【Linux】Linux文件锁
|
人工智能 安全 Linux
Linux 挖矿程序把病毒文件锁住了,删不了,怎么破?(chattr)
本文就讲讲,怎么把这些加了锁的只读文件去 i 取消只读!
|
2月前
|
Linux 网络安全 数据安全/隐私保护
Linux 超级强大的十六进制 dump 工具:XXD 命令,我教你应该如何使用!
在 Linux 系统中,xxd 命令是一个强大的十六进制 dump 工具,可以将文件或数据以十六进制和 ASCII 字符形式显示,帮助用户深入了解和分析数据。本文详细介绍了 xxd 命令的基本用法、高级功能及实际应用案例,包括查看文件内容、指定输出格式、写入文件、数据比较、数据提取、数据转换和数据加密解密等。通过掌握这些技巧,用户可以更高效地处理各种数据问题。
120 8
|
2月前
|
监控 Linux
如何检查 Linux 内存使用量是否耗尽?这 5 个命令堪称绝了!
本文介绍了在Linux系统中检查内存使用情况的5个常用命令:`free`、`top`、`vmstat`、`pidstat` 和 `/proc/meminfo` 文件,帮助用户准确监控内存状态,确保系统稳定运行。
473 6
|
2月前
|
Linux
在 Linux 系统中,“cd”命令用于切换当前工作目录
在 Linux 系统中,“cd”命令用于切换当前工作目录。本文详细介绍了“cd”命令的基本用法和常见技巧,包括使用“.”、“..”、“~”、绝对路径和相对路径,以及快速切换到上一次工作目录等。此外,还探讨了高级技巧,如使用通配符、结合其他命令、在脚本中使用,以及实际应用案例,帮助读者提高工作效率。
98 3
|
2月前
|
监控 安全 Linux
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景,包括 ping(测试连通性)、traceroute(跟踪路由路径)、netstat(显示网络连接信息)、nmap(网络扫描)、ifconfig 和 ip(网络接口配置)。掌握这些命令有助于高效诊断和解决网络问题,保障网络稳定运行。
82 2
|
26天前
|
Linux Shell
Linux 10 个“who”命令示例
Linux 10 个“who”命令示例
52 14
Linux 10 个“who”命令示例