欢迎光临
我们一直在努力

VPS 网站数据全自动每天备份方法分享:rsync + crontab

分享下网站数据全自动每天备份的方法。

相关图片

一、材料准备

除了自己建站的服务器外,还需要一台 VPS 作为备份服务器,这一台 VPS 的线路不是特别重要,数据可以慢慢传输,能稳定传完就行了,最好找一个跟你建站 VPS 之间传输速度还可以的 VPS 作为备份服务器。

根据你网站数据的多少决定备份服务器的硬盘容量,网站需要备份的数据包括数据库数据(一般就几十兆)和网站数据,这个如果你图片比较多的话可能会上 G,所以如果每天备份的话需要备份服务器的硬盘容量大于 30G(如果你每天备份,每月清理一次数据的话)。

二、数据同步设置

两台 VPS 之间的数据传输借助的是 rsync,这里介绍一个传输命令:

rsync -avP data.zip [email protected].11.11.11:/root/backup

这条命令的作用是将建站 VPS 上的 data.zip 传输到备份 VPS(IP 为 104.11.11.11)上的 /root/backup 目录下。

备份思路很清楚:

  1. 导出数据库;
  2. 压缩网站数据;
  3. 将数据库数据和网站数据打包好;
  4. 利用 rsync 将打包后的数据传输到备份 VPS 上。

这里分享一个写好的打包与传输脚本,保存为 backup.sh:

DATE=$(date +%Y%m)
BLOG_DIR='/home/wwwroot/www.pianyivps.com'
BLOG_NAME='www.pianyivps.com'
MYSQL_USER='user'
MYSQL_PASS='password'
DB='db'
BACKUP_DIR='/root/backup'
BACKUP_IP_DEST='104.11.11.11'
BACKUP_DIR_DEST='/root/backup'
if [ ! -d ${BACKUP_DIR} ]; then
  mkdir ${BACKUP_DIR}
fi
cd ${BACKUP_DIR}
 
mysqldump -u$MYSQL_USER -p$MYSQL_PASS ${DB} > ${DB}_${DATE}.sql
 
echo "SQL size: $(wc -c ${DB}_${DATE}.sql | awk '{print $1}')"
 
zip -r ${BLOG_NAME}_${DATE}.zip ${BLOG_DIR} > /dev/null
 
echo "WWW size: $(wc -c ${BLOG_NAME}_${DATE}.zip | awk '{print $1}')"
 
zip ${BLOG_NAME}_${DATE}_ALL.zip ${BLOG_NAME}_${DATE}.zip ${DB}_${DATE}.sql > /dev/null
 
rsync -avP ${BLOG_NAME}_${DATE}_ALL.zip [email protected]${BACKUP_IP_DEST}:${BACKUP_DIR_DEST}
 
rm -rf ${DB}_${DATE}.sql ${BLOG_NAME}_${DATE}.zip ${BLOG_NAME}_${DATE}_ALL.zip
 
echo ${BLOG_NAME}_${DATE}_DONE

为了防止每次传输数据都需要输入 root 密码,那么可以先配置好 SSH 公钥。

1.在建站 VPS 上生成 SSH 公钥

生成 SSH 公钥的命令如下,一路回车即可,生成的公钥为 /root/.ssh/id_rsa.pub

ssh-keygen

2.将建站 VPS 的 SSH 公钥保存到备份 VPS 上

将刚才的 id_rsa.pub 重命名,例如这里我重命名为 pianyivps.pub,再把文件拷贝到备份 VPS 的 /root/.ssh 下,将改公钥保存到备份 VPS 上:

cat pianyivps.pub >> authorized_keys

之后,再用 rsync 时就不需要输入 root 密码了。

三、定时任务设置

最后的定时任务就是借助 crontab 命令了,例如我希望每天 0:30 备份网站数据:

# 每天0点30分执行/root/backup.sh脚本,执行的日志保存在/root/backup.log中
30 0 * * * /root/backup.sh >> /root/backup.log 2>&1

OK,大功告成,数据每日自动备份,高枕无忧。

赞(0) 打赏
未经允许不得转载:老赵部落 » VPS 网站数据全自动每天备份方法分享:rsync + crontab

评论 抢沙发