ubuntu crontab 踩坑实录

Linux crontab是用来定期执行程序的命令。
通过crontab -e 可以编辑需要定时执行的命令。

这里记录一下在ubuntu上实际使用crontab的几个坑。

log显示问题

cron 日志中记录了crontab中命令执行信息。
Ubuntu系统默认是不打开cron日志的。需要进行几步操作。

先打开以下文件

vi /etc/rsyslog.d/50-default.conf

在文件中找到cron.*一行,把前面的#去掉,保存退出。
执行以下命令,重启系统日志:

sudo service rsyslog restart

稍微等下就能在/var/log目录下看到cron.log 文件了。

相对路径问题

如果程序直接运行没问题,但在crontab中执行效果不符合预期(要先通过查看log确定目标程序被执行了),很可能是由于路径问题,crontab中命令的默认执行路径是当前用户的根路径,建议在待执行程序中先添加cd命令,或直接使用绝对路径。

时间设置问题

crontab 的基本设置方式在网上很好找到,
这里引用菜鸟教程的说明:
ubuntu crontab 踩坑实录_第1张图片
网上很多教程给了一个错误的例子(包括菜鸟教程),假定待执行命令为: /dir/test.sh

* */1 * * * /dir/test.sh

很多教程说上面命令代表每小时执行一次,亲测之后发现上面的命令时每分钟执行一次。查阅了这篇博客中也给出了同样的结果。

猜测原因是由于上面的命令中第一位分钟是*号,代表所有取值范围,也就是每一分钟。
如果想每小时执行一次,可以采用如下写法:

*/60 * * * * /dir/test.sh

此方法亲测可用。
或者采用下面的写法(未亲测):

1 */1 * * * /dir/test.sh

代表每小时的第一分钟执行。

参考资料:
1.https://blog.csdn.net/k_young1997/article/details/81606667
2.https://blog.csdn.net/liu0808/article/details/80668705
3.https://www.runoob.com/w3cnote/linux-crontab-tasks.html

你可能感兴趣的:(ubuntu,linux)