MySQL備份與恢復(fù)之冷備(1)
用一句話概括冷備,就是把數(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)文章
navicat 連接數(shù)據(jù)庫(kù)隔段時(shí)間后自動(dòng)斷開(kāi)連接的解決方案
這篇文章主要介紹了navicat 連接數(shù)據(jù)庫(kù)隔段時(shí)間后自動(dòng)斷開(kāi)連接的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12MySQL不使用order by實(shí)現(xiàn)排名的三種思路總結(jié)
ORDER BY語(yǔ)句用于根據(jù)指定的列對(duì)結(jié)果集進(jìn)行排序,在日常開(kāi)發(fā)中也經(jīng)常會(huì)用到,但下面這篇文章主要給大家介紹了關(guān)于MySQL不使用order by實(shí)現(xiàn)排名的三種思路,需要的朋友可以參考下2021-06-06MySQL執(zhí)行update語(yǔ)句和原數(shù)據(jù)相同會(huì)再次執(zhí)行嗎
這篇文章主要給大家介紹了關(guān)于MySQL執(zhí)行update語(yǔ)句和原數(shù)據(jù)相同是否會(huì)再次執(zhí)行的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MySQL具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04Navicat 遠(yuǎn)程連接 MySQL實(shí)現(xiàn)步驟解析
這篇文章主要介紹了Navicat 遠(yuǎn)程連接 MySQL實(shí)現(xiàn)步驟解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08mysql 常用數(shù)據(jù)庫(kù)語(yǔ)句 小練習(xí)
一個(gè)mysql小練習(xí) 建表 查詢 修改表 增加字段 刪除字段2009-07-07