我正在尝试在CEntOS 5.5机器上运行bash脚本,检查远程mysql服务器上的复制。该脚本创建一个临时锁定文件,并计划每分钟在Crontab中运行。但有一段时间,cron工作不同步 - 暂停或延迟工作两分钟,并尝试一次运行三个工作。这会产生误报,淹没我的邮箱说"锁定文件存在!可能的冲突"。
以下是可能感兴趣的脚本部分:
#!/bin/sh
lock_file=/tmp/slave_alert.lck
finished=0
# Alert function
function mail_alert () {
cat /var/log/replication_check.log | mail -s "Replication check errors!" mail@mail.com
}
# Check if lock file exists
if [ -f $lock_file ];
then
echo "Lock file exists! Possible conflict!" > /var/log/replication_check.log 2>&1
mail_alert
exit 1
else
touch $lock_file
fi
finished=1
while [ $finished -ne 0 ]
do
if [Replication is not configured or you do not have the required access to MySQL];
then
rm $lock_file
exit 1
fi
# Do some logic
sleep 1
done
rm $lock_file
echo "Script complete!"
exit 0
这是Cronjob:
* 0-1,4-23 * * * path/check_replication.sh > /dev/null 2>&1
以下是日志文件输出的一部分:/ var / log / cron。我们可以看到14:35和14:36被推迟了。
让我们将此字符串命名为CRONJOB =(root)CMD(path / check_replication.sh> / dev / null 2>& 1)
Sep 23 14:30:01 remote-host crond[3959]: CRONJOB
Sep 23 14:31:01 remote-host crond[4025]: CRONJOB
Sep 23 14:32:01 remote-host crond[4054]: CRONJOB
Sep 23 14:33:01 remote-host crond[4102]: CRONJOB
Sep 23 14:34:01 remote-host crond[4129]: CRONJOB
Sep 23 14:37:00 remote-host crond[4276]: CRONJOB
Sep 23 14:37:01 remote-host crond[4308]: CRONJOB
Sep 23 14:37:02 remote-host crond[4365]: CRONJOB
Sep 23 14:38:01 remote-host crond[4129]: CRONJOB
Sep 23 14:39:01 remote-host crond[4129]: CRONJOB