我的crontab中有一个如下所示的条目:
0 3 * * * pg_dump mydb | gzip > ~/backup/db/$(date +%Y-%m-%d).psql.gz
当我从shell执行它时,该脚本工作正常,但它似乎并不是每晚都在运行.我假设权限有问题,也许crontab在不同的用户或其他东西下运行.我该怎么调试呢?我是一个共享托管环境(WebFaction).
解决方法
您需要使用反斜杠转义crontab条目中的“%”字符 – 请参阅crontab(5)联机帮助页.我有完全相同的问题.
例如:
0 7 * * * MysqLdump usblog | bzip2 -c > usblog.$(date --utc +\%Y-\%m-\%dT\%H-\%M-\%sZ).sql.bz2
你没有收到有关cron错误的电子邮件吗?即使你把“MAILTO = [email protected]”放在crontab中也没有?
如果pg_dump或gzip不在系统默认路径上,您可能还需要在crontab中设置PATH(因此使用“type pg_dump”来检查它们的位置,crontab通常只在/ bin或/usr/bin中运行命令)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。