(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 #Define DIR and mkdir DIR 判斷目錄是否存在,不存在則建立 if [ ! -d $BAKDIR ];then mkdir -p $BAKDIR #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 |