zoukankan      html  css  js  c++  java
  • 12-2 MySQL数据库备份(分表)

    #!/bin/bash
    source /etc/profile
    
    DATE="$(date +%F_%H-%M-%S)"
    DB_IP="172.16.1.122"
    HOST="localhost"
    PORT="3306"
    USER="root"
    PASS="Liuchang@2020"
    BACKUP_DIR="/data/db_backup"
    [ ! -d $BACKUP_DIR ] && mkdir -p $BACKUP_DIR
    
    MYSQL_DUMP="mysqldump -h${HOST} -P${PORT} -u${USER} -p${PASS}"
    MYSQL_COMMAND="mysql -h${HOST} -P${PORT} -u${USER} -p${PASS}"
    DB_LIST="`$MYSQL_COMMAND -s -e "show databases;" 2>/dev/null |egrep -v "information_schema|performance_schema|sys|mysql"`"
    
    for DB in $DB_LIST; do
        BACKUP_DB_DIR="${BACKUP_DIR}/${DB}_${DATE}"
        [ ! -d $BACKUP_DB_DIR ] && mkdir -p $BACKUP_DB_DIR
        TABLE_LIST="$($MYSQL_COMMAND -s -e "use $DB;show tables;" 2>/dev/null)"
        for TABLE in $TABLE_LIST; do
            BACKUP_NAME="${BACKUP_DB_DIR}/${TABLE}.sql"
            if ! $MYSQL_DUMP $DB $TABLE -R --single-transaction --events --hex-blob --triggers --flush-privileges > $BACKUP_NAME 2>/dev/null; then
                echo "MySQL $DB_IP DATABASE $DB TABLE $BACKUP_NAME BACKUP FAILD" |mail -s "MySQL $DB_IP DATABASE $DB TABLE $TABLE BACKUP FAILD" 2504164765@qq.com
            fi
        done
    done
    
    
    ##############补充说明##########################
    # 主从复制时全备主库的命令
    # mysqldump -uroot -p'Liuchang@2020' -A -F -R --single-transaction --master-data=1 --events --hex-blob --triggers --flush-privileges | gzip > /tmp/mysql_master_20200821.sql.bak.gz
    
    # 普通备份参数:
    # -R: 转储存储的例程(功能和过程);
    # -E: --events:转储事件;
    # -A: 转储所有数据库, 这将与--databases以及所有已选择的数据库相同;
    # -B: 转储多个数据库,增加建库语句和use连接库的语句;
    # --hex-blob: 转储十六进制格式的二进制字符串(BINARY,VARBINARY,BLOB);
    # --triggers: 为每个转储的表转储触发器;
    # --flush-privileges: 转储mysql数据库后,发出FLUSH PRIVILEGES语句;
    # --single-transaction: 设置事务的隔离级别为可重复读(REPEATABLE READ),用于热备,只适用于MySQL InnoDB引擎。
    
    # 用于MySQL开启binlog时的参数:
    # -F: 开始转储之前刷新服务器中的日志文件;
    # --master-data=1: 备份中增加binlog日志文件名及对应的位置点,1不加注释,2加注释;
    
    # -d:没有行信息,只备份表结构,不备份表数据; Usage: -d <数据库> <表名称,多个表名称可用空格隔开>
    # -t:不要写表创建信息,只备份表数据,不备份表结构;Usage: -t <数据库> <表名称,多个表名称可用空格隔开>
    ################################################
  • 相关阅读:
    文件的上传
    自定义EL表达式的函数
    JSTL 自定义标签
    Java c3p0连接池之二
    Java c3p0连接池
    JSP 登录与注册的小案例
    Java jdbc 连接oracle之三(封装工具类)
    Java jdbc 连接oracle之二(使用properties文件)
    Swift中Notification.Name自定义枚举
    swift UITableViewCell 策划删除,iOS11之后 设置侧滑不到最左边
  • 原文地址:https://www.cnblogs.com/LiuChang-blog/p/14697967.html
Copyright © 2011-2022 走看看