shell脚本获得所有数据库备份(整库备份,表级备份)

数据库备份到天翼云对象存储OBS

https://blog.csdn.net/qq_34631220/article/details/135755894

1、获得所有数据库

bash 复制代码
#!/bin/sh
HOSTNAME="ip"  #数据库信息
PORT="3306"
USERNAME="root"
PASSWORD=""
DBNAME="yusuan"  #数据库名称
# select_sql="select * from dade"
# 获得所有数据库
select_sql="show databases"
data=$(mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}")
for list in ${data}
do
    if [ "$list" != "Database" ] && [ "$list" != "information_schema" ] && [ "$list" != "mysql" ] && [ "$list" != "performance_schema" ] && [ "$list" != "sys" ];then
        if [ "$list" == "yusuan" ]; then
            echo "数据库66666----${list}"
        else
            echo "数据库----${list}"
        fi
    fi
done

2.单库表级备份

bash 复制代码
#!/bin/sh

# 获得时间date "+%Y-%m-%d %H:%M:%S"
mkdirYmd=$(date +%Y%m%d)
ymd=$(date +%Y%m%d-%H:%M:%S)
# 判断目录是否存在,不存在创建,压缩存放目录
[ -d /obsfs/obsfs_CentOS7.6_amd64/zip ] || mkdir -p /obsfs/obsfs_CentOS7.6_amd64/zip

HOSTNAME="ip"  #数据库信息
PORT="3306"
USERNAME="root"
PASSWORD=""
DBNAME="yusuan"  #数据库名称
# select_sql="select * from dade"
# 获得所有数据库
select_sql="show databases"
data=$(mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}")
for list in ${data}
do
    if [ "$list" != "Database" ] && [ "$list" != "information_schema" ] && [ "$list" != "mysql" ] && [ "$list" != "performance_schema" ] && [ "$list" != "sys" ];then
        if [ "$list" == "yusuan" ]; then
            echo "数据库66666----${list}"
            # 判断目录是否存在,不存在创建,日期+库名创建目录
            [ -d /obsfs/obsfs_CentOS7.6_amd64/cdj-file/mysql/${mkdirYmd}/${list} ] || mkdir -p /obsfs/obsfs_CentOS7.6_amd64/cdj-file/mysql/${mkdirYmd}/${list}
            # 整库备份
            # mysqldump -h${HOSTNAME} -u${USERNAME} -p${PASSWORD} --databases $list >/obsfs/obsfs_CentOS7.6_amd64/sql/${list}.sql
            # 按库单表备份
            tables_sql="show tables"
            Tab=$(mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${list} -e "${tables_sql}")
            for it in ${Tab}
            do  
                if [ "$it" != "Tables_in_yusuan" ];then
                    echo "表-----${it}"
                    # 单表备份
                    mysqldump -h${HOSTNAME} -u${USERNAME} -p${PASSWORD} --databases ${list} --tables ${it} > /obsfs/obsfs_CentOS7.6_amd64/sql/${it}_${ymd}.sql
                    # 单表压缩
                    zip -r /obsfs/obsfs_CentOS7.6_amd64/zip/${it}_${ymd}.zip /obsfs/obsfs_CentOS7.6_amd64/sql/${it}_${ymd}.sql
                    # 复制到天翼云对象存储目录OBS(并行文件系统),备份
                    cp /obsfs/obsfs_CentOS7.6_amd64/zip/${it}_${ymd}.zip /obsfs/obsfs_CentOS7.6_amd64/cdj-file/mysql/${mkdirYmd}/${list}
                    # 删除两个原文件
                    rm -rf /obsfs/obsfs_CentOS7.6_amd64/sql/${it}_${ymd}.sql;
                    rm -rf /obsfs/obsfs_CentOS7.6_amd64/zip/${it}_${ymd}.zip;
                fi
            done
        else
            echo "数据库----${list}"
        fi
    fi
done

3、备份所有库(表级)

bash 复制代码
#!/bin/sh

