欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL備份與恢復(fù)之冷備(1)

 更新時(shí)間:2015年08月12日 09:36:26   作者:Wentasy  
這篇文章主要介紹了MySQL備份與恢復(fù)之冷備,冷備一般需要定制計(jì)劃,比如什么時(shí)候做備份,每次對(duì)哪些數(shù)據(jù)進(jìn)行備份等等,對(duì)冷備感興趣的小伙伴們可以參考一下

        用一句話概括冷備,就是把數(shù)據(jù)庫(kù)服務(wù),比如MySQL,Oracle停下來(lái),然后使用拷貝、打包或者壓縮命令對(duì)數(shù)據(jù)目錄進(jìn)行備份。如果數(shù)據(jù)出現(xiàn)異常,則可以通過(guò)備份數(shù)據(jù)恢復(fù)。冷備一般需要定制計(jì)劃,比如什么時(shí)候做備份,每次對(duì)哪些數(shù)據(jù)進(jìn)行備份等等。但是由于這樣的備份占用過(guò)多的空間,對(duì)大數(shù)據(jù)量的環(huán)境下不一定適合,故生產(chǎn)環(huán)境很少使用。

冷備示意圖

 

冷備實(shí)驗(yàn)

第一步,創(chuàng)建測(cè)試數(shù)據(jù)庫(kù),插入測(cè)試數(shù)據(jù)

mysql> use larrydb;
Database changed
mysql> show tables;
+-------------------+
| Tables_in_larrydb |
+-------------------+
| access  |
+-------------------+
1 row in set (0.00 sec)

mysql> drop table access;
Query OK, 0 rows affected (0.00 sec)

mysql> clear
mysql> show tables;
Empty set (0.00 sec)

mysql> 
mysql> create table class(
 -> cid int,
 -> cname varchar(30));
Query OK, 0 rows affected (0.01 sec)

mysql> show create table class \G;
*************************** 1. row ***************************
 Table: class
Create Table: CREATE TABLE `class` (
 `cid` int(11) DEFAULT NULL,
 `cname` varchar(30) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=latin1
1 row in set (0.00 sec)

ERROR: 
No query specified

mysql> create table stu(
 -> sid int,
 -> sname varchar(30),
 -> cid int) engine=myisam;
Query OK, 0 rows affected (0.00 sec)

mysql> show create table stu \G;
*************************** 1. row ***************************
 Table: stu
Create Table: CREATE TABLE `stu` (
 `sid` int(11) DEFAULT NULL,
 `sname` varchar(30) DEFAULT NULL,
 `cid` int(11) DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8
1 row in set (0.00 sec)

ERROR: 
No query specified

mysql> insert into class values(1,'linux'),(2,'oracle');
Query OK, 2 rows affected (0.00 sec)
Records: 2 Duplicates: 0 Warnings: 0

mysql> desc class;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| cid | int(11) | YES | | NULL | |
| cname | varchar(30) | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

mysql> desc stu;
+-------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| sid | int(11) | YES | | NULL | |
| sname | varchar(30) | YES | | NULL | |
| cid | int(11) | YES | | NULL | |
+-------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

mysql> insert into stu values(1,'larry01',1),(2,'larry02',2);
Query OK, 2 rows affected (0.00 sec)
Records: 2 Duplicates: 0 Warnings: 0

mysql> select * from stu;
+------+---------+------+
| sid | sname | cid |
+------+---------+------+
| 1 | larry01 | 1 |
| 2 | larry02 | 2 |
+------+---------+------+
 

第二步,停掉MySQL

[root@serv01 ~]# /etc/init.d/mysqld stop
Shutting down MySQL... SUCCESS! 

 
第三步,創(chuàng)建備份目錄,并修改擁有者和所屬組

[root@serv01 ~]# mkdir /databackup
[root@serv01 ~]# chown mysql.mysql /databackup/ -R
[root@serv01 ~]# ll /databackup/ -d
drwxr-xr-x. 2 mysql mysql 4096 Sep 10 17:46 /databackup/
[root@serv01 ~]# cd /databackup/
 

第四步,冷備(使用tar命令)

[root@serv01 databackup]# tar -cvPzf mysql01.tar.gz 

 
第五步,測(cè)試?yán)鋫涞臄?shù)據(jù)是否正常,我們刪除掉data下的所有數(shù)據(jù)

[root@serv01 databackup]# rm -rf /usr/local/mysql/data/*

 
第六步,刪除所有數(shù)據(jù)后數(shù)據(jù)庫(kù)不能啟動(dòng)

[root@serv01 databackup]# /etc/init.d/mysqld start
Starting MySQL.. ERROR! The server quit without updating PID file (/usr/local/mysql/data/serv01.host.com.pid).

 
第七步,恢復(fù)數(shù)據(jù)(使用tar命令)

[root@serv01 databackup]# tar -xvPf mysql01.tar.gz 

 
第八步,啟動(dòng)MySQL,然后登錄MySQL,查看數(shù)據(jù)是否丟失,如果數(shù)據(jù)正常代表冷備成功

[root@serv01 databackup]# /etc/init.d/mysqld start
Starting MySQL.. SUCCESS! 

[root@serv01 ~]# mysql
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.5.29-log Source distribution

Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> use larrydb;
Database changed
mysql> select * from class;
+------+--------+
| cid | cname |
+------+--------+
| 1 | linux |
| 2 | oracle |
+------+--------+
2 rows in set (0.00 sec)

mysql> select * from stu;
+------+---------+------+
| sid | sname | cid |
+------+---------+------+
| 1 | larry01 | 1 |
| 2 | larry02 | 2 |
+------+---------+------+
2 rows in set (0.00 sec)

以上就是實(shí)現(xiàn)MySQL冷備的全部過(guò)程,大家對(duì)冷備有沒(méi)有了大概的了解,希望這篇文章可以對(duì)大家的學(xué)習(xí)有所幫助。

相關(guān)文章

最新評(píng)論