zoukankan      html  css  js  c++  java
  • linux脚本数据库备份脚本

    portal_mysql_backup.sh:

    #!/bin/bash
    #chmod 700 ${PATH}/portal_mysql_backup.sh
    #crontab -e (1 3 * * * ${PATH}/portal_mysql_backup.sh)

    red='e[0;31m' # 红色
    RED='e[1;31m'
    green='e[0;32m' # 绿色
    GREEN='e[1;32m'
    blue='e[0;34m' # 蓝色
    BLUE='e[1;34m'
    purple='e[0;35m' # 紫色
    PURPLE='e[1;35m'
    NC='e[0m' # 没有颜色

    source /etc/bash.bashrc
    source /etc/profile

    MySQL_USER=root
    MySQL_PASSWORD=123456
    MySQL_HOST=localhost
    MySQL_PORT=3306
    MySQL_DUMP_PATH=/mysql-backup
    MYSQL_BIN_PATH=/usr/bin/mysql
    MYSQL_DUMP_BIN_PATH=/usr/bin/mysqldump
    MySQL_DATABASE_NAME="itrm grafana reporter"
    DATE=$(date '+%Y-%m-%d')

    MySQLDUMP () {
    [ -d ${MySQL_DUMP_PATH} ] || mkdir ${MySQL_DUMP_PATH}
    cd ${MySQL_DUMP_PATH}
    [ -d logs ] || mkdir logs
    [ -d ${DATE} ] || mkdir ${DATE}
    cd ${DATE}

    for DATABASE in $MySQL_DATABASE_NAME
    do
    ${MYSQL_DUMP_BIN_PATH} -u${MySQL_USER} -p${MySQL_PASSWORD} -P${MySQL_PORT} -h${MySQL_HOST} ${DATABASE} >${DATABASE}.sql
    sleep 20

    [ "$?" == 0 ] && echo "${DATE}: Backup ${DATABASE} succeed" >> ${MySQL_DUMP_PATH}/logs/PortalMysqlDump.log
    [ "$?" != 0 ] && echo "${DATE}: Backup ${DATABASE} succeed" >> ${MySQL_DUMP_PATH}/logs/PortalMysqlDump.log
    done



    cd ${MySQL_DUMP_PATH}/
    [ "$?" == 0 ] && rm -rf $(date +%Y-%m-%d --date='3 days ago')
    exit 0
    }

    MySQLImport () {
    cd ${MySQL_DUMP_PATH}
    DATE=$(ls ${MySQL_DUMP_PATH} |egrep "^[0-9]+-[0-9]+-[0-9]+$")
    echo -e "${green}${DATE}"
    echo -e "${blue}what DATE do you want to import,please input date:${NC}"
    read SELECT_DATE
    if [ -d "${SELECT_DATE}" ];then
    echo -e "you select is ${green}${SELECT_DATE}${NC}, do you want to contine,if,input ${red}(yes|y|Y)${NC},if other exit"
    read Input
    [[ 'yes|y|Y' =~ "${Input}" ]]
    status="$?"
    if [ "${status}" == "0" ];then
    echo "now import SQL....... Please wait......."
    else
    exit 1
    fi
    cd ${SELECT_DATE}
    for PER_TABEL_SQL in $(ls *.sql)
    do
    ${MYSQL_BIN_PATH} -u${MySQL_USER} -p${MySQL_PASSWORD} -h${MySQL_HOST} ${MySQL_DATABASE_NAME} < ${PER_TABEL_SQL}
    echo -e "import ${PER_TABEL_SQL} ${PURPLE}........................${NC}"
    done
    echo "Finish import SQL,Please check un database"
    else
    echo "Don't exist ${SELECT_DATE} DIR"
    fi
    }

    case "$1" in
    MySQLDUMP|mysqldump)
    MySQLDUMP
    ;;
    MySQLImport|mysqlimport)
    MySQLImport
    ;;
    *)
    echo "Usage: $0 {(MySQLDUMP|mysqldump) (MySQLImport|mysqlimport)}"
    ;;
    esac

    ======================================(OK)================================

    zabbix_mysql_backup.sh:

    #!/bin/bash
    #chmod 700 ${PATH}/Zabbix_MySQLdump_per_table_v2.sh
    #crontab -e (0 3 * * * ${PATH}/Zabbix_MySQLdump_per_table_v2.sh)

    red='e[0;31m' # 红色
    RED='e[1;31m'
    green='e[0;32m' # 绿色
    GREEN='e[1;32m'
    blue='e[0;34m' # 蓝色
    BLUE='e[1;34m'
    purple='e[0;35m' # 紫色
    PURPLE='e[1;35m'
    NC='e[0m' # 没有颜色

    source /etc/bashrc
    source /etc/profile

    MySQL_USER=zabbix
    MySQL_PASSWORD=zabbix
    MySQL_HOST=localhost
    MySQL_PORT=3306
    MySQL_DUMP_PATH=/mysql-backup
    MYSQL_BIN_PATH=/usr/bin/mysql
    MYSQL_DUMP_BIN_PATH=/usr/bin/mysqldump
    MySQL_DATABASE_NAME=zabbix
    DATE=$(date '+%Y-%m-%d')

    MySQLDUMP () {
    [ -d ${MySQL_DUMP_PATH} ] || mkdir ${MySQL_DUMP_PATH}
    cd ${MySQL_DUMP_PATH}
    [ -d logs ] || mkdir logs
    [ -d ${DATE} ] || mkdir ${DATE}
    cd ${DATE}
    [ -d zabbix ] || mkdir zabbix
    cd zabbix
    #"show tables"|egrep -v "(Tables_in_zabbix|history*)")
    TABLE_NAME_ALL=$(${MYSQL_BIN_PATH} -u${MySQL_USER} -p${MySQL_PASSWORD} -h${MySQL_HOST} ${MySQL_DATABASE_NAME} -e
    "show tables"|egrep -v "(Tables_in_zabbix|history*|trends*|acknowledges|alerts|auditlog|events|service_alarms)")
    for TABLE_NAME in ${TABLE_NAME_ALL}
    do
    ${MYSQL_DUMP_BIN_PATH} --opt -u${MySQL_USER} -p${MySQL_PASSWORD} -P${MySQL_PORT} -h${MySQL_HOST}
    ${MySQL_DATABASE_NAME} ${TABLE_NAME} >${TABLE_NAME}.sql
    sleep 0.01
    done

    [ "$?" == 0 ] && echo "${DATE}: Backup zabbix succeed" >> ${MySQL_DUMP_PATH}/logs/ZabbixMysqlDump.log
    [ "$?" != 0 ] && echo "${DATE}: Backup zabbix not succeed" >> ${MySQL_DUMP_PATH}/logs/ZabbixMysqlDump.log

    cd ${MySQL_DUMP_PATH}/
    [ "$?" == 0 ] && rm -rf $(date +%Y-%m-%d --date='3 days ago')
    exit 0
    }

    MySQLImport () {
    cd ${MySQL_DUMP_PATH}
    DATE=$(ls ${MySQL_DUMP_PATH} |egrep "^[0-9]+-[0-9]+-[0-9]+$")
    echo -e "${green}${DATE}"
    echo -e "${blue}what DATE do you want to import,please input date:${NC}"
    read SELECT_DATE
    if [ -d "${SELECT_DATE}" ];then
    echo -e "you select is ${green}${SELECT_DATE}${NC}, do you want to contine,if,input ${red}(yes|y|Y)${NC},if other exit"
    read Input
    [[ 'yes|y|Y' =~ "${Input}" ]]
    status="$?"
    if [ "${status}" == "0" ];then
    echo "now import SQL....... Please wait......."
    else
    exit 1
    fi
    cd ${SELECT_DATE}
    for PER_TABEL_SQL in $(ls *.sql)
    do
    ${MYSQL_BIN_PATH} -u${MySQL_USER} -p${MySQL_PASSWORD} -h${MySQL_HOST} ${MySQL_DATABASE_NAME} < ${PER_TABEL_SQL}
    echo -e "import ${PER_TABEL_SQL} ${PURPLE}........................${NC}"
    done
    echo "Finish import SQL,Please check Zabbix database"
    else
    echo "Don't exist ${SELECT_DATE} DIR"
    fi
    }

    case "$1" in
    MySQLDUMP|mysqldump)
    MySQLDUMP
    ;;
    MySQLImport|mysqlimport)
    MySQLImport
    ;;
    *)
    echo "Usage: $0 {(MySQLDUMP|mysqldump) (MySQLImport|mysqlimport)}"
    ;;
    esac

    ==================================(OK)==============================

    itsm_mysql_backup.sh:

    #!/bin/bash
    #chmod 700 ${PATH}/itsm_mysql_backup.sh
    #crontab -e (1 2 * * * ${PATH}/itsm_mysql_backup.sh)

    red='e[0;31m' # 红色
    RED='e[1;31m'
    green='e[0;32m' # 绿色
    GREEN='e[1;32m'
    blue='e[0;34m' # 蓝色
    BLUE='e[1;34m'
    purple='e[0;35m' # 紫色
    PURPLE='e[1;35m'
    NC='e[0m' # 没有颜色

    source /etc/bash.bashrc
    source /etc/profile

    MySQL_USER=root
    MySQL_PASSWORD=123456
    MySQL_HOST=localhost
    MySQL_PORT=3306
    MySQL_DUMP_PATH=/mysql-backup
    MYSQL_BIN_PATH=/usr/bin/mysql
    MYSQL_DUMP_BIN_PATH=/usr/bin/mysqldump
    MySQL_DATABASE_NAME=itsm
    DATE=$(date '+%Y-%m-%d')

    MySQLDUMP () {
    [ -d ${MySQL_DUMP_PATH} ] || mkdir ${MySQL_DUMP_PATH}
    cd ${MySQL_DUMP_PATH}
    [ -d logs ] || mkdir logs
    [ -d ${DATE} ] || mkdir ${DATE}
    cd ${DATE}
    ${MYSQL_DUMP_BIN_PATH} -u${MySQL_USER} -p${MySQL_PASSWORD} -P${MySQL_PORT} -h${MySQL_HOST} ${MySQL_DATABASE_NAME} >${MySQL_DATABASE_NAME}.sql
    sleep 10

    [ "$?" == 0 ] && echo "${DATE}: Backup itsm succeed" >> ${MySQL_DUMP_PATH}/logs/ItsmMysqlDump.log
    [ "$?" != 0 ] && echo "${DATE}: Backup itsm not succeed" >> ${MySQL_DUMP_PATH}/logs/ItsmMysqlDump.log

    cd ${MySQL_DUMP_PATH}/
    [ "$?" == 0 ] && rm -rf $(date +%Y-%m-%d --date='3 days ago')
    exit 0
    }

    MySQLImport () {
    cd ${MySQL_DUMP_PATH}
    DATE=$(ls ${MySQL_DUMP_PATH} |egrep "^[0-9]+-[0-9]+-[0-9]+$")
    echo -e "${green}${DATE}"
    echo -e "${blue}what DATE do you want to import,please input date:${NC}"
    read SELECT_DATE
    if [ -d "${SELECT_DATE}" ];then
    echo -e "you select is ${green}${SELECT_DATE}${NC}, do you want to contine,if,input ${red}(yes|y|Y)${NC},if other exit"
    read Input
    [[ 'yes|y|Y' =~ "${Input}" ]]
    status="$?"
    if [ "${status}" == "0" ];then
    echo "now import SQL....... Please wait......."
    else
    exit 1
    fi
    cd ${SELECT_DATE}
    for PER_TABEL_SQL in $(ls *.sql)
    do
    ${MYSQL_BIN_PATH} -u${MySQL_USER} -p${MySQL_PASSWORD} -h${MySQL_HOST} ${MySQL_DATABASE_NAME} < ${PER_TABEL_SQL}
    echo -e "import ${PER_TABEL_SQL} ${PURPLE}........................${NC}"
    done
    echo "Finish import SQL,Please check itsm database"
    else
    echo "Don't exist ${SELECT_DATE} DIR"
    fi
    }

    case "$1" in
    MySQLDUMP|mysqldump)
    MySQLDUMP
    ;;
    MySQLImport|mysqlimport)
    MySQLImport
    ;;
    *)
    echo "Usage: $0 {(MySQLDUMP|mysqldump) (MySQLImport|mysqlimport)}"
    ;;
    esac

    =========================================(OK)=================================

    un_mysql_backup.sh:

    #!/bin/bash
    #chmod 700 ${PATH}/un_mysql_backup.sh
    #crontab -e (30 2 * * * ${PATH}/un_mysql_backup.sh)

    red='e[0;31m' # 红色
    RED='e[1;31m'
    green='e[0;32m' # 绿色
    GREEN='e[1;32m'
    blue='e[0;34m' # 蓝色
    BLUE='e[1;34m'
    purple='e[0;35m' # 紫色
    PURPLE='e[1;35m'
    NC='e[0m' # 没有颜色

    source /etc/bash.bashrc
    source /etc/profile

    MySQL_USER=uinnova
    MySQL_PASSWORD=Uinnova@123
    MySQL_HOST=localhost
    MySQL_PORT=3306
    MySQL_DUMP_PATH=/mysql-backup
    MYSQL_BIN_PATH=/usr/bin/mysql
    MYSQL_DUMP_BIN_PATH=/usr/bin/mysqldump
    MySQL_DATABASE_NAME=db_vmdb
    DATE=$(date '+%Y-%m-%d')

    MySQLDUMP () {
    [ -d ${MySQL_DUMP_PATH} ] || mkdir ${MySQL_DUMP_PATH}
    cd ${MySQL_DUMP_PATH}
    [ -d logs ] || mkdir logs
    [ -d ${DATE} ] || mkdir ${DATE}
    cd ${DATE}
    ${MYSQL_DUMP_BIN_PATH} -u${MySQL_USER} -p${MySQL_PASSWORD} -P${MySQL_PORT} -h${MySQL_HOST} ${MySQL_DATABASE_NAME} >${MySQL_DATABASE_NAME}.sql
    sleep 10

    [ "$?" == 0 ] && echo "${DATE}: Backup un succeed" >> ${MySQL_DUMP_PATH}/logs/UnMysqlDump.log
    [ "$?" != 0 ] && echo "${DATE}: Backup un not succeed" >> ${MySQL_DUMP_PATH}/logs/UnMysqlDump.log

    cd ${MySQL_DUMP_PATH}/
    [ "$?" == 0 ] && rm -rf $(date +%Y-%m-%d --date='3 days ago')
    exit 0
    }

    MySQLImport () {
    cd ${MySQL_DUMP_PATH}
    DATE=$(ls ${MySQL_DUMP_PATH} |egrep "^[0-9]+-[0-9]+-[0-9]+$")
    echo -e "${green}${DATE}"
    echo -e "${blue}what DATE do you want to import,please input date:${NC}"
    read SELECT_DATE
    if [ -d "${SELECT_DATE}" ];then
    echo -e "you select is ${green}${SELECT_DATE}${NC}, do you want to contine,if,input ${red}(yes|y|Y)${NC},if other exit"
    read Input
    [[ 'yes|y|Y' =~ "${Input}" ]]
    status="$?"
    if [ "${status}" == "0" ];then
    echo "now import SQL....... Please wait......."
    else
    exit 1
    fi
    cd ${SELECT_DATE}
    for PER_TABEL_SQL in $(ls *.sql)
    do
    ${MYSQL_BIN_PATH} -u${MySQL_USER} -p${MySQL_PASSWORD} -h${MySQL_HOST} ${MySQL_DATABASE_NAME} < ${PER_TABEL_SQL}
    echo -e "import ${PER_TABEL_SQL} ${PURPLE}........................${NC}"
    done
    echo "Finish import SQL,Please check un database"
    else
    echo "Don't exist ${SELECT_DATE} DIR"
    fi
    }

    case "$1" in
    MySQLDUMP|mysqldump)
    MySQLDUMP
    ;;
    MySQLImport|mysqlimport)
    MySQLImport
    ;;
    *)
    echo "Usage: $0 {(MySQLDUMP|mysqldump) (MySQLImport|mysqlimport)}"
    ;;
    esac

    ====================================(OK)===============================

  • 相关阅读:
    OCM_第十四天课程:Section6 —》数据库性能调优_各类索引 /调优工具使用/SQL 优化建议
    OCM_第十三天课程:Section6 —》数据库性能调优 _结果缓存 /多列数据信息采集统计/采集数据信息保持游标有效
    OCM_第十二天课程:Section6 —》数据库性能调优_ 资源管理器/执行计划
    使用NuGet时的一个乌龙
    .net调用存储过程碰到的一个问题
    数据库的备份与还原
    创建link server链接服务器碰到的问题及解决办法
    如何管理好项目的DLL
    项目中Enum枚举的使用
    .NET开发知识体系
  • 原文地址:https://www.cnblogs.com/A121/p/12217995.html
Copyright © 2011-2022 走看看