zhetmdoubeizhanyong
johopig
采纳率100%
2019-08-31 23:44

centos crond不执行shell

5

首先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条回答

  • weixin_43975295 weixin_43975295 2年前

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

    点赞 评论 复制链接分享
  • liang_shui_guo liang_shui_guo 2年前

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

    点赞 1 评论 复制链接分享
  • zhouchao6 zhouchao6 2年前

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

    点赞 1 评论 复制链接分享

为你推荐