Shell脚本实战——对MySQL进行分库分表备份

一、查看当前数据库以及数据表


如何除去Datebase标题字样以及系统自带的数据库呢?可以使用以下命令

bash 复制代码
mysql -uroot -p'#BenJM123' -e 'show databases' -N | egrep -v "information_schema|mysql|performance_schema|sys"

剩下的两个就是用户自己创建的表啦,我们要备份的就是这两个数据库中的数据

二、编写脚本

源码如下

bash 复制代码
#!/bin/bash
#********************************************************************
#Author: BenJM
#Date: 2023-07-26
#FileName: Mysql_Bak.sh
#Description: The test script
#********************************************************************


#除去系统自带的库以外,再将存在的数据库名分别保存到dbname文件中
mysql -uroot -p'#BenJM123' -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'#BenJM123' -B $line | gzip > /backup/db/${line}_$(date +%F).sql.gz

        #分别将数据库中的表名保存到tbname文件中
        mysql -uroot -p'#BenJM123' -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'#BenJM123' $line $line2 | gzip > /backup/db/$line/${line2}_$(date +%F).sql.gz
        done < tbname
done < dbname

三、检查测试

1.备份检验

运行脚本

查看是否生成备份文件

分库分表备份成功

2.还原检验

删除school和company数据库

删除掉了,只剩下系统自带的那几个数据库

开始还原

我们就直接选择用库的备份文件还原库,由于是压缩的备份文件,所以使用压缩还原

bash 复制代码
gunzip < /backup/db/school_2023-07-26.sql.gz | mysql -uroot -p'#BenJM123' -B
gunzip < /backup/db/company_2023-07-26.sql.gz | mysql -uroot -p'#BenJM123' -B

现在来查看还原情况

最后没有问题,数据还原成功

相关推荐
Highcharts.js27 分钟前
Highcharts Grid 中文站正式上线:表格数据处理的全新选择
前端·javascript·数据库·表格数据·highcharts·可视化图表·企业级图表
Elastic 中国社区官方博客4 小时前
Elasticsearch:使用 Agent Builder 的 A2A 实现 - 开发者的圣诞颂歌
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
2301_816660214 小时前
PHP怎么处理Eloquent Attribute Inference属性推断_Laravel从数据自动推导类型【操作】
jvm·数据库·python
qq_372154235 小时前
Go 中自定义类型与基础类型的显式转换规则详解
jvm·数据库·python
_下雨天.5 小时前
NoSQL之Redis配置与优化
数据库·redis·nosql
LiAo_1996_Y5 小时前
CSS如何实现文字渐变效果_通过background-clip实现艺术字
jvm·数据库·python
2401_887724506 小时前
CSS如何让表单在手机端友好展示_利用Flexbox实现堆叠排版
jvm·数据库·python
数据库小组6 小时前
MySQL 删库后怎么恢复?binlog2sql 之外,NineData 还能做什么
数据库·sql·mysql·安全·数据·ninedata·删库
zhangchaoxies6 小时前
Layui轮播图(carousel)怎么设置自动播放间隔
jvm·数据库·python
切糕师学AI6 小时前
HBase:一文搞懂分布式宽列数据库(原理 + 架构 + 实战)
数据库·分布式·nosql·hbase·分布式宽列数据库·wide column db