问题提出
如题,原本需要手动执行的任务,我现在想用crontab周期性执行,具体情况为每一天固定时间执行一次。
以下是我原本代码(不用crontab,手动执行)
$ time bash taskrunner.sh >log/`date +"%Y%m%d"`_formal.log 2>&1
这是个很好理解的代码。我运行taskrunner.sh脚本,然后将脚本的"标准输出"重定向到20190813_formal.log文件中(对今天而言),然后将"标准错误"也重定向到标准输出中。这个直接在shell中可以运行。
不过,一旦你将这行命令通过crontab -e编辑到crontab脚本中,如下所示:
*/5 * * * * time bash tashrunner.sh >log/`date +"%Y%m%d"`_formal.log 2>&1
那么结果就是啥也没发生。。。crontab并没有将你的程序每隔5分钟执行一次,甚至20190813_formal.log文件都没有生成。
So,why??
问题解决
如果你确定你的日志文件和可执行脚本的路径没有问题(在crontab中最好都使用绝对路径),那么问题就是出在字符的转义上。crontab文件中无法理解%的含义,因而需要将%转义。所以上面的crontab命令应该写成下面这样:
*/5 * * * * time bash tashrunner.sh >log/`date +"\%Y\%m\%d"`_formal.log 2>&1
PS,反引号中的内容:'date'和后面的'+.....'之间,要有一个空格,否则date命令无法执行