MySQL Cluster 备份与恢复

  1. 1、在管理节点上进行备份。   
  2. ndb_mgm> start backup   
  3. ndb_mgm> shutdown   
  4. ndb_mgm> exit   
  5. 2、删掉SQL节点的数据。   
  6.    DROP DATABASE TEST_CLUSTER;   
  7. 3、关闭MYSQLD服务器。   
  8. [root@localhost bin]# service mysqld stop   
  9. Shutting down MySQL... SUCCESS!    
  10. 4、重新顺序启动所有节点。   
  11. [root@localhost mysql]#ndb_mgmd -f /etc/config.ini --reload   
  12. [root@localhost data]#ndbd --initial   
  13. 我发现如果不带这个 --initial选项的话,恢复会失败。   
  14. [root@localhost bin]# service mysqld start   
  15. //我用的7.0.8a版rpm 安装<b>service mysqld start</b>无法启动,用、、   
  16. //[root@localhost ~]# mysqld_safe &   
  17.   
  18. 4、在NDBD节点上进行恢复。(每个节点都得执行一次,因为数据分散在两个节点上)   
  19. 第一个节点:   
  20. [root@localhost BACKUP]# /usr/local/mysql/bin/ndb_restore -n3 -b4 -r -m --backup_path=/usr/local/mysql/data/BACKUP/BACKUP-4/    
  21. -r开关是记录集合。   
  22. -m是元数据。就是表和库的SCHEMA。   
  23. Nodeid = 3  
  24. Backup Id = 4  
  25. backup path = /usr/local/mysql/data/BACKUP/BACKUP-4/   
  26. Ndb version in backup files: Version 5.1.21  
  27. Connected to ndb!!   
  28. Successfully restored table `test_cluster/def/lk4_test`   
  29. ...   
  30. Successfully created index `PRIMARY` on `lk4_test`   
  31. ...   
  32. _____________________________________________________   
  33. Processing data in table: test_cluster/def/lk4_test54) fragment 1  
  34. _____________________________________________________   
  35. ...   
  36. Restored 37 tuples and 0 log entries   
  37.   
  38. NDBT_ProgramExit: 0 - OK   
  39. 第二个节点:   
  40. [root@localhost BACKUP-1]# /usr/local/mysql/bin/ndb_restore -n4 -b4  -r --backup_path=/usr/local/mysql/data/BACKUP/BACKUP-4/   
  41. Nodeid = 4  
  42. Backup Id = 4  
  43. backup path = /usr/local/mysql/data/BACKUP/BACKUP-4/   
  44. Ndb version in backup files: Version 5.1.21  
  45. Connected to ndb!!   
  46. _____________________________________________________   
  47. Processing data in table: sys/def/NDB$EVENTS_0(1) fragment 1  
  48. _____________________________________________________   
  49. Processing data in table: mysql/def/ndb_apply_status(4) fragment 1  
  50. _____________________________________________________   
  51. Processing data in table: mysql/def/NDB$BLOB_2_3(3) fragment 1  
  52. _____________________________________________________   
  53. Processing data in table: test/def/t11(5) fragment 1  
  54. _____________________________________________________   
  55. Processing data in table: sys/def/SYSTAB_0(0) fragment 1  
  56. _____________________________________________________   
  57. Processing data in table: mysql/def/ndb_schema(2) fragment 1  
  58. Restored 2 tuples and 0 log entries   
  59.   
  60. NDBT_ProgramExit: 0 - OK   
  61.   
  62.   
  63. 这里完成。   
  64. 5、查看一下有没有数据,为了安全起见。   
  65. mysql> show databases;   
  66. +--------------------+   
  67. | Database           |   
  68. +--------------------+   
  69. | information_schema |   
  70. | mysql              |   
  71. | test               |   
  72. +--------------------+   
  73. 3 rows in set (0.00 sec)   
  74. 没有恢复的数据库?   
  75. MYSQL现在必须重新建立SCHEMA。   
  76.   
  77. mysql> create database test_cluster;   
  78. Query OK, 1 row affected (0.33 sec)   
  79.   
  80. mysql> use test_cluster;   
  81. Database changed   
  82. mysql> show tables;   
  83. +------------------------------+   
  84. | Tables_in_test_cluster       |   
  85. +------------------------------+   
  86. | lk4_test                     |   
  87. | ...                          |   
  88. +------------------------------+   
  89. 27 rows in set (0.11 sec)   
  90.   
  91. mysql> select * from cs_comment;   
  92. Empty set (0.00 sec)   
  93.   
  94. 不过MYSQL的backup 程序现在还只能进行完全备份。   
  95. [root@localhost BACKUP]# du -h   
  96. 76K     ./BACKUP-2  
  97. 96K     ./BACKUP-6  
  98. 180K    ./BACKUP-4  
  99. 172K    ./BACKUP-3  
  100. 76K     ./BACKUP-1  
  101. 60K     ./BACKUP-5  
  102. 668K    .   
  103.   
  104. 6、在NDBD节点上进行恢复的时候有一个要注意的问题。   
  105. 因为NDBD节点以 --initial 方式启动的时候不会自动删除undo 和 data 文件(即保存到磁盘上的表数据),所以得手动在每个NDBD节点上进行RM操作:   
  106.   
  107. [root@node239 ndb_6_fs]# rm -rf *.dat   
  108.   
  109. 然后开始备份。   
  110. 在MASTER上备份的时候要加 -m 开关。   
  111. 在SLAVE上要加-d 而且不要-m开关。   
  112.   
  113. 具体步骤如下:   
  114. MASTER :    
  115.   
  116. [root@localhost ndb_3_fs]# /usr/local/mysql/bin/ndb_restore -n3 -b1 -r -m --backup_path=/usr/local/mysql/data/BACKUP/BACKUP-1/   
  117. Nodeid = 3  
  118. Backup Id = 1  
  119. backup path = /usr/local/mysql/data/BACKUP/BACKUP-1/   
  120. Ndb version in backup files: Version 5.1.21  
  121. Connected to ndb!!   
  122. Creating logfile group: lg_1...done   
  123. Creating tablespace: ts_1...done   
  124. Creating datafile "data_1.dat"...done   
  125. Creating undofile "undo_1.dat"...done   
  126. Successfully restored table `test/def/t11`   
  127. Successfully restored table event REPL$test/t11   
  128. _____________________________________________________   
  129. Processing data in table: sys/def/NDB$EVENTS_0(1) fragment 0  
  130. _____________________________________________________   
  131. Processing data in table: mysql/def/NDB$BLOB_2_3(3) fragment 0  
  132. _____________________________________________________   
  133. Processing data in table: sys/def/SYSTAB_0(0) fragment 0  
  134. _____________________________________________________   
  135. Processing data in table: mysql/def/ndb_schema(2) fragment 0  
  136. _____________________________________________________   
  137. Processing data in table: mysql/def/ndb_apply_status(4) fragment 0  
  138. _____________________________________________________   
  139. Processing data in table: test/def/t11(10) fragment 0  
  140. Restored 26 tuples and 0 log entries   
  141.   
  142. NDBT_ProgramExit: 0 - OK   
  143.   
  144. 其他的SLAVE上的操作:   
  145.   
  146. [root@node239 ndb_6_fs]# /usr/local/mysql/bin/ndb_restore -n6 -b1 -r -d --backup_path=/usr/local/mysql/data/BACKUP/BACKUP-1/                                                                                                                   
  147. Nodeid = 6  
  148. Backup Id = 1  
  149. backup path = /usr/local/mysql/data/BACKUP/BACKUP-1/   
  150. Ndb version in backup files: Version 5.1.21  
  151. Connected to ndb!!   
  152. _____________________________________________________   
  153. Processing data in table: sys/def/NDB$EVENTS_0(1) fragment 3  
  154. _____________________________________________________   
  155. Processing data in table: mysql/def/NDB$BLOB_2_3(3) fragment 3  
  156. _____________________________________________________   
  157. Processing data in table: sys/def/SYSTAB_0(0) fragment 3  
  158. _____________________________________________________   
  159. Processing data in table: mysql/def/ndb_schema(2) fragment 3  
  160. _____________________________________________________   
  161. Processing data in table: mysql/def/ndb_apply_status(4) fragment 3  
  162. _____________________________________________________   
  163. Processing data in table: test/def/t11(10) fragment 3  
  164. Restored 20 tuples and 0 log entries   
  165.   
  166. NDBT_ProgramExit: 0 - OK   
  167.   
  168.   
  169.   
  170. -d 开关的意思即:   
  171.  -d, --no-restore-disk-objects    
  172.                       Dont restore disk objects (tablespace/logfilegroups etc)   
  173. 既忽略表空间和分组空间  


异常:
[root@localhost ~]# ndb_restore -n2 -b2 -r -m --backup_path=/var/lib/mysql-cluster/BACKUP/BACKUP-2
Nodeid = 2
Backup Id = 2
backup path = /var/lib/mysql-cluster/BACKUP/BACKUP-2
Opening file '/var/lib/mysql-cluster/BACKUP/BACKUP-2/BACKUP-2.2.ctl'
Backup version in files: ndb-6.3.11 ndb version: mysql-5.1.37 ndb-7.0.8
Stop GCP of Backup: 0
Configuration error: Error : Could not alloc node id at 192.168.8.120 port 1186: Connection done from wrong host ip 192.168.8.121.
Failed to initialize consumers

NDBT_ProgramExit: 1 - Failed
解决:管理节点配置文件添加
[mysqld]
//空节点

come from http://xylonwang.iteye.com/blog/563063

你可能感兴趣的:(MySQL Cluster 备份与恢复)