国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

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

2024-07-24 13:07:49
字體:
供稿:網(wǎng)友

這篇文章主要介紹了MySQL備份與恢復(fù)之冷備,冷備一般需要定制計(jì)劃,比如什么時(shí)候做備份,每次對哪些數(shù)據(jù)進(jìn)行備份等等,對冷備感興趣的小伙伴們可以參考一下

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

冷備示意圖

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

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

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

 

 
  1. mysql> use larrydb; 
  2. Database changed 
  3. mysql> show tables; 
  4. +-------------------+ 
  5. | Tables_in_larrydb | 
  6. +-------------------+ 
  7. | access | 
  8. +-------------------+ 
  9. 1 row in set (0.00 sec) 
  10.  
  11. mysql> drop table access; 
  12. Query OK, 0 rows affected (0.00 sec) 
  13.  
  14. mysql> clear 
  15. mysql> show tables; 
  16. Empty set (0.00 sec) 
  17.  
  18. mysql>  
  19. mysql> create table class
  20. -> cid int
  21. -> cname varchar(30)); 
  22. Query OK, 0 rows affected (0.01 sec) 
  23.  
  24. mysql> show create table class /G; 
  25. *************************** 1. row *************************** 
  26. Table: class 
  27. Create Table: CREATE TABLE `class` ( 
  28. `cid` int(11) DEFAULT NULL, 
  29. `cname` varchar(30) DEFAULT NULL 
  30. ) ENGINE=InnoDB DEFAULT CHARSET=latin1 
  31. 1 row in set (0.00 sec) 
  32.  
  33. ERROR:  
  34. No query specified 
  35.  
  36. mysql> create table stu( 
  37. -> sid int
  38. -> sname varchar(30), 
  39. -> cid int) engine=myisam; 
  40. Query OK, 0 rows affected (0.00 sec) 
  41.  
  42. mysql> show create table stu /G; 
  43. *************************** 1. row *************************** 
  44. Table: stu 
  45. Create Table: CREATE TABLE `stu` ( 
  46. `sid` int(11) DEFAULT NULL, 
  47. `sname` varchar(30) DEFAULT NULL, 
  48. `cid` int(11) DEFAULT NULL 
  49. ) ENGINE=MyISAM DEFAULT CHARSET=utf8 
  50. 1 row in set (0.00 sec) 
  51.  
  52. ERROR:  
  53. No query specified 
  54.  
  55. mysql> insert into class values(1,'linux'),(2,'oracle'); 
  56. Query OK, 2 rows affected (0.00 sec) 
  57. Records: 2 Duplicates: 0 Warnings: 0 
  58.  
  59. mysql> desc class
  60. +-------+-------------+------+-----+---------+-------+ 
  61. | Field | Type | Null | Key | Default | Extra | 
  62. +-------+-------------+------+-----+---------+-------+ 
  63. | cid | int(11) | YES | | NULL | | 
  64. | cname | varchar(30) | YES | | NULL | | 
  65. +-------+-------------+------+-----+---------+-------+ 
  66. 2 rows in set (0.00 sec) 
  67.  
  68. mysql> desc stu; 
  69. +-------+-------------+------+-----+---------+-------+ 
  70. | Field | Type | Null | Key | Default | Extra | 
  71. +-------+-------------+------+-----+---------+-------+ 
  72. | sid | int(11) | YES | | NULL | | 
  73. | sname | varchar(30) | YES | | NULL | | 
  74. | cid | int(11) | YES | | NULL | | 
  75. +-------+-------------+------+-----+---------+-------+ 
  76. 3 rows in set (0.00 sec) 
  77.  
  78. mysql> insert into stu values(1,'larry01',1),(2,'larry02',2); 
  79. Query OK, 2 rows affected (0.00 sec) 
  80. Records: 2 Duplicates: 0 Warnings: 0 
  81.  
  82. mysql> select * from stu; 
  83. +------+---------+------+ 
  84. | sid | sname | cid | 
  85. +------+---------+------+ 
  86. | 1 | larry01 | 1 | 
  87. | 2 | larry02 | 2 | 
  88. +------+---------+------+ 

第二步,停掉MySQL

 

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

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

 

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

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

 

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

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

 

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

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

 

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

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

 

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

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

 

 
  1. [root@serv01 databackup]# /etc/init.d/mysqld start 
  2. Starting MySQL.. SUCCESS!  
  3.  
  4. [root@serv01 ~]# mysql 
  5. Welcome to the MySQL monitor. Commands end with ; or /g. 
  6. Your MySQL connection id is 1 
  7. Server version: 5.5.29-log Source distribution 
  8.  
  9. Copyright (c) 2000, 2012, Oracle and/or its affiliates. All rights reserved. 
  10.  
  11. Oracle is a registered trademark of Oracle Corporation and/or its 
  12. affiliates. Other names may be trademarks of their respective 
  13. owners. 
  14.  
  15. Type 'help;' or '/h' for help. Type '/c' to clear the current input statement. 
  16.  
  17. mysql> use larrydb; 
  18. Database changed 
  19. mysql> select * from class
  20. +------+--------+ 
  21. | cid | cname | 
  22. +------+--------+ 
  23. | 1 | linux | 
  24. | 2 | oracle | 
  25. +------+--------+ 
  26. 2 rows in set (0.00 sec) 
  27.  
  28. mysql> select * from stu; 
  29. +------+---------+------+ 
  30. | sid | sname | cid | 
  31. +------+---------+------+ 
  32. | 1 | larry01 | 1 | 
  33. | 2 | larry02 | 2 | 
  34. +------+---------+------+ 
  35. 2 rows in set (0.00 sec) 

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 怀远县| 海南省| 巧家县| 阜城县| 洛扎县| 全南县| 阳江市| 辰溪县| 彝良县| 宣威市| 兴宁市| 视频| 岑巩县| 得荣县| 五大连池市| 民县| 军事| 依兰县| 邛崃市| 长治市| 潍坊市| 武夷山市| 六盘水市| 长顺县| 津市市| 北流市| 江口县| 宝应县| 鲜城| 卫辉市| 阳高县| 日喀则市| 新津县| 邢台市| 天长市| 宣城市| 吉首市| 靖远县| 彭山县| 东港市| 阳高县|