MySQL Cluster 备份与恢复

本文详细介绍了MySQL NDB Cluster集群的备份与恢复过程,包括管理节点备份、SQL节点数据清理、各节点重启及NDBD节点数据恢复的具体步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  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. 既忽略表空间和分组空间  
1、在管理节点上进行备份。
ndb_mgm> start backup
ndb_mgm> shutdown
ndb_mgm> exit
2、删掉SQL节点的数据。
   DROP DATABASE TEST_CLUSTER;
3、关闭MYSQLD服务器。
[root@localhost bin]# service mysqld stop
Shutting down MySQL... SUCCESS! 
4、重新顺序启动所有节点。
[root@localhost mysql]#ndb_mgmd -f /etc/config.ini --reload
[root@localhost data]#ndbd --initial
我发现如果不带这个 --initial选项的话,恢复会失败。
[root@localhost bin]# service mysqld start
//我用的7.0.8a版rpm 安装<b>service mysqld start</b>无法启动,用、、
//[root@localhost ~]# mysqld_safe &

4、在NDBD节点上进行恢复。(每个节点都得执行一次,因为数据分散在两个节点上)
第一个节点:
[root@localhost BACKUP]# /usr/local/mysql/bin/ndb_restore -n3 -b4 -r -m --backup_path=/usr/local/mysql/data/BACKUP/BACKUP-4/ 
-r开关是记录集合。
-m是元数据。就是表和库的SCHEMA。
Nodeid = 3
Backup Id = 4
backup path = /usr/local/mysql/data/BACKUP/BACKUP-4/
Ndb version in backup files: Version 5.1.21
Connected to ndb!!
Successfully restored table `test_cluster/def/lk4_test`
...
Successfully created index `PRIMARY` on `lk4_test`
...
_____________________________________________________
Processing data in table: test_cluster/def/lk4_test54) fragment 1
_____________________________________________________
...
Restored 37 tuples and 0 log entries

NDBT_ProgramExit: 0 - OK
第二个节点:
[root@localhost BACKUP-1]# /usr/local/mysql/bin/ndb_restore -n4 -b4  -r --backup_path=/usr/local/mysql/data/BACKUP/BACKUP-4/
Nodeid = 4
Backup Id = 4
backup path = /usr/local/mysql/data/BACKUP/BACKUP-4/
Ndb version in backup files: Version 5.1.21
Connected to ndb!!
_____________________________________________________
Processing data in table: sys/def/NDB$EVENTS_0(1) fragment 1
_____________________________________________________
Processing data in table: mysql/def/ndb_apply_status(4) fragment 1
_____________________________________________________
Processing data in table: mysql/def/NDB$BLOB_2_3(3) fragment 1
_____________________________________________________
Processing data in table: test/def/t11(5) fragment 1
_____________________________________________________
Processing data in table: sys/def/SYSTAB_0(0) fragment 1
_____________________________________________________
Processing data in table: mysql/def/ndb_schema(2) fragment 1
Restored 2 tuples and 0 log entries

NDBT_ProgramExit: 0 - OK


这里完成。
5、查看一下有没有数据,为了安全起见。
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| test               |
+--------------------+
3 rows in set (0.00 sec)
没有恢复的数据库?
MYSQL现在必须重新建立SCHEMA。

mysql> create database test_cluster;
Query OK, 1 row affected (0.33 sec)

mysql> use test_cluster;
Database changed
mysql> show tables;
+------------------------------+
| Tables_in_test_cluster       |
+------------------------------+
| lk4_test                     |
| ...                          |
+------------------------------+
27 rows in set (0.11 sec)

mysql> select * from cs_comment;
Empty set (0.00 sec)

不过MYSQL的backup 程序现在还只能进行完全备份。
[root@localhost BACKUP]# du -h
76K     ./BACKUP-2
96K     ./BACKUP-6
180K    ./BACKUP-4
172K    ./BACKUP-3
76K     ./BACKUP-1
60K     ./BACKUP-5
668K    .

6、在NDBD节点上进行恢复的时候有一个要注意的问题。
因为NDBD节点以 --initial 方式启动的时候不会自动删除undo 和 data 文件(即保存到磁盘上的表数据),所以得手动在每个NDBD节点上进行RM操作:

[root@node239 ndb_6_fs]# rm -rf *.dat

然后开始备份。
在MASTER上备份的时候要加 -m 开关。
在SLAVE上要加-d 而且不要-m开关。

具体步骤如下:
MASTER : 

[root@localhost ndb_3_fs]# /usr/local/mysql/bin/ndb_restore -n3 -b1 -r -m --backup_path=/usr/local/mysql/data/BACKUP/BACKUP-1/
Nodeid = 3
Backup Id = 1
backup path = /usr/local/mysql/data/BACKUP/BACKUP-1/
Ndb version in backup files: Version 5.1.21
Connected to ndb!!
Creating logfile group: lg_1...done
Creating tablespace: ts_1...done
Creating datafile "data_1.dat"...done
Creating undofile "undo_1.dat"...done
Successfully restored table `test/def/t11`
Successfully restored table event REPL$test/t11
_____________________________________________________
Processing data in table: sys/def/NDB$EVENTS_0(1) fragment 0
_____________________________________________________
Processing data in table: mysql/def/NDB$BLOB_2_3(3) fragment 0
_____________________________________________________
Processing data in table: sys/def/SYSTAB_0(0) fragment 0
_____________________________________________________
Processing data in table: mysql/def/ndb_schema(2) fragment 0
_____________________________________________________
Processing data in table: mysql/def/ndb_apply_status(4) fragment 0
_____________________________________________________
Processing data in table: test/def/t11(10) fragment 0
Restored 26 tuples and 0 log entries

NDBT_ProgramExit: 0 - OK

其他的SLAVE上的操作:

[root@node239 ndb_6_fs]# /usr/local/mysql/bin/ndb_restore -n6 -b1 -r -d --backup_path=/usr/local/mysql/data/BACKUP/BACKUP-1/                                                                                                                
Nodeid = 6
Backup Id = 1
backup path = /usr/local/mysql/data/BACKUP/BACKUP-1/
Ndb version in backup files: Version 5.1.21
Connected to ndb!!
_____________________________________________________
Processing data in table: sys/def/NDB$EVENTS_0(1) fragment 3
_____________________________________________________
Processing data in table: mysql/def/NDB$BLOB_2_3(3) fragment 3
_____________________________________________________
Processing data in table: sys/def/SYSTAB_0(0) fragment 3
_____________________________________________________
Processing data in table: mysql/def/ndb_schema(2) fragment 3
_____________________________________________________
Processing data in table: mysql/def/ndb_apply_status(4) fragment 3
_____________________________________________________
Processing data in table: test/def/t11(10) fragment 3
Restored 20 tuples and 0 log entries

NDBT_ProgramExit: 0 - OK



-d 开关的意思即:
 -d, --no-restore-disk-objects 
                      Dont restore disk objects (tablespace/logfilegroups etc)
既忽略表空间和分组空间



异常:
[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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值