随笔 - 144  文章 - 0  评论 - 2  阅读 - 19万

Linux下面Crontab文件锁实现进程互斥

这个方案目前已经是比较成熟,主要是结合flock来实现,这里做一下记录。

理论基础

实现格式:
flock [-sxun][-w #] fd#
flock [-sxon][-w #] file [-c] command...

常用选项如下:
-s, --shared:获得一个共享的锁。
-x, --exclusive:获得一个独占的锁。
-u, --unlock:移除一个锁,通常是不需要的,脚本执行完后会自动丢弃锁。
-n, --nonblock:如果没有立即获得锁直接失败而不是等待。
-w, --timeout:如果没有立即获得锁就等待指定的时间。
-o, --close:在运行命令前关闭文件的描述符。用于如果命令产生子进程时会不受锁的管控。
-c, --command:在shell中运行一个单独的命令。
-h, --help:显示帮助。
-V, --version:显示版本。

具体实现

如下面的实例,原计划每5秒执行一次test脚本,同时产生test.lock文件,如果5秒时间前一个进程没有执行完,后面一个进程发起了,便会放弃本次操作。

*/5 * * * * flock -x -n /tmp/test.lock -c '/test.sh'

每天进步一点点,更多精彩内容,欢迎关注公众号“编程社”!!!
在这里插入图片描述

posted on   黑夜开发者  阅读(25)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
· AI 智能体引爆开源社区「GitHub 热点速览」
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示