已解决
编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份
来自网友在路上 162862提问 提问时间:2023-11-04 17:09:14阅读次数: 62
最佳答案 问答题库628位专家为你答疑解惑
查看数据和数据表
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 line2do#备份数据表mysqldump -uroot -p'123456' $line $line2 | gzip > /backup/db/$line/${line2}_$(date +%F).sql.gzdone < 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
查看数据库
查看全文
99%的人还看了
相似问题
猜你感兴趣
版权申明
本文"编写shell脚本,利用mysqldump实现MySQL数据库分库分表备份":http://eshow365.cn/6-31997-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!
- 上一篇: 基于SSM的个性化美食推荐系统设计与实现
- 下一篇: 新的线程:C++20 std::jthread