云原生高级--shell自动化脚本备份

=======================================================================

shell自动化脚本实战---备份

=======================================================================

数据库备份: 结合计划任务 MySQL、 Oracle

网站备份: tar,异地保存--ftp、rsync

一、数据库备份

1.利用自带工具mysqldump 实现数据库分库备份

分库备份:

1> 如何获取备份的数据库列表

复制代码
[root@localhost mysql-5.7.18]# DBS=`mysql -uroot -p'123456' -N -e 'show databases' | egrep -v "information_schema|mysql|performance_schema|sys"`
mysql: [Warning] Using a password on the command line interface can be insecure.
[root@localhost mysql-5.7.18]# echo $DBS

2> 循环遍历

复制代码
for db in $DBS
do
	echo 备份 $db
done

3> 备份语句实现

复制代码
[root@localhost ~]# mysqldump -uroot -p'123456' -B $db > $db.sql
优化:
[root@localhost ~]# mysqldump -uroot -p'123456' -B user > user_$(date +%F).sql
分库备份参考代码:
#!/bin/bash

#define var
BAK_DIR=/backup/db
CMD_OPT="-uroot -p123456"
EX_DB="information_schema|mysql|performance_schema|sys"

DBS=$(mysql ${CMD_OPT} -N -e 'show databases' | egrep -v ${EX_DB})


# main program
[ -d ${BAK_DIR} ] || mkdir -p ${BAK_DIR}

for db in $DBS
do
   mysqldump ${CMD_OPT} -B $db > ${BAK_DIR}/${db}_$(date +%F).sql
done

2、分表

复制代码
mysql -uroot -p'123456' -N -e 'show tables from user'

#!/bin/bash

#define var
BAK_DIR=/backup/db
CMD_OPT="-uroot -p123456"
db=user
TABS=$(mysql ${CMD_OPT} -N -e "show tables from $db")


# main program
[ -d ${BAK_DIR}/$db ] || mkdir -p ${BAK_DIR}/$db

for tab in $TABS
do
mysqldump ${CMD_OPT} $db $tab > ${BAK_DIR}/$db/${db}_$tab_$(date +%F).sql

3、分库分表

复制代码
#define var
BAK_DIR=/backup/db
CMD_OPT="-uroot -p123456"
EX_DB="information_schema|mysql|performance_schema|sys"

DBS=$(mysql ${CMD_OPT} -N -e 'show databases' | egrep -v ${EX_DB})

for db in $DBS
do
	TABS=$(mysql ${CMD_OPT} -N -e "show tables from $db")
	[ -d ${BAK_DIR}/$db ] || mkdir -p ${BAK_DIR}/$db
	mysqldump ${CMD_OPT} -B $db > ${BAK_DIR}/${db}_$(date +%F).sql

	for tab in $TABS
	do
	  mysqldump ${CMD_OPT} $db $tab > ${BAK_DIR}/$db/${db}_$tab_$(date +%F).sql
	done
done

4.优化

复制代码
优化:
#!/bin/bash

#define var
BAK_DIR=/backup/db
CMD_OPT="-uroot -p123456"
EX_DB="information_schema|mysql|performance_schema|sys"

DBS=$(mysql ${CMD_OPT} -N -e 'show databases' | egrep -v ${EX_DB})

# main program
for db in $DBS
do
  TABS=$(mysql ${CMD_OPT} -N -e "show tables from $db")
  [ -d ${BAK_DIR}/$db ] || mkdir -p ${BAK_DIR}/$db
  mysqldump ${CMD_OPT} -B $db | gzip > ${BAK_DIR}/$db/${db}_$(date +%F).sql.gz
# 分表备份
for tab in $TABS
  do
    mysqldump ${CMD_OPT} $db $tab | gzip > ${BAK_DIR}/$db/${db}_$tab_$(date +%F).sql.gz
  done
done
相关推荐
视觉震撼2 分钟前
逐步指南:为大模型构建自动化知识图谱
运维·自动化·知识图谱
yeflx38 分钟前
OpenMVS源码编译
运维
北京耐用通信42 分钟前
耐达讯自动化Profibus光纤链路模块:跨行业通信的“隐形桥梁”,让控制更丝滑!
人工智能·网络协议·自动化·信息与通信
有泽改之_1 小时前
ssh命令使用
linux·运维·ssh
玩大数据的龙威1 小时前
【乱占耕地建房】—试点工作平台自动化填报系统
运维·自动化
小白学大数据2 小时前
绕过拼多多 App 反抓包机制的综合逆向解决方案
开发语言·爬虫·python·自动化
JoyCong19982 小时前
高效远程协作指南:基于ToDesk的六大应用场景详解
运维·服务器·远程工作·远程操作
三不原则3 小时前
实战:混沌工程入门,模拟服务器宕机的故障演练
运维·kubernetes·chaos mesh
cws2004013 小时前
MFA双因素用户使用手册
运维·windows·网络安全·github·邮件·邮箱
weixin_462446234 小时前
使用 Python 脚本自动化管理 Docker 容器:启动、修改密码、删除及系统资源监控
python·docker·自动化·系统监控