一、知识储备工作:
- Mysql导出数据库语法:
mysqldump -u用户名 -p密码 数据库名 > 数据库名.sql
- shell脚本for循环及if条件判断基本语法
- gzip压缩文件用法
- rsync异地备份用法:
- ssh免密登录
二、场景
本次利用shell脚本实现以下需求:
- 每天凌晨3点执行备份,需备份所有库(db1 db2 db3)
- 备份的数据存放在本地/data/mysql下
- 将所有备份文件压缩,格式为gzip
- 压缩后的名称格式示例:qin-2020-02-24-21:19.sql.gz
- 利用rsync实现异地备份
- 本地备份数据保留2个月
三、MySQL数据库备份脚本
- 编写脚本:mysql-backup.sh
1 #! /bin/bash
2 #Save sa /etc/mysql-backup.sh
3 BAKDIR="/data/mysql"
4 MYSQLUSR