查看数据和数据表
mysql -uroot -p'123456' -e 'show databases'
mysql -uroot -p'123456' -e 'show tables from cb_d'
删除头部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
分表分库备份成功
还原检测
删除数据库并查看库
mysql -uroot -p'123456' -e 'drop database cb_d'
mysql -uroot -p'123456' -e 'show databases'
开始还原
使用备份的库进行还原,由于是压缩文件,使用压缩还原
gunzip < /backup/db/cb_d_2023-11-02.sql.gz | mysql -uroot -p'123456' -B
查看数据库