linux中的定时任务crontab会定时执行一些脚本,但是脚本的时间往往无法控制,当脚本的执行时间过长,可能会导致上一次任务的脚本还没执行完,下一次任务的脚本又开始执行的问题。这种情况下会出现一些并发问题,严重时会导致出现脏数据或性能瓶颈的恶性循环。
通过使用flock建立排他锁可以规避这个问题
#!/bin/sh
echo "---------------------------"
echo "start at `date '+%Y-%m-%d %H:%M:%S'` ..."
sleep
echo "finished at `date '+%Y-%m-%d %H:%M:%S'` ..."
#crontab -e */ * * * * 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 -- :: ...
finished at -- :: ...
---------------------------
start at -- :: ...
finished at -- :: ...
---------------------------
start at -- :: ...
finished at -- :: ...
---------------------------
start at -- :: ...
finished at -- :: ...
观察日志定时任务还是以90秒一次在执行,而不是定时任务的每60秒执行一次