企業備份恢復案例

在MySQl中咱們備份數據通常有幾種方式mysql


熱備份                         溫備份                           冷備份sql

熱備份指的是當數據庫進行備份時, 數據庫的讀寫操做均不是受影響 
數據庫

溫備份指的是當數據庫進行備份時, 數據庫的讀操做能夠執行, 可是不能執行寫操做 app

冷備份指的是當數據庫進行備份時, 數據庫不能進行讀寫操做, 即數據庫要下線tcp


這裏咱們說個MYSQL數據庫的備份與恢復的企業案例ide

條件:ui

1.具有全量備份(mysqldump)。spa

2.除全量備份之外,還有全量備份以後產生的的全部binlog增量日誌。日誌

首先建立環境orm

#建立個名爲oldboy的數據庫

CREATE DATABASE oldboy;   

 #切到oldboy庫中

use `oldboy`;  

#鍵表

CREATE TABLE `oldboy` (

`id` int(4) NOT NULL AUTO_INCREMENT,

`name` char(20) NOT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;


INSERT INTO `oldboy` VALUES (1,'oldboy'),(2,'oldgirl'),(3,'inca'),(4,'zuma'),(5,'kaka');

#查看下oldboy庫中的表

mysql> select * from oldboy;

+----+---------+

| id | name    |

+----+---------+

|  1 | oldboy  |

|  2 | oldgirl |

|  3 | inca    |

|  4 | zuma    |

|  5 | kaka    |

+----+---------+

5 rows in set (0.01 sec)

mysql> quit

#將時間改成晚上12點,準備個存放備份文件的目錄

mkdir /data/backup -p

date -s "2017/06/22"

#備份庫

mysqldump -uroot -poldboy123  -B --master-data=2 --single-transaction oldboy|gzip>/data/backup/oldboy_$(date +%F).sql.gz

#此時咱們的binlog日誌已經分割了

#增長兩個表

mysql -uroot -poldboy123 -e "use oldboy;insert into oldboy values(6,'bingbing');"

mysql -uroot -poldboy123 -e "use oldboy;insert into oldboy values(7,'xiaoting');"

#查看下

mysql -uroot -poldboy123 -e "select * from oldboy.oldboy;"

+----+----------+

| id | name     |

+----+----------+

|  1 | oldboy   |

|  2 | oldgirl  |

|  3 | inca     |

|  4 | zuma     |

|  5 | kaka     |

|  6 | bingbing |

|  7 | xiaoting |

+----+----------+

 

#模擬誤刪數據庫

date -s "2017/06/22 11:40"

mysql -uroot -poldboy123 -e "drop database oldboy;show databases;" 

#出現問題10分鐘後,發現問題,刪除了數據庫了.


#開始恢復準備

#採用iptables防火牆屏蔽全部應用程序的寫入。

[root@oldboy ~]# iptables -I INPUT -p tcp --dport3306 ! -s 172.16.1.51 -j DROP #<==172.16.1.51禁止訪問數據庫3306端口。

#拷貝binlog文件到剛纔建立的目錄中

cp -a /application/mysql/logs/oldboy-bin.* /data/backup/

cd /data/backup


#解壓備份文件

zcat oldboy_2017-06-22.sql.gz>oldboy_2017-06-22.sql

#查看備份後執行的命令放在哪一個binlog下

sed -n '22p' oldboy_2017-06-22.sql

-- CHANGE MASTER TO MASTER_LOG_FILE='oldboy-bin.000003',MASTER_LOG_POS=2623;

#講binlog轉換格式

mysqlbinlog -d oldboy --start-position=2623 oldboy-bin.000003-r bin.sql

#這裏要對應上面查看的


#開始恢復

#開始恢復全備。恢復順序很重要

[root@db02 backup]# mysql –uroot –poldboy123<oldboy_2017-06-22.sql

[root@db02 backup]# mysql -e "showdatabases;"

+--------------------+

| Database          |

+--------------------+

| information_schema |

| mysql             |

| oldboy            |

| oldgirl           |

| performance_schema |

+--------------------+

 

[root@db02 backup]# mysql -e "useoldboy;select * from oldboy;"

+----+---------+

| id | name   |

+----+---------+

|  1 |oldboy  |

|  2 |oldgirl |

|  3 |inca    |

|  4 |zuma    |

|  5 |kaka    |

+----+---------+

 

 

#開始恢復增量

[root@db02 backup]# mysql oldboy <bin.sql

[root@db02 backup]# mysql -e "useoldboy;select * from oldboy;"

+----+----------+

| id | name    |

+----+----------+

|  1 |oldboy   |

|  2 |oldgirl  |

|  3 |inca     |

|  4 |zuma     |

|  5 |kaka     |

|  6 |bingbing |

|  7 |xiaoting |

+----+----------+

恢復完畢。

調整iptables容許用戶訪問.

相關文章
相關標籤/搜索