您的位置:首页 > 运维架构 > Shell

Shell 脚本备份MySQL数据库

2017-12-06 13:44 423 查看
(1)思路

<1>安装MySQL数据库

<2>创建数据库,表,插入数据

<3>授权一个用于备份数据库的用户名和密码

<4>备份数据库的命令: mysqldump -u root -p 1234 -d MySQLDB > 1.sql

<5>引入if语句实现备份全部数据库

<6>引入for循环语句,实现备份多个数据库

(2)实战案例
编写MySQL数据库备份脚本,可以实现备份任意数据库,输入A,就备份A库,输入B,就备份B库,输入C,就备份C库,输入ALL,就备份全部数据库

(3)安装步骤
<1>安装MySQL数据库
yum install mysql-server mysql-devel mysql-libs -y

<2>重启MySQL数据库
service mysqld restart

<3>进入数据库命令行模式
创建3个数据库,分别在3个数据库中创建3张表,在表中插入一条数据
create database jfedu;
use jfedu;
create table t1(id varchar(20),name varchar(20));
insert into t1 values("1","daqi");
desc t1;
select * from t1;
注释:
不要忘记验证数据库,表 ,数据是否都已经创建成功

<4>授权一个用于备份数据库的用户名和密码
grant all on *.* to backup@localhost identified by "123456";

<5>

#!/bin/bash
#2017年12月6日10:28:54
#by author daqi
#mysqldump MySQLDB
BAKDIR=/data/backup/mysql/`date +%Y-%m-%d`
MYSQLDB=$*
MYSQLPW=123456
MYSQLUSR=backup
#must use root user run scripts 必须使用root用户运行,$UID为系统变量
if [ $UID -ne 0 ];then
echo This script must use the root user ! ! !
sleep 2
exit
fi
#判断用户输入参数的个数
if [ -z "$1" ];then
echo -e "\033[36mPlease Select mysqldump MySQLDB:jfedu|taobao|jd|all\033[0m"
exit 0
fi

#Define DIR and mkdir DIR 判断目录是否存在,不存在则新建

if
[ ! -d $BAKDIR ];then
mkdir -p $BAKDIR
fi

#Use mysqldump backup Databases
if [ $1 == "all" ];then
/usr/bin/mysqldump -u$MYSQLUSR -p$MYSQLPW --all-databases >$BAKDIR/ALL_DB.sql
echo "The $BAKDIR/ALL_DB.sql Mysql Database backup successfully "
else
for i in `echo $MYSQLDB`
do
/usr/bin/mysqldump -u$MYSQLUSR -p$MYSQLPW -d $i >$BAKDIR/${i}_db.sql
echo "The mysql databases $BAKDIR/${i}_db.sql successfully "
done
fi
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  shell mysql mysqldump