数据无价,且行且珍惜

你的每一个谨慎操作都有可能造成数据丢失甚至销毁
所以,及时备份很重要

所谓备份,就是将数据及时 copy 到其它地方进行存储,正所谓“鸡蛋不要放在一个篮子里”,数据存储也一样。

思路

  1. 每天定时进行对数据打包;
  2. 打包完成后发送电子邮件;
  3. 发送成功后将备份数据删除(主要考虑 空间容量问题);

数据打包备份,需要编写脚本,然后做定时任务

#!/usr/bin/bash

# mail 发送中文邮件会有乱码情况,特别是调用脚本的时候
# 加上这两行代码,可以有效解决 中文乱码问题
export LANG="zh_CN.UTF-8"
export LC_ALL="zh_CN.UTF-8"

# 这是一个网站数据打包备份脚本
# 脚本中涉及到的目录请根据自己环境进行修改:如 PHP目录、Nginx目录、web目录等

dtime=$(date "+%Y")
# 准备需要备份的文件
function webBack(){
    # 备份 PHP 配置文件,如果不需要可忽略
    cp -r /usr/local/php/etc /usr/local/nginx/html/
    
    # 备份 Nginx 配置文件,如果不需要可忽略了
    cp -r /usr/local/nginx/conf /usr/local/nginx/html/

    # 备份数据库,这里假定 数据名称为 typecho
    mysqldump -u typecho -pAb123456 --databases typecho > /usr/local/nginx/html/webDB_$dtime.sql

    # 打包数据
    tar -czf /usr/local/nginx/webBack_$dtime.tar.gz -C /usr/local/nginx/html .
}

# 发送电子邮件,这里涉及代发邮件问题,需要配置相关的mail
function sendmail(){
    echo "$dtime: 网站数据备份" | mail -s "$dtime: 网站数据备份" -a /usr/local/nginx/webBack_$dtime.tar.gz databack@qq.com
}

# 开始打包备份、发送邮件、删除备份文件
webBack && sendmail && rm -rf /usr/local/nginx/webBack_$dtime.tar.gz
rm -rf /usr/local/nginx/html/webDB_$dtime.sql
rm -rf /usr/local/nginx/html/conf
rm -rf /usr/local/nginx/html/etc

mail 发送邮件配置

  • 如果没有 mail 命里,请进行安装

    # Redhat 系列
    yum install -y mail
    
    # Debian 系列
    apt-get install mail   
  • 配置mail
    vim /etc/mail.rc 增加如下代码

    # 发件人地址
    set from=xxxx@126.com
    # smtp 服务器,也就是邮件服务商
    set smtp=smtp.126.com
    # 邮件真实账号
    set smtp-auth-user=xx@126.com
    # 登陆密码,有些服务商会要求填写授权码
    set smtp-auth-password=xxx
    set smtp-auth=login

定时任务配置

[root@VM-0-17-centos ~]# crontab -e

# 添加如下计划任务,脚本路径建议写绝对路径
# 每天 凌晨 3:00 执行一次脚本
0 3 * * * /usr/bin/bash /usr/local/nginx/web_back.sh

「 希望熬过一切,星光璀璨 」

流年小站,感谢有您的支持

「 道路坎坷,感谢有您 ---来自 anYun 的感谢 」

使用微信扫描二维码完成支付

2021-06-14
已阅:11859 人/次

 
 
 
分享是一种美德 x
打开微信,右上角的"+"选择"扫一扫"
使用“扫一扫”将博文分享至朋友圈吧

本文由 anYun 创作,采用 知识共享署名 3.0,可自由转载、引用,但需署名作者且注明文章出处。
我的博客即将同步至腾讯云开发者社区,邀请大家一同入驻:https://cloud.tencent.com/developer/support-plan?invite_code=3oibnoh9lo6cs

还不快抢沙发

添加新评论

Myssl安全认证