1

我正在努力将 MongoDB 每日备份存储在 Amazon S3 上。这是我第一次使用 crontab 和 shell 脚本,但遇到了麻烦。我发现了一个似乎可以工作的脚本,但只有当我手动运行它时。这就是我所拥有的。

在 crontab 中(以 root 身份登录)。

* 2 * * * /mongo_backups/daily_script/mongobackup.sh

在我的脚本(mongobackup.sh)中。

#!/bin/sh

MONGODUMP_PATH="/usr/bin/mongodump"
MONGO_HOST="Aspire"
TIMESTAMP=`date +%F`
S3_BUCKET_PATH="Aspire_Backups"

# Create backup
$MONGODUMP_PATH --host $HOST

# Add timestamp to backup
mv dump mongodb-$HOSTNAME-$TIMESTAMP
tar cf mongodb-$HOSTNAME-$TIMESTAMP.tar mongodb-$HOSTNAME-$TIMESTAMP

# Upload to S3
s3cmd put mongodb-$HOSTNAME-$TIMESTAMP.tar s3://$S3_BUCKET_PATH/aspire-mongodb-  $HOSTNAME-$TIMESTAMP.tar

如果我使用 sh -x ./mongobackup.sh 手动运行脚本,这就是我得到的:

root@ip-10-4-149-188:/mongo_backups/daily_script# sh -x ./mongobackup.sh
+ MONGODUMP_PATH=/usr/bin/mongodump
+ MONGO_HOST=Aspire
+ date +%F
+ TIMESTAMP=2013-02-13
+ S3_BUCKET_PATH=Aspire_Backups
+ /usr/bin/mongodump --host
ERROR: required parameter is missing in 'host'

+ mv dump mongodb--2013-02-13
mv: cannot stat `dump': No such file or directory
+ tar cf mongodb--2013-02-13.tar mongodb--2013-02-13
tar: mongodb--2013-02-13: Cannot stat: No such file or directory
tar: Exiting with failure status due to previous errors
+ s3cmd put mongodb--2013-02-13.tar s3://Aspire_Backups/aspire-mongodb--2013-02-                                                                                                                        13.tar
mongodb--2013-02-13.tar -> s3://Aspire_Backups/aspire-mongodb--2013-02-13.tar  [                                                                                                                       1 of 1]
10240 of 10240   100% in    0s    42.59 kB/s  done

就像我说的,我是 crontab 和 shell 脚本的新手。我了解这里发生的大部分事情,但我仍在努力掌握总体思路。

4

1 回答 1

2

在脚本中你有:

$MONGODUMP_PATH --host $HOST

# Add timestamp to backup
mv dump mongodb-$HOSTNAME-$TIMESTAMP
tar cf mongodb-$HOSTNAME-$TIMESTAMP.tar mongodb-$HOSTNAME-$TIMESTAMP

这意味着您正在使用 variables $HOST$HOSTNAME并且$TIMESTAMP之前没有声明过。

尝试像这样声明它们

HOST=$(hostname)
HOSTNAME=$(hostname)
TIMESTAMP=$(date "+%Y%m%d") # it will output 20130213
于 2013-02-13T09:10:52.560 回答