我的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 = your@example.com”放在crontab中也没有?
如果pg_dump或gzip不在系统默认路径上,您可能还需要在crontab中设置PATH(因此使用“type pg_dump”来检查它们的位置,crontab通常只在/ bin或/usr/bin中运行命令)