腾讯云服务器优惠活动华纳云香港服务器

ECS服务器实现本地七天循环备份数据库和网站文件

以前懿古今备份网站数据库和文件都是通过安装BackUpWordpress 插件来实现,刚开始还很好用,备份文件小的时候还能自动发送到指定邮箱中。不过秉承着能不用插件就不用插件的原则,终于根据张戈博主分享的《Linux/vps 本地七天循环备份和七牛远程备份脚本》成功实现本地七天循环备份数据库和网站文件,从而可以停用卸载 BackUpWordpress 插件了。

ECS服务器实现本地七天循环备份数据库和网站文件-第1张-boke112百科(boke112.com)

七天循环备份说明:

七天循环备份的意思就是总共保留七份备份文件,到第 8 天的时候就会覆盖第一天的备份文件,比如星期一到星期天总共七份备份文件,每次备份都将覆盖上星期同一天的文件,从而只备份 7 份数据,不至于占用特别大的空间。

准备工作

  • 整理 ECS 服务器已有网站的数据库用户名和密码;
  • 已有网站的根目录所在路径,如/home/wwwroot/yigujin.cn;
  • 本地存放备份文件的路径,如/home/wwwroot/wwwbackup。

本地七天循环备份具体步骤:

1、下载张戈博主分享的 VPS 备份脚本 backup.sh,并上传 backup.sh 到 ECS 服务器指定路径(如/home/wwwroot/wwwbackup),然后执行以下命令赋予其执行权限:

  1. chmod +x /home/wwwroot/wwwbackup/backup.sh

2、编写备份数据库文件和网站文件命令

①备份数据库文件命令:

  1. /home/wwwroot/wwwbackup/backup.sh db 网站域名(用于备份文件命名) 数据库名称 数据库用户名 数据库密码 备份文件存放路径

完整的命令如下:

  1. /home/wwwroot/wwwbackup/backup.sh db yigujin.cn yigujin_db root rootpasswd /home/wwwroot/wwwbackup/yigujin.cn

②备份网站文件命令:

  1. /home/wwwroot/wwwbackup/backup.sh file 网站域名(用于备份文件命名) 网站文件路径 备份文件存放路径

完整的命令如下:

  1. /home/wwwroot/wwwbackup/backup.sh file yigujin.cn /home/wwwroot/yigujin.cn  /home/wwwroot/wwwbackup/yigujin.cn

3、建立七天循环备份任务计划

①先执行 crontab -l 看看命令是否存在,若不存在,请使用yum -y install vixie-cron crontabs 安装 crond

②确认 crond 已存在后,请执行/etc/init.d/crond start 确保启动了 crond 服务,并执行 chkconfig crond on 设置为开机启动。

③执行 crontab -e 建立任务计划,如下是我 ECS 服务器的任务计划(只备份数据库文件,如还需备份网站文件,只需要按备份网站文件命令继续添加到任务计划即可),请参考添加:

  1. #backup boke112.com:
  2. 0 4 * * * /home/wwwroot/wwwbackup/backup.sh db boke112.com boke112com_db root 123456 /home/wwwroot/wwwbackup/boke112.com >/dev/null 2>&1
  3. #backup yigujin.cn:
  4. 30 3 * * * /home/wwwroot/wwwbackup/backup.sh db yigujin.cn yigujinwang_db root 123456 /home/wwwroot/wwwbackup/yigujin.cn >/dev/null 2>&1

其中,0 4 * * *为分 时 日 月 周,意思就是每天凌晨 4 点开始执行后面的命令行计划;>/dev/null 2>&1,表示屏蔽任何日志信息。

4、平滑重启 nginx

  1. /usr/local/nginx/sbin/nginx -s reload

至此,我的 ECS 服务器上两个站点的数据库文件都已经成功实现了本地七天循环备份机制,终于可以放心停用并卸载 BackUpWordpress 插件了。

特别说明:

1、本文的技术及代码均来自张戈博主分享的《Linux/vps 本地七天循环备份和七牛远程备份脚本》。

2、本想同时实现本地七天循环备份和七牛远程备份的,可惜七牛远程备份功能死活折腾都不成功,最后只能放弃。

3、由于我的主题文件和插件文件都很少改动,个人觉得完全没必要备份网站文件,所以我的七天备份任务计划中就没有添加网站备份的命令行,想要备份网站文件的可以参照步骤 2 中的备份网站文件命令添加。

4、如果手头相对宽裕的,不妨购买一个阿里云 OSS 对象存储来实现定时远程备份网站,具体效果更佳,具体可前往张戈博主分享的《Python&Shell 脚本结合阿里云 OSS 对象存储定时远程备份网站》学习。

本文地址:https://boke112.com/post/3598.html

赞 (0) 打赏
版权声明:本文为投稿文章,感谢 懿古今 的投稿,版权归原作者所有!发布此文是出于传递更多信息之目的,若有来源标注错误或侵犯了您的合法权益,请联系我们,确认后马上更正或删除,谢谢!
wu