前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >crontab 踩坑之绝对路径

crontab 踩坑之绝对路径

作者头像
ihoey
发布2018-10-31 16:23:22
5.9K0
发布2018-10-31 16:23:22
举报
文章被收录于专栏:梦魇小栈梦魇小栈

由于放假后网络原因不方便使用电脑,需要创建一个 crontab 定时任务,用来在每天固定时间执行一个 Shell 脚本

过程

添加计划任务

代码语言:javascript
复制
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=-~" # 每天九点半执行一次

重启计划任务

代码语言:javascript
复制
sudo service crond start

到了时间以后发现第一个没有反应,第二个是有效的,后来一步步排查问题发现问题

问题

Shell 脚本中,有对该脚本所在目录的相关文件进行操作的逻辑,在一开始实现时,对当前目录的文件操作时都是使用的相对目录,即 ./* 。在终端直接 sh 执行时没有任何问题,正常结束,而一旦在 crontab 中定时执行时,就出现问题,如提示 file not found 或者没有任何输出等错误。

之前的脚本内容是

代码语言:javascript
复制
echo "test" >> temp.txt
git add .
git commit -m"更新"
git push origin master

解决问题

出现问题后,我在脚本中试着打印出 crontab 执行时的当前目录,如 curPath=$(pwd) ,执行后发现,打印出的结果为 $HOME 的目录,而非脚本所在的原始目录,这就造成了在脚本中使用相对路径时出现找不到的情况。

找到问题后,解决方法有两个:

  • 将相对路径替换为绝对路径。(ps:如脚本中包含某些Shell命令,且命令的某些参数为默认当前目录的,都需要显式的给出绝对路径)
  • 在操作相对路径之前,使用 cd /....../ ,在执行脚本时强制进入到该目录。
代码语言:javascript
复制
cd /root/home/

echo "test" >> temp.txt
git add .
git commit -m"更新"
git push origin master

排查问题可以查看日志来看是否执行

代码语言:javascript
复制
#编辑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 命令来使配置生效。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-02-132,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 过程
    • 添加计划任务
      • 重启计划任务
      • 问题
      • 解决问题
        • 排查问题可以查看日志来看是否执行
        • 附录
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档