数据库定时备份脚本
一、知识储备工作:
- Mysql导出数据库语法:
mysqldump -u用户名 -p密码 数据库名 > 数据库名.sql
- shell脚本if条件判断基本语法
- gzip压缩文件用法
- rsync异地备份用法:
- ssh免密登录
二、场景
本次利用shell脚本实现以下需求:
- 每天凌晨3点执行备份,需备份所有库
- 备份的数据存放在本地/data/backup下
- 将所有备份文件压缩,格式为gzip
- 压缩后的名称格式示例:mysql_bak.tar.gz
- 利用rsync实现异地备份
- 本地备份数据保留30天
三、MySQL数据库备份脚本
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 | #!/bin/bash #date: 20220120 set -e #错误时,便停止执行脚本 #数据库名,可以添加多个 EXCLUDE= "Database|mysql|information_schema|performance_schema|sys" USER= "root" PASSWORD= "123456" BACKUP_DIR= /data/backup LOGFILE= /data/backup/data_backup .log DATE=` date +%Y%m%d_%H%M` cd $BACKUP_DIR #写入日记文件 echo "--------------------" >> $LOGFILE echo "BACKUP DATE:" $( date + "%y-%m-%d %H:%M:%S" ) >> $LOGFILE echo "-------------------" >> $LOGFILE mysql -uroot -p${PASSWORD} -e "show databases" | grep -Ev ${EXCLUDE}| xargs mysqldump -uroot -p${PASSWORD} --routines --single_transaction --master-data=2 --databases > xzmysql_bak${DATE}.sql if [ $? == 0 ]; then echo "$DATE--Database is backup succeed" >> $LOGFILE else echo "Database Backup Fail!" >> $LOGFILE fi cd $BACKUP_DIR tar -czf xzmysql_bak${DATE}. tar .gz xzmysql_bak${DATE}.sql rm -rf xzmysql_bak${DATE}.sql #全部成功就同步到异地备份服务器 if [ $? == 0 ]; then rsync -avz --progress --password- file = /etc/rsync .password --exclude={*.log,*.txt} ${BACKUP_DIR}/* rsync_backup@192.168.10.51::xzmysqlbackup /192 .168.10.128/ else echo "Database Backup Fail!" >> $LOGFILE fi #删除30天以上的备份文件 find $BACKUP_DIR - type f -mtime +30 -name "*.gz" - exec rm -f {} \; |
原文链接:https://www.toutiao.com/article/7055631704794759694/?channel=&source=search_tab
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义