几个独立的进程(不是由一个 fork 出来的,都是单独跑的)去读写一个文件,为了避免写乱,想着在读写文件时加锁,想问一下大佬们,几个独立的进程间如何共享锁,在同一台设备上的。
![]() | 1 WildCat 2022-05-27 14:35:36 +08:00 参考 SQLite 参考 Git |
![]() | 2 eote 2022-05-27 14:37:26 +08:00 不考虑高并发的情况,可以写之前判断指定目录有没有特定空文件,没有则生成,写完再删 |
![]() | 3 mingl0280 2022-05-27 14:39:15 +08:00 flock shared pthread lock semaphore 就这三种,随便想用哪种咯 |
![]() | 考虑并发就起个 redis 或者数据库 |
5 GeruzoniAnsasu 2022-05-27 14:40:22 +08:00 |
![]() | 6 TigerJie 2022-05-27 14:40:55 +08:00 |
![]() | 7 cubecube 2022-05-27 14:43:32 +08:00 性能要求不高的话,/var/run 下面弄个文件锁就行。。 |
![]() | 8 codehz 2022-05-27 15:26:45 +08:00 看你需求,用锁的方案楼上都有写 如果是每个进程都是往尾部写的情况,倒是可以用 append 模式打开文件,然后一次只发一行(关闭缓冲区避免拆分),日志都是这样做的 |
![]() | 9 LeegoYih 2022-05-27 17:53:34 +08:00 windows 可以调 win32api ,用 mutex 互斥体 |
![]() | 10 LeeReamond 2022-06-03 01:01:01 +08:00 借楼问一下,类似 flock 这种内核提供的文件锁,楼上文档里写是没有超时时间接口的,如果 A 进程获取锁以后挂了,那锁不是永远放不出来了? |
11 GeruzoniAnsasu 2022-06-04 18:57:36 +08:00 @LeeReamond A 进程如果还能消失,那么说明内核已经正确处理了这个进程所有资源的释放,包括它持有的任何锁和 fd 。但你要说那种常见的 .lock 文件由于进程崩了没删掉导致程序误判,那属于逻辑问题,跟锁本身无关 |
![]() | 12 LeeReamond 2022-06-05 14:25:39 +08:00 @GeruzoniAnsasu 进程彻底消失的话系统分配的资源也会被释放,很合理。是否存在一种中间状态,比如 windows 操作系统中有类似程序未响应,等待响应的状态,此时资源也没有释放,业务逻辑也没有执行 |
13 GeruzoniAnsasu 2022-06-05 18:42:00 +08:00 @LeeReamond 当然是有可能的,所以一般还会有非阻塞的使用方式,比如 flock 有个 LOCK_NB 控制位 |