linux中的定时任务crontab会定时执行一些脚本,但是脚本的时间往往无法控制,当脚本的执行时间过长,可能会导致上一次任务的脚本还没执行完,下一次任务的脚本又开始执行的问题。这种情况下会出现一些并发问题,严重时会导致出现脏数据或性能瓶颈的恶性循环。
通过使用flock建立排他锁可以规避这个问题
#!/bin/sh echo "---------------------------" echo "start at `date '+%Y-%m-%d %H:%M:%S'` ..." sleep 90 echo "finished at `date '+%Y-%m-%d %H:%M:%S'` ..."
#crontab -e */1 * * * * flock -xn /dev/shm/test.lock -c "sh /root/scripts/flock.sh >> /tmp/flock.log"
-x --exclusive 获得一个独占锁
-n --nonblock 如果没有立即获得锁,直接失败而不是等待
-c --command 在shell中运行一个单独的命令
flock.log输出:
--------------------------- start at 2018-08-21 13:10:01 ... finished at 2018-08-21 13:11:31 ... --------------------------- start at 2018-08-21 13:12:01 ... finished at 2018-08-21 13:13:31 ... --------------------------- start at 2018-08-21 13:14:01 ... finished at 2018-08-21 13:15:31 ... --------------------------- start at 2018-08-21 13:16:01 ... finished at 2018-08-21 13:17:31 ...
观察日志定时任务还是以90秒一次在执行,而不是定时任务的每60秒执行一次