MySQL 高级知识之使用 mysqldump 备份和恢复

一 前言

mysqldump是 MySQL 自带的备份工具,它可以实现对 MyISAM 表的温备份和对 innodb 表的热备份。但是它的还原速度很慢,在备份小型数据库时,使用很方便。

二 数据库备份类型

热备份 温备份 冷备份

  • 热备份:数据读写不受影响
  • 温备份:仅可以执行读操作
  • 冷备份:离线备份、读写均终止

物理备份 逻辑备份

  • 物理备份:复制数据文件
  • 逻辑备份:将数据导出成文本文件

完全备份 增量备份 差异备份

  • 完全备份:备份所有数据
  • 增量备份:仅备份上次完全备份或增量备份变化的数据
  • 差异备份:仅备份上次完全备份以来所有变化的数据

三 数据库备份

3.1 备份全库

# 备份全库
mysqldump -h192.168.1.11 -uroot -p123456 --all-databases > /opt/#{DATE}.sql

3.2 备份单库

# 备份单库
mysqldump -h192.168.1.11 -uroot -p123456 db-name > /opt/#{DATE}.sql

# 还原单库
mysql -uroot -p123456 db-name </opt/2021-11-12_10_29.sql

3.3 排除部分库备份

mysql -uroot -p'123456' -N -e "show databases;"|grep -Ev "information_schema|performance_schema|sys|mysql|database1"|xargs mysqldump -uroot -p'123456' --databases > /opt/#{DATE}.sql

3.4 备份脚本

创建备份脚本:vim backup.sh

#!/bin/bash
#备份 MySQL 数据库
db_user=root
db_password=123456
# 排除库名称
db_names="information_schema|mysql|performance_schema|sys"
echo "MySQL 数据库备份开始时间:...............$(date "+%Y-%m-%d %H:%M:%S")">>/home/project/backup-mysql/logs.log
mysql -u$db_user -p$db_password -N -e "show databases;"|grep -Ev $db_names|xargs mysqldump -u$db_user -p$db_password --databases |gzip > /home/project/backup-mysql/mysql-db-$(date "+%Y-%m-%d").sql.gz
echo "MySQL 数据库备份结束时间:...............$(date "+%Y-%m-%d %H:%M:%S")">>/home/project/backup-mysql/logs.log

3.5 自动化备份脚本

创建备份脚本:vim backup.sh

#!/bin/bash
# 定义备份用户/密码
DbUser=root
DbPasswd=123456

# 定义备份数据库
DbName=("neworg_prod_project" "prod_project")
# 定义备份目录
Path=/home/project/backup-mysql/data
# 定义备份数据保存天数 Mtime=3+1 天数也就是4天
Mtime=3
# 定时任务日志
LogPath=/home/project/backup-mysql/db_backup.log

Time=$(date +%F)
CurrentPath=$(pwd)

if ! [ -d ${Path} ];then
    mkdir ${Path}
fi

for i in ${DbName[@]};do
    if [ -d ${Path}/${Time} ];then
        cd ${Path}/${Time}
    else
        mkdir ${Path}/${Time} && cd ${Path}/${Time}
    fi
          mysqldump -f -x  -u${DbUser} -p${DbPasswd} ${i} >${i}.sql
                  zip ${i}.zip ${i}.sql
                  rm -f ${i}.sql
done

cd ${Path} && find ${Path} -name '*.sql' -mtime +${Mtime}|awk -F"/" '{print $3}'|xargs rm -rf

# 定时任务凌晨1点 自动添加
if ! (grep -r ${CurrentPath}/${0} /var/spool/cron/root &>/dev/null);then
        echo >> /var/spool/cron/root
        echo "#DBServer: Backup Database" >> /var/spool/cron/root
    echo "0 0 1 * * ? bash ${CurrentPath}/${0} >> ${LogPath}" >> /var/spool/cron/root
fi
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

十点摆码

有用你就打赏一下

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值