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'
每天进步一点点,更多精彩内容,欢迎关注公众号“编程社”!!!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 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 热点速览」