几个独立的进程间如何共享锁

2022-05-27 14:32:13 +08:00
 mzmxcvbn

几个独立的进程(不是由一个 fork 出来的,都是单独跑的)去读写一个文件,为了避免写乱,想着在读写文件时加锁,想问一下大佬们,几个独立的进程间如何共享锁,在同一台设备上的。

2477 次点击
所在节点    Python
13 条回复
WildCat
2022-05-27 14:35:36 +08:00
参考 SQLite
参考 Git
eote
2022-05-27 14:37:26 +08:00
不考虑高并发的情况,可以写之前判断指定目录有没有特定空文件,没有则生成,写完再删
mingl0280
2022-05-27 14:39:15 +08:00
flock
shared pthread lock
semaphore
就这三种,随便想用哪种咯
eote
2022-05-27 14:40:22 +08:00
考虑并发就起个 redis 或者数据库
GeruzoniAnsasu
2022-05-27 14:40:22 +08:00
文件锁是内核处理的,不需要「共享」锁,只需要正确地访问文件就够了。

https://man7.org/linux/man-pages/man2/flock.2.html
TigerJie
2022-05-27 14:40:55 +08:00
cubecube
2022-05-27 14:43:32 +08:00
性能要求不高的话,/var/run 下面弄个文件锁就行。。
codehz
2022-05-27 15:26:45 +08:00
看你需求,用锁的方案楼上都有写
如果是每个进程都是往尾部写的情况,倒是可以用 append 模式打开文件,然后一次只发一行(关闭缓冲区避免拆分),日志都是这样做的
LeegoYih
2022-05-27 17:53:34 +08:00
windows 可以调 win32api ,用 mutex 互斥体
LeeReamond
2022-06-03 01:01:01 +08:00
借楼问一下,类似 flock 这种内核提供的文件锁,楼上文档里写是没有超时时间接口的,如果 A 进程获取锁以后挂了,那锁不是永远放不出来了?
GeruzoniAnsasu
2022-06-04 18:57:36 +08:00
@LeeReamond A 进程如果还能消失,那么说明内核已经正确处理了这个进程所有资源的释放,包括它持有的任何锁和 fd 。但你要说那种常见的 .lock 文件由于进程崩了没删掉导致程序误判,那属于逻辑问题,跟锁本身无关
LeeReamond
2022-06-05 14:25:39 +08:00
@GeruzoniAnsasu 进程彻底消失的话系统分配的资源也会被释放,很合理。是否存在一种中间状态,比如 windows 操作系统中有类似程序未响应,等待响应的状态,此时资源也没有释放,业务逻辑也没有执行
GeruzoniAnsasu
2022-06-05 18:42:00 +08:00
@LeeReamond 当然是有可能的,所以一般还会有非阻塞的使用方式,比如 flock 有个 LOCK_NB 控制位

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/855677

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX