centos crond不执行shell

首先restart_mysql.sh文件如下

# !/bin/sh
pidof mysqld >/dev/null
if [ $? -eq 0 ]
then
echo "running...">> ./mysql_log.txt
else
echo " mysql server was stopped">> ./mysql_log.txt
service mysql start
fi

crontab -e 进入编辑如下

*/2 * * * * /var/spool/cron/restart_mysql.sh

接着

service crond restart
```两分钟后去看 mysql_log.txt 是空的, 但是直接在该目录下 ./restart_mysql.sh之后去查看mysql_log.txt,能看到增加了一条信息。。。

3个回答

嗯,路径问题。一定要使用绝对路径,或者在脚本第一行就先写明cd到了哪个目录下去执行。
两点建议把:
1、脚本中无特殊需求的话,一定要使用绝对路径,否则会很容易出现找不到文件的问题。
2、脚本开头,尽量先引入环境变量。source /etc/profile; source ~/.bash.profile,因为你加到cron计划任务后,它并不是以root身份执行的,可能你用root来测试的时候一些命令可以用,但是加到了cron中那些命令就不能用了,因为用户的PATH变量都不一样。

应该是你看错mysql_log.txt文件了
crontab执行,这个文件是在你执行账号的家目录下,你手动执行,在哪个目录下执行,就会生成在哪个目录,可以把./换成绝对路径

使用绝对路径好查找,另外编辑完内容不需要重启crond

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!