• 数据库定时备份脚本


    一、知识储备工作:

    1. Mysql导出数据库语法:
    mysqldump -u用户名 -p密码 数据库名 > 数据库名.sql
    1. shell脚本if条件判断基本语法
    2. gzip压缩文件用法
    3. rsync异地备份用法:
    4. ssh免密登录

    二、场景

    本次利用shell脚本实现以下需求:

    1. 每天凌晨3点执行备份,需备份所有库
    2. 备份的数据存放在本地/data/backup下
    3. 将所有备份文件压缩,格式为gzip
    4. 压缩后的名称格式示例:mysql_bak.tar.gz
    5. 利用rsync实现异地备份
    6. 本地备份数据保留30天

    三、MySQL数据库备份脚本

    #!/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

  • 相关阅读:
    jQuery的DOM操作
    jQuery的样式篇
    DOM对象控制HTML
    线程属性
    Glib动态加载模块(插件)
    linux 进程与线程命令
    error: server certificate verification failed.
    Qt qmake高级应用(翻译)
    Linux下设置QT环境变量
    pro、pri、prf、prl文件(qmake)
  • 原文地址:https://www.cnblogs.com/shuai666/p/16278439.html
Copyright © 2020-2023  润新知