当前位置: 首页 > news >正文

MySQL数据库分库分表备份(shell脚本)

创建目录

mkdir /server/scripts

一、使用脚本实现分库备份

1、创建脚本并编写
[root@localhost scripts]# vim bak_db_v1.sh +#!/bin/bash
#########################################
# File Name:bak_db_v1.sh
# Version: V1.0
# Author:Shen QL
# Email:17702390000@163.com
# Organization:
# Create Time:2023-07-27 19:21:21
# Description:分库备份
##########################################优化
#备份的路径
bak_path=/backup/db
#账号,密码
mysql_cmd='-uroot -pRedHat@123'
#需要排除的数据库
exclude_db='information_schema|mysql|performance_schema|sys'#检验备份路径是否存在,不存在则创建
[ -d ${bak_path} ] || mkdir -p ${bak_path}#提取需要备份的数据库,并将其写入文件(dbname)中
mysql ${mysql_cmd} -e 'show databases' -N | egrep -v "${exclude_db}" > dbname#循环文件,针对每个库进行备份
while read line
domysqldump ${mysql_cmd} -B $line | gzip > ${bak_path}/${line}_$(date +%F).sql.gz
done < dbname#删除临时文件
rm -f dbname

 结果 

二、使用脚本实现分表备份

#!/bin/bash
#########################################
# File Name:bak_tb_v1.sh
# Version: V1.0
# Author:Shen QL
# Email:17702390000@163.com
# Organization:
# Create Time:2023-07-27 19:21:21
# Description:分表备份
##########################################优化
#备份的路径
bak_path=/backup/db
#账号,密码
mysql_cmd='-uroot -pRedHat@123'
#需要排除的数据库
exclude_db='information_schema|mysql|performance_schema|sys'#提取需要备份的数据表,并将其写入文件(tbname)中
mysql -uroot -pRedHat@123 -N -e'show tables from abc' > tbname
#循环文件,针对每个表进行备份
while read line
do#将数据表放在对应的数据库下面[ -d ${bak_path}/abc ] || mkdir -p ${bak_path}/abcmysqldump ${mysql_cmd} abc $line | gzip > ${bak_path}/abc/abc_${line}_$(date +%F).sql.gz
done < tbname#删除临时文件
rm -f tbname

  结果 

三、使用脚本实现分库分表备份

#!/bin/bash
#########################################
# File Name:bak_tb_v1.sh
# Version: V1.0
# Author:Shen QL
# Email:17702390000@163.com
# Organization:
# Create Time:2023-07-27 19:21:21
# Description:分库分表备份
##########################################优化
#备份的路径
bak_path=/backup/db
#账号,密码
mysql_cmd='-uroot -pRedHat@123'
#需要排除的数据库
exclude_db='information_schema|mysql|performance_schema|sys'#提取需要备份的数据库,并将其写入文件(dbname)中
mysql ${mysql_cmd} -e 'show databases' -N | egrep -v "${exclude_db}" > dbname
while read line
do#循环文件,针对每个库进行备份 [ -d ${bak_path}/$line ] || mkdir -p ${bak_path}/$linemysqldump ${mysql_cmd} -B $line | gzip > ${bak_path}/${line}/${line}_$(date +%F).sql.gz#提取需要备份的数据表,并将其写入文件(tbname)中mysql ${mysql_cmd} -N -e "show tables from $line" > tbname#循环文件,针对每个表进行备份while read tbdo#将数据表放在对应的数据库下面mysqldump ${mysql_cmd} $line $tb | gzip > ${bak_path}/$line/${line}_${tb}_$(date +%F).sql.gzdone < tbname
done < dbname#删除临时文件
rm -f dbname tbname

  结果

 

http://www.lryc.cn/news/99139.html

相关文章:

  • 建造者设计模式go实现尝试
  • 创建交互式用户体验:探索JavaScript中的Prompt功能
  • 自然语言处理从入门到应用——LangChain:提示(Prompts)-[提示模板:基础知识]
  • OpenPCDet调试出现的问题
  • 【业务功能篇58】Springboot + Spring Security 权限管理 【下篇】
  • VBA技术资料MF34:检查Excel自动筛选是否打开
  • spring扩展点
  • Skin Shader 使用自动生成的Thickness
  • Docker中的网络
  • SRS开源代码框架,协程库state-threads的使用
  • 【QT 网络云盘客户端】——登录界面功能的实现
  • 【复盘与分享】第十一届泰迪杯B题:产品订单的数据分析与需求预测
  • X - Transformer
  • ubuntu下畅玩Seer(via wine)
  • 第五章:Spring下
  • 在CSDN学Golang云原生(Kubernetes基础)
  • 给APK签名—两种方式(flutter android 安装包)
  • 观察者模式、中介者模式和发布订阅模式
  • PHP-Mysql图书管理系统--【白嫖项目】
  • 网络传输层协议:UDP和TCP
  • ElementUI Select选择器如何根据value值显示对应的label
  • Kotlin 内联函数语法之let、apply、also、run、with的用法与详解
  • Swift 中如何判断是push 过来的页面 还是present过来的 页面
  • 基于K8s环境·使用ArgoCD部署Jenkins和静态Agent节点
  • 874. 模拟行走机器人
  • 【Linux】- RPM 与 YUM
  • Visual Studio 2015编译器 自动生成 XXX_EXPORTS宏
  • HTML5的应用现状与发展前景
  • day44-Spring_AOP
  • selenium IDE 接入jenkins-转载