MySQL 实现分库和分表的备份 2023.7.29

1、分库备份

bash 复制代码
[root@localhost mysql-backup]# cat db_bak.sh 
#!/bin/bash
k_user=root
bak_password=123456
bak_path=/root/mysql-backup/
bak_cmd="-u$bak_user -p$bak_password"
exc_db="Database|information_schema|mysql|performance_schema|sys"
dbname=`mysql $bak_cmd -e "show databases"| egrep -v $exc_db`
for db in `echo $dbname`
do
   [ -d $bak_path ] || mkdir -p $bak_path
   mysqldump $bak_cmd -B $db | gzip > $bak_path/${db}_`date +$Y%m%d`.sql.gz
done

2、分表备份

bash 复制代码
[root@localhost mysql-backup]# cat tb_bak.sh 
#!/bin/bash
k_user=root
bak_password=123456
bak_path=/root/mysql-backup/
bak_cmd="-u$bak_user -p$bak_password"
exc_db="Database|information_schema|mysql|performance_schema|sys"
db_name=`mysql $bak_cmd -e "show databases"| egrep -v $exc_db`
#echo $db_name
for db in `echo $db_name`
do        
  [ -d ${bak_path} ] || mkdir -p ${bak_path}
  dt_name=`mysql $bak_cmd -e "use $db;show tables" | egrep -v "Tables_in_$db"`
  #echo $db
  #echo $dt_name
  for dt in `echo $dt_name`
  do
  #echo $db $dt
  mysqldump $bak_cmd $db ${dt} | gzip > $bak_path/${db}_${dt}.`date +%F%m%d`.sql.gz
  done 
done

3、运行截图

相关推荐
百锦再20 分钟前
第21章 构建命令行工具
android·java·图像处理·python·计算机视觉·rust·django
skyhh2 小时前
Android Studio 最新版汉化
android·ide·android studio
路人甲ing..2 小时前
Android Studio 快速的制作一个可以在 手机上跑的app
android·java·linux·智能手机·android studio
携欢5 小时前
PortSwigger靶场之Web shell upload via path traversal靶场通关秘籍
android
kitty_hi10 小时前
mysql主从配置升级,从mysql5.7升级到mysql8.4
linux·数据库·mysql·adb
q***133412 小时前
Linux系统离线部署MySQL详细教程(带每步骤图文教程)
linux·mysql·adb
消失的旧时光-194313 小时前
Android ADB指令大全详解
android·adb
ashcn200115 小时前
opengl 播放视频的android c++ 方案
android·c++ opengl es
abner.Li15 小时前
android 反编译
android
Digitally15 小时前
如何删除 realme 手机上的短信
android