我有一个在 Amazon EC2 上运行的 Ubuntu 9.10 映像,并且我已经设置了一个备份脚本 ec2-consisten-snapshot。
我能够从 SSH 运行脚本,一切正常。
sudo ec2-consistent-snapshot --mysql --xfs-filesystem /vol vol-xxxxxxx >>/mnt/backup.log 2>&1
但是,当我在 sudo crontab -e 中安排 cron 作业时,脚本运行但给了我错误。
12 18 4 2 * ec2-consistent-snapshot --mysql --xfs-filesystem /vol vol-xxxxxxx >>/mnt/backup.log 2>&1
ec2-consistent-snapshot:错误:在 /usr/bin/ec2-consistent-snapshot 第 76 行找不到 AWS 访问密钥或秘密访问密钥。xfs_freeze:无法解冻安装在 /vol 的文件系统:无效参数 ec2-consistent-snapshot : 错误: xfs_freeze -u /vol: 失败(256)
AWS 访问密钥位于 $HOME/.awssecret 下,如果您不从 cron 运行它,则可以正常工作
有人可以指出我需要做什么,过去一周我一直在努力解决这个问题。另外,我如何对从命令行正常工作的 xfs_freeze 进行故障排除。
非常感谢!
McLovin:我是 ec2-consistent-snapshot 的主要作者。如果您将 .awssecret 复制到 /root/.awssecret 它应该可以按照您的意愿运行。如果您查看手册页,还有许多其他方法可以传递访问密钥 ID 和秘密访问密钥。
xfs_freeze 错误只是由于先前的错误而发生。如果您尝试解冻尚未冻结的文件系统,则此软件的最新版本会出现错误。您可以忽略该错误,但修复此类行为的补丁已经在审核中。
我会在此处添加对各种资源的有用链接,但 serverfault 还不够信任我 :)
sudo crontab -e
编辑root的crontab对吗?当您说您有 $HOME/.awssecret 时,什么是 $HOME?根的家还是你的家?您可能想考虑使用 /etc/cron.d,您可以另外添加用户名来执行脚本,就像在这些文件中一样(例如注意:脚本的语法略有不同)
编辑(在评论中回答您的问题):
创建文件
/etc/cron.d/myEc2Crontab
使其包含:
请注意在时间规范之后添加的“根”,在您的命令之前。这指定了命令运行的用户。
根据它的配置,sudo 在运行时不会重置所有环境变量。例如,当我在 Ubuntu 9.10 中 sudo 时,$HOME 仍然指向我用户的主目录,而不是根目录!
在您的脚本中,将 $HOME 替换为 .awssecret 的完整路径。