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、运行截图

相关推荐
tmacfrank21 分钟前
Android 性能优化入门(一)—— 数据结构优化
android·数据结构·性能优化
.似水26 分钟前
ADB基本操作和命令
adb
东风西巷32 分钟前
Screen Mirroring App:轻松实现手机与电视的无缝投屏
android·智能手机·生活·软件需求
每次的天空1 小时前
Android第三次面试总结之网络篇补充
android·网络·面试
uwvwko13 小时前
BUUCTF——web刷题第一页题解
android·前端·数据库·php·web·ctf
fzxwl13 小时前
隆重推荐(Android 和 iOS)UI 自动化工具—Maestro
android·ui·ios
LittleLoveBoy15 小时前
踩坑:uiautomatorviewer.bat 打不开
android
Snasph16 小时前
Ubnutu ADB 无法识别设备的解决方法
ubuntu·adb
居然是阿宋16 小时前
Android核心系统服务:AMS、WMS、PMS 与 system_server 进程解析
android
CGG9219 小时前
【单例模式】
android·java·单例模式