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

2016年10月25日 08:21:19  阅读 301 次 评论 17 条

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

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

七天循环备份说明:

七天循环备份的意思就是总共保留七份备份文件,到第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://www.yigujin.cn/994.html
版权声明:本文为原创文章,版权归 懿古今 所有,欢迎分享本文,转载请保留出处!

相关文章 分类热门分类热评随机文章

发表评论


表情

  1. 野人摊影视分享
    野人摊影视分享 【主管】 @回复

    建立七天循环备份任务计划的第二步,无法完成,提示不存在这个文件,但是我第一步已经安装了,不知道博主能否帮忙下

    • 懿古今
      懿古今【老板】2016-10-30 22:57  回复

      @野人摊影视分享这个建议你去问张戈博主,我是根据他的文章折腾的,万幸的是直接成功了,对于这个服务器我只会根据教程折腾

  2. 热腾网
    热腾网 【经理】 @回复

    博主最后说的对,现在阿里云的OSS价格又低了。

  3. 橘子书
    橘子书 【副总】 @回复

    这个方法都是有趣。可以考虑。不过习惯纯手工备份。

    • 懿古今
      懿古今【老板】2016-10-25 22:25  回复

      @橘子书我以前是安装插件自动完成的,后来发现这个挺简单的,让服务器自动完成,挺好的

  4. 我爱动感单车网
    我爱动感单车网 【副总】 @回复

    使用虚拟主机的咱,与此无缘啊!

  5. 网赚博客
    网赚博客 【试用】 @回复

    多些的分享

  6. 商商博客
    商商博客 【实习】 @回复

    不错的

  7. Koolight
    Koolight 【副总】 @回复

    虚拟空间表示心有余而力不足。

    • 我爱动感单车网
      我爱动感单车网 【副总】2016-10-25 15:07  回复

      @Koolight那今后也弄个服务器玩玩吧,一定会爽上很多的吧。

    • 懿古今
      懿古今【老板】2016-10-25 22:29  回复

      @Koolight[偷笑] 虚拟空间更好,不容花时间去折腾它,我发现阿里云的虚拟主机比ECS服务器还要贵,所以才买服务器的,要不然也是使用虚拟主机,省事很多

      • 我爱动感单车网
        我爱动感单车网 【副总】2016-10-27 12:56  回复

        @懿古今是啊,阿里云的虚拟主机真的挺贵的,那价格有点令人咋舌!难道它很好很好吗?

  8. QQ-13501128
    QQ-13501128 【实习】 @回复

    学习带来乐趣,谢谢博主!