由于放假后网络原因不方便使用电脑,需要创建一个 crontab 定时任务,用来在每天固定时间执行一个 Shell 脚本
crontab -e
* 10,19 * * * sh /root/home/cron.sh >> /root/home/temp.txt #每天10点和19点执行一次,路径一定要是绝对路径
30 9 * * * curl "https://sc.ftqq.com/SCU10625Td571049c53dd2e36148f134*****44ef59855df9df77c.send?text=-~" # 每天九点半执行一次sudo service crond start到了时间以后发现第一个没有反应,第二个是有效的,后来一步步排查问题发现问题
在 Shell 脚本中,有对该脚本所在目录的相关文件进行操作的逻辑,在一开始实现时,对当前目录的文件操作时都是使用的相对目录,即 ./* 。在终端直接 sh 执行时没有任何问题,正常结束,而一旦在 crontab 中定时执行时,就出现问题,如提示 file not found 或者没有任何输出等错误。
之前的脚本内容是
echo "test" >> temp.txt
git add .
git commit -m"更新"
git push origin master出现问题后,我在脚本中试着打印出 crontab 执行时的当前目录,如 curPath=$(pwd) ,执行后发现,打印出的结果为 $HOME 的目录,而非脚本所在的原始目录,这就造成了在脚本中使用相对路径时出现找不到的情况。
找到问题后,解决方法有两个:
cd /....../ ,在执行脚本时强制进入到该目录。cd /root/home/
echo "test" >> temp.txt
git add .
git commit -m"更新"
git push origin master#编辑rsyslog
sudo vim /etc/rsyslog.d/50-default.conf
#找到rsyslog中cron一行将前面的注释符#去掉
cron.* /var/log/cron.log
#重启rsyslog
sudo service rsyslog restart
# 然后查看日志,到指定时间看是否执行
tail -f /var/log/cron.log系统在执行定时任务时,是不会加载任何环境变量的,所以当脚本需要环境变量时,可以通过在脚本中添加 source /etc/profile 命令来使配置生效。