云原生高级--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
相关推荐
2601_949221032 小时前
Splashtop赋能企业级远程办公全场景安全连接成选型优选
运维·人工智能·安全
七度黑光2 小时前
用 openclaw 给故障复盘打分:质量审核自动化实践
运维·服务器·前端·数据库·自动化
last demo3 小时前
mysql
运维·数据库·mysql·oracle
灰阳阳4 小时前
Dockerfile实践-构建Nginx镜像
运维·nginx·docker·dockerfile
Johnstons4 小时前
网络流量监控工具怎么选
运维·网络·网络故障排除·网络流量分析·网络性能监控
信创DevOps先锋7 小时前
中国DevOps工具链选型新趋势:合规、协同与生态融合的平衡之道
运维·gitee·devops
白鸽梦游指南8 小时前
docker镜像优化
linux·运维·docker
陳10308 小时前
Linux:基础开发工具
linux·运维·服务器
IT界的老黄牛8 小时前
Prometheus + Grafana + AlertManager 监控体系搭建:Docker 一把梭
运维·grafana·prometheus
阿干tkl9 小时前
K3s + Harbor 端口冲突问题解决方案(Harbor 使用 80 端口)
运维