# 获得时间date "+%Y-%m-%d %H:%M:%S"
mkdirYmd=$(date +%Y%m%d)
ymd=$(date +%Y%m%d-%H:%M:%S)
# 判断目录是否存在,不存在创建,压缩存放目录
[ -d /obsfs/obsfs_CentOS7.6_amd64/zip ] || mkdir -p /obsfs/obsfs_CentOS7.6_amd64/zip

HOSTNAME="ip"  #数据库信息
PORT="3306"
USERNAME="root"
PASSWORD=""
DBNAME="yusuan"  #数据库名称
# select_sql="select * from dade"
# 获得所有数据库
select_sql="show databases"
data=$(mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}")
for list in ${data}
do
    if [ "$list" != "Database" ] && [ "$list" != "information_schema" ] && [ "$list" != "mysql" ] && [ "$list" != "performance_schema" ] && [ "$list" != "sys" ];then
        echo "数据库----${list}"
        # 判断目录是否存在,不存在创建,日期+库名创建目录
        [ -d /obsfs/obsfs_CentOS7.6_amd64/cdj-file/mysql/${mkdirYmd}/${list} ] || mkdir -p /obsfs/obsfs_CentOS7.6_amd64/cdj-file/mysql/${mkdirYmd}/${list}
        # 整库备份
        # mysqldump -h${HOSTNAME} -u${USERNAME} -p${PASSWORD} --databases $list >/obsfs/obsfs_CentOS7.6_amd64/sql/${list}.sql
        # 按库单表备份
        tables_sql="show tables"
        Tab=$(mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${list} -e "${tables_sql}")
        for it in ${Tab}
        do  
            if [ "$it" != "Tables_in_yusuan" ];then
                echo "库:${list}---表:${it}"
                # 单表备份
                mysqldump -h${HOSTNAME} -u${USERNAME} -p${PASSWORD} --databases ${list} --tables ${it} > /obsfs/obsfs_CentOS7.6_amd64/sql/${it}_${ymd}.sql
                # 单表压缩
                zip -r /obsfs/obsfs_CentOS7.6_amd64/zip/${it}_${ymd}.zip /obsfs/obsfs_CentOS7.6_amd64/sql/${it}_${ymd}.sql
                # 复制到天翼云对象存储目录OBS(并行文件系统),备份
                cp /obsfs/obsfs_CentOS7.6_amd64/zip/${it}_${ymd}.zip /obsfs/obsfs_CentOS7.6_amd64/cdj-file/mysql/${mkdirYmd}/${list}
                # 删除两个原文件
                rm -rf /obsfs/obsfs_CentOS7.6_amd64/sql/${it}_${ymd}.sql;
                rm -rf /obsfs/obsfs_CentOS7.6_amd64/zip/${it}_${ymd}.zip;
            fi
        done
    fi
done
相关推荐
IT策士2 分钟前
Redis 从入门到精通:分片之道 —— Redis Cluster
数据库·redis·缓存
AOwhisky37 分钟前
学习自测与解析:Redis系列第一期与第二期核心知识点详解
运维·数据库·redis·学习·云计算
kishu_iOS&AI1 小时前
LLM —— Milvmus向量数据库
数据库·人工智能·milvus
名不经传的养虾人1 小时前
从0到1:企业级AI项目迭代日记 Vol.46|三个检索源、缓存限流、深度整合——联网检索一日冲刺
数据库·人工智能·agent·ai编程·ai工作流·企业ai
BugShare1 小时前
Mac 上原生开发的开源免费、尽享丝滑数据库工具
数据库·macos·开源
Java爱好狂.1 小时前
阿里1658页2026最新Java面试题总结(含答案)
数据库·redis·程序员·java面试·java面试题·java编程·java八股文
jieyucx1 小时前
《Go 数据库编程开篇:彻底打通 database/sql 与 MySQL 驱动的连接池调优密码》
数据库·sql·golang
白露与泡影1 小时前
深入理解MySQL事务隔离级别:MVCC机制与Next-Key Lock如何解决幻读问题?
数据库·mysql
Gong-Yu1 小时前
MySQL数据库运维——性能优化进阶2️⃣
运维·数据库·mysql·性能优化
吴声子夜歌1 小时前
SQL经典实例——概述
数据库·sql