编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份

 查看数据和数据表

mysql -uroot -p'123456' -e 'show databases'

编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份_第1张图片

 mysql -uroot -p'123456' -e 'show tables from cb_d'

编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份_第2张图片

删除头部Database和数据库自带的表

mysql -uroot -p'123456' -e 'show databases' -N | egrep -v "information_schema|mysql|performance_schema|sys"

 编写脚本

#!/bin/bash
#********************************************************************
#Author: cb
#Date: 2023-11-02
#FileName: cbmysql.sh
#Description: The test script
#********************************************************************


#除去系统自带的库以外,再将存在的数据库名分别保存到dbname文件中
mysql -uroot -p'123456' -e 'show databases' -N | egrep -v 'information_schema|mysql|performance_schema|sys' > dbname

# 判断是否有/backup/db目录,没有则创建
[ -d /backup/db ] || mkdir -p /backup/db

#一行一行读取dbname中的库名,然后开始备份数据库,进而分别备份数据库中的表
while read line
do
        #备份数据库
        mysqldump -uroot -p'123456' -B $line | gzip > /backup/db/${line}_$(date +%F).sql.gz

        #分别将数据库中的表名保存到tbname文件中
        mysql -uroot -p'123456' -e "show tables from $line" -N > tbname

        #判断是否有/backup/db/$line目录,没有则创建
        [ -d /backup/db/$line ] || mkdir /backup/db/$line

        #读取tbname中的表名,备份数据表
        while read line2
        do
                #备份数据表
                mysqldump -uroot -p'123456' $line $line2 | gzip > /backup/db/$line/${line2}_$(date +%F).sql.gz
        done < tbname
done < dbname

检查脚本运行备份数据库

tree /backup/db

编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份_第3张图片

分表分库备份成功

还原检测

删除数据库并查看库

 mysql -uroot -p'123456' -e 'drop database cb_d'
mysql -uroot -p'123456' -e 'show databases'

编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份_第4张图片

开始还原

使用备份的库进行还原,由于是压缩文件,使用压缩还原

gunzip < /backup/db/cb_d_2023-11-02.sql.gz | mysql -uroot -p'123456' -B

查看数据库

编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份_第5张图片

 编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份_第6张图片

你可能感兴趣的:(数据库,mysql)