linux使用flock解决crontab任务冲突

Posted 枫叶那个飘啊

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux使用flock解决crontab任务冲突相关的知识,希望对你有一定的参考价值。

Linux的crontab最小的间隔是每分钟执行一次,但是如果在这一分钟之内,之前的命令并没有执行完成呢?这样就会产生冲突。接下来我介绍一个解决冲突的办法,那就是linux的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:   显示版本

 

下面是在crontab中的使用:

* * * * * flock -xn /tmp/aaa.lock -c php /home/aaa.php >> /home/aaa.log‘ . //-xn  文件锁使用独占锁,如果锁定则失败不等待。

 

以上是关于linux使用flock解决crontab任务冲突的主要内容,如果未能解决你的问题,请参考以下文章

flock防止crontab脚本周期内未执行完重复执行(转)

Linux crontab学习

linux下使用crontab命令执行定时任务

Crontab 里解决脚本冲突的问题

使用python crontab设置linux定时任务

Docker容器内运行定时任务crontab