在终端输入以下命令可以直接运行,但丢进 crontab 就有问题了
echo -e "=== $(date '+%Y-%m-%d %H:%M:%S') start ===\n" >> /tmp/backup.log && cd /home/lukachen && rsync -chavzP --stats lukachen@192.168.1.1:/data/www/backup/* /home/lukachen/backup >> /tmp/backup.log 2>&1 && echo -e "=== $(date '+%Y-%m-%d %H:%M:%S') end ===\n" >> /tmp/backup.log
crontab -e
需要做一点微调:
# 每天凌晨2点10分, 跨机备份文件
10 02 * * * source ~/.bash_profile && echo -e "=== $(date '+\%Y-\%m-\%d \%H:\%M:\%S') start ===\n" >> /tmp/backup.log && cd /home/lukachen && rsync -chavzP --stats lukachen@192.168.1.1:/data/www/backup/* /home/lukachen/backup >> /tmp/backup.log 2>&1 && echo -e "=== $(date '+\%Y-\%m-\%d \%H:\%M:\%S') end ===\n" >> /tmp/backup.log
source ~/.bash_profile
易出错点:环境变量不同
解决方法:用上述 source 命令,使用当前用户环境变量,包括 alias、用户登录终端会做的一些初始化操作(如果 ~/.bash_profile 做的事情过多,这个命令一定程度上降低效率)
echo -e "=== $(date '+\%Y-\%m-\%d \%H:\%M:\%S') start ===\n" >> /tmp/backup.log
易出错点:% 在 crontab 里是特殊字符
解决方法:对 % 加反斜线转义
rsync -chavzP --stats lukachen@139.x.x.x:/data/www/backup/* /home/lukachen/backup >> /tmp/backup.log 2>&1
简单解释一下命令中 rsync 和 2>&1: