shell 自动导出导入数据库,将导出的格式为 : 数据库名+时间.sql

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: mysqldump 自动导出mysql8 or mariadb10x 数据库工具,导入数据库工具,mysql 创建于删除数据库

#!/bin/bash
# databases out save
# developer : eisc.cn
# 开发: 小绿叶技术博客; 功能:shell 自动导出数据库,将导出的格式为 : 数据库名+时间.sql 
echo "linux user: $USER ;  Enter the current user sudo password: " ; sudo date ; formatdate=`date +%Y.%m.%d-%H%M%S` ; echo "time year month day Hour branch second: $formatdate "
dir=/datadisk/eisc/back/sql
sudo mkdir -p $dir ; sudo chmod 777 $dir
# 数据库导出文件保存目录, 创建这个目录,和附加权限

DestDir=/datadisk/eisc/back/sql
DestDBName=(`ls $DestDir | grep "sql" | grep -vE "tar|gz|zip|sh"`)
# 目标服务器,需要导入的数据库文件。根据实际存放目录修改

# user=root
# passwd=eisc.cn
# dataip=127.0.0.1
# 脚本中配置 数据库用户名 和密码 和数据库链接地址

if [ "$user"="" ]
then 
    echo "请输入数据库管理员用户和密码以及ip, 案例:root eisc.cn 127.0.0.1
Please enter the database administrator user and password and ip, case: root eisc.cn 127.0.0.1
" 
    read -p "input: " inputuser
else
    echo "[ok] 已经定义过 user 和 passwd 的值!"
fi

inputuser=($inputuser)
user=${inputuser[0]}
passwd=${inputuser[1]}
dataip=${inputuser[2]}

export_databases(){
    databases=(`mysql -u $user  -p$passwd -e "show databases;"`)
    NoOutDatabases=(Database information_schema mysql performance_schema sys )
    # 这是系统库,不是项目中的数据库。只需要导出项目库

    echo "databases is : ${databases[*]}
    NoOutDatabases is : ${NoOutDatabases[*]}
     "

    sudo tar -czvf $dir/sqlback_$formatdate.tar.gz $dir ; sudo rm -rf $dir/*

    for i in ${databases[*]}
    do
        echo "#-------- database $i -----------# "
      
        for o in ${NoOutDatabases[*]}
        do
            case "$i" in 
                "$o") echo " [ok]  $i : The current database does not need to be exported!" ; OutStatus=0 ; echo "" ;echo "" ;;
            esac

        done
    
        if [ "$OutStatus" = "1" ]
        then 
            sql="sudo mysqldump --column-statistics=0 -h $dataip -u $user -p$passwd  --databases $i"
            echo "[runing] shell cmd:  $sql" ; echo ""
            $sql > $dir/$i-$formatdate.sql
            # mysqldump 不支持有变量的数据库,因此赋值为字符串
            # 因为新版的mysqldump默认启用了一个新标志,通过- -column-statistics=0来禁用他
        else 
            echo "[ok] $i Database does not need to be saved" 
        fi 
    
        OutStatus=1
        # 状态 为 1 才进行导出数据,由于受到 NoOutDatabases 不导出影响,会被定义为 0. 最后再次将状态更新为正常 1 
        # 注意: shell if 判断的时候需要在变量和值加双引号,否则异常
    done

    echo "数据库导出保存目录: $dir 将目录 $dir 备份为:sqlback_$formatdate.tar.gz"
    ls -alh $dir
}


mysql_database_tools(){
#!/bin/bash
# shell 自动创建数据库 用户和密码
sudo apt install libncurses*
# 解决mysql 命令报错,缺少库:Couldn't find any package by glob 'libncurses.so.5'

sudo apt install mysql-client  -y
# 安装连接数据库工具
sudo mkdir /var/run/mysqld/
sudo ln -s /tmp/mysql.sock /var/run/mysqld/mysqld.sock
# 解决 mysql 报错,无法进入mysql 。 mariadb 的启动sock 不一样

    runmysql=`sudo netstat -nltp | grep 3306 | grep -w tcp | grep mariadb`
    if [ ${#runmysql} -lt 1 ]
    then
      sudo /etc/init.d/mariadb1011 start
    fi

sudo $installdir/mysql/mariadb1011/bin/mysqladmin  -u root password eisc.cn
# 启动数据库,重置数据库 root 用户密码为: eisc.cn

  echo "#---------------- 数据库管理工具 ------------#

参考输入案例: create eisc.cn www www 000000 localhost

  1 创建 or 删除,输入: create 或 drop
  2 数据库 root 用户密码
  3 子数据库名
  4 子库用户名
  5 子库密码
  6 开放数据库方式:本地/远程 输入: localhost 或 %
  用空格隔开,必须按照顺序输入6个参数!"
  read -p "请输入:" in_buff
  buff=( abcd $in_buff);

  echo "你输入的信息为: ${buff[*]}";

  case ${buff[1]} in
  "create")
#    mysql -uroot -p${buff[2]} -e "create database ${buff[3]} character set utf8 collate utf8_bin;"
    mysql -uroot -p${buff[2]} -e "create database ${buff[3]} character set utf8;"
    mysql -uroot -p${buff[2]} -e "grant all on ${buff[4]}.* to '${buff[4]}'@'${buff[6]}' identified by '${buff[5]}'"
    mysql -uroot -p${buff[2]} -e "show databases;SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS ListUsername FROM mysql.user where User='${buff[4]}';"
  ;;
  "drop")
    mysql -uroot -p${buff[2]} -e "drop database ${buff[3]}"
    mysql -uroot -p${buff[2]} -e "drop user '${buff[4]}'@'${buff[6]}'"
    mysql -uroot -p${buff[2]} -e "show databases;SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS ListUsername FROM mysql.user where User='${buff[4]}';"
  ;;
  esac
}

import_databases(){
    dipasswd=eisc.cn
    # 定义 子库密码
    echo  "将从文件目录: $DestDir 导入数据库, 注意,不能出现重复的数据库文件。一个数据库保留一个sql 文件。列出该目录的文件,如下:" ; ls $DestDir
    read -p "是否将文件放置在该目录?y/n:" fzfile 
    if [ "$fzfile" != "y" ]
    then 
        echo "[ok] 退出! 将文件复制到该目录后,重新执行函数"
        exit
    fi
    echo "如果遇到问题,你可以使用 mysql管理工具来创建数据库和用户, 不使用该工具,会自动创建数据库。"

    for((s=0;s<${#DestDBName[*]};s++))
    do
        di=`echo ${DestDBName[$s]} | awk -F"-" '{print $1}'`
        difile=${DestDBName[$s]} 

        ShowDBName=`mysql -h $dataip -u $user -p$passwd -e "show databases" | grep $di `
        if [ "$ShowDBName"  = "$di"]
        then 
            echo "[error] Database exists $di "
        else
            echo "[ok] runing import data $di"
            mysql -h $dataip -u $user -p$passwd -e "create database $di character set utf8;"
            mysql -h $dataip -u $user -p$passwd -e "grant all on $di.* to '$di'@'localhost' identified by '$dipasswd'"
            mysql -h $dataip -u $user -p$passwd -e "show databases;SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS ListUsername FROM mysql.user where User='$di';"
        fi

        mysql -h $dataip -u $user -p$passwd -e "use $di ; source $DestDir/$difile ; show tables;"
        echo "[ok] import databases $DestDir/$difile "
    done
}

main(){

echo "
欢迎使用,小绿叶技术博客 eisc.cn 数据库搬家,数据库导出与导入工具,提供工具功能:
1. 数据库导出
2. 数据库导入
3. 数据库管理工具,创建与删除数据库和用户
请输入功能序号:


Welcome to the small green leaf technology blog eisc.cn database move, database export and import tool, providing tool functions:
1. Database export
2. Database import
3. Database management tool, creating and deleting databases and users
Please enter the function serial number:
" 
    read -p "input number: " tnumber
    case "$tnumber" in 
        "1") echo "[runing]  1. Database export" ;          export_databases ;; 
        "2") echo "[runing]  2. Database import" ;          import_databases ;;
        "3") echo "[runing]  3. Database management tool" ; mysql_database_tools ;;
    esac

}

main

# 一键下载使用:    wget eisc.cn/file/ubuntu/shell/server/mysql_export_import.sh ; chmod +x mysql_export_import.sh ; ./mysql_export_import.sh

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2天前
|
SQL Oracle 关系型数据库
sql语句创建数据库
在创建数据库之前,请确保你有足够的权限,并且已经考虑了数据库的安全性和性能需求。此外,不同的DBMS可能有特定的最佳实践和配置要求,因此建议查阅相关DBMS的官方文档以获取更详细和准确的信息。
|
13天前
|
SQL 人工智能 算法
【SQL server】玩转SQL server数据库:第二章 关系数据库
【SQL server】玩转SQL server数据库:第二章 关系数据库
52 10
|
30天前
|
SQL 存储 BI
【软件设计师备考 专题 】数据库语言(SQL)
【软件设计师备考 专题 】数据库语言(SQL)
90 0
|
1月前
|
算法 Shell Linux
【Shell 命令集合 备份压缩 】Linux 处理lha格式 lha命令 使用指南
【Shell 命令集合 备份压缩 】Linux 处理lha格式 lha命令 使用指南
40 0
|
1月前
|
SQL 安全 数据库
SQL-Server 数据库部署
SQL-Server 数据库部署
63 0
|
1月前
|
安全 Shell Linux
【Shell 命令集合 备份压缩 】Linux将可执行文件压缩成gzip格式 gzexe命令 使用指南
【Shell 命令集合 备份压缩 】Linux将可执行文件压缩成gzip格式 gzexe命令 使用指南
38 0
|
1月前
|
SQL 数据库
sql server中创建数据库和表的语法
sql server中创建数据库和表的语法
18 1
|
13天前
|
SQL 算法 数据库
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
79 6
|
2天前
|
SQL 缓存 数据库
sql 数据库优化
SQL数据库优化是一个复杂且关键的过程,涉及多个层面的技术和策略。以下是一些主要的优化建议: 查询语句优化: 避免全表扫描:在查询时,尽量使用索引来减少全表扫描,提高查询速度。 使用合适的子查询方式:子查询可能降低查询效率,但可以通过优化子查询的结构或使用连接(JOIN)替代子查询来提高性能。 简化查询语句:避免不必要的复杂查询,尽量使SQL语句简单明了。 使用EXISTS替代IN:在查询数据是否存在时,使用EXISTS通常比IN更快。 索引优化: 建立合适的索引:对于经常查询的列,如主键和外键,应创建相应的索引。同时,考虑使用覆盖索引来进一步提高性能。 避免过多的索引:虽然索引可以提高查询
|
2天前
|
SQL XML 数据库
sql导入数据库命令
在SQL Server中,数据库导入可通过多种方式实现:1) 使用SSMS的“导入数据”向导从各种源(如Excel、CSV)导入;2) BULK INSERT语句适用于导入文本文件;3) bcp命令行工具进行批量数据交换;4) OPENROWSET函数直接从外部数据源(如Excel)插入数据。在操作前,请记得备份数据库,并可能需对数据进行预处理以符合SQL Server要求。注意不同方法可能依版本和配置而异。

热门文章

最新文章