目录
一,分库备份
python
#!/bin/bash
mysql_cmd='-uroot -pzly666666'
bak_path=/backup/db
[ -d ${bak_path} ] || mkdir -p ${bak_path}
mysql ${mysql_cmd} -e 'show databases' -N | egrep -v 'sys|mysql|information_schema|performance_schema' > dbname
while read line
do
mysqldump ${mysql_cmd} -B $line | gzip > ${bak_path}/${line}_$(date +%F).sql.gz
done < dbname
rm -rf dbname
data:image/s3,"s3://crabby-images/4af0c/4af0c77f6eee87a3ffc2865f5523bfe884fd6b3d" alt=""
二,分库操作
python
#!/bin/bash
mysql_cmd='-uroot -pzly666666'
bak_path=/backup/db
mysql -uroot -pzly666666 -e 'show tables from homework;' -N > tbname
#mysql ${mysql_cmd} -e 'show databases' | egrep -v 'sys|mysql|information_schema|performance_schema' > dbname
while read line
do
[ -d ${bak_path}/homework ] || mkdir -p ${bak_path}/homework
mysqldump ${mysql_cmd} homework $line | gzip > ${bak_path}/homework/homework_${line}_$(date +%F).sql.gz
done < tbname
rm -rf tbname
data:image/s3,"s3://crabby-images/581b1/581b18afca0fd3690fd8eb78e859e6d81baeaa3b" alt=""
三,分库分表备份
python
#!/bin/bash
mysql_cmd='-uroot -pzly666666'
bak_path=/backup/db
exclude_db='sys|mysql|information_schema|performance_schema'
mysql ${mysql_cmd} -e 'show databases' -N | egrep -v ${exclude_db} > dbname
while read db
do
[ -d ${bak_path}/$db ] || mkdir -p ${bak_path}/$db
mysqldump ${mysql_cmd} -B $db | gzip > ${bak_path}/${db}/${db}_$(date +%F).sql.gz
mysql ${mysql_cmd} -e "show tables from ${db};" -N > tbname
while read tb
do
mysqldump ${mysql_cmd} $db $tb | gzip > ${bak_path}/${db}/${db}_${tb}_$(date +%F).sql.gz
done < tbname
done < dbname
rm -rf tbname
rm -rf dbname
data:image/s3,"s3://crabby-images/a6f2a/a6f2a363a9625c5dcd0e7e7725b188a56f60c1c0" alt=""
四,备份还原
data:image/s3,"s3://crabby-images/d876c/d876cdd520e75ca013f479426645cf4f06eb0333" alt=""
data:image/s3,"s3://crabby-images/e4c80/e4c80a1aedde49cc4101890da5f9f71bbd5bbd0b" alt=""
zcat /backup/db/homework/homework_emp_2023-07-30.sql.gz | mysql -uroot -pzly666666 homework