md-cluster.txt 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325
  1. The cluster MD is a shared-device RAID for a cluster, it supports
  2. two levels: raid1 and raid10 (limited support).
  3. 1. On-disk format
  4. Separate write-intent-bitmaps are used for each cluster node.
  5. The bitmaps record all writes that may have been started on that node,
  6. and may not yet have finished. The on-disk layout is:
  7. 0 4k 8k 12k
  8. -------------------------------------------------------------------
  9. | idle | md super | bm super [0] + bits |
  10. | bm bits[0, contd] | bm super[1] + bits | bm bits[1, contd] |
  11. | bm super[2] + bits | bm bits [2, contd] | bm super[3] + bits |
  12. | bm bits [3, contd] | | |
  13. During "normal" functioning we assume the filesystem ensures that only
  14. one node writes to any given block at a time, so a write request will
  15. - set the appropriate bit (if not already set)
  16. - commit the write to all mirrors
  17. - schedule the bit to be cleared after a timeout.
  18. Reads are just handled normally. It is up to the filesystem to ensure
  19. one node doesn't read from a location where another node (or the same
  20. node) is writing.
  21. 2. DLM Locks for management
  22. There are three groups of locks for managing the device:
  23. 2.1 Bitmap lock resource (bm_lockres)
  24. The bm_lockres protects individual node bitmaps. They are named in
  25. the form bitmap000 for node 1, bitmap001 for node 2 and so on. When a
  26. node joins the cluster, it acquires the lock in PW mode and it stays
  27. so during the lifetime the node is part of the cluster. The lock
  28. resource number is based on the slot number returned by the DLM
  29. subsystem. Since DLM starts node count from one and bitmap slots
  30. start from zero, one is subtracted from the DLM slot number to arrive
  31. at the bitmap slot number.
  32. The LVB of the bitmap lock for a particular node records the range
  33. of sectors that are being re-synced by that node. No other
  34. node may write to those sectors. This is used when a new nodes
  35. joins the cluster.
  36. 2.2 Message passing locks
  37. Each node has to communicate with other nodes when starting or ending
  38. resync, and for metadata superblock updates. This communication is
  39. managed through three locks: "token", "message", and "ack", together
  40. with the Lock Value Block (LVB) of one of the "message" lock.
  41. 2.3 new-device management
  42. A single lock: "no-new-dev" is used to co-ordinate the addition of
  43. new devices - this must be synchronized across the array.
  44. Normally all nodes hold a concurrent-read lock on this device.
  45. 3. Communication
  46. Messages can be broadcast to all nodes, and the sender waits for all
  47. other nodes to acknowledge the message before proceeding. Only one
  48. message can be processed at a time.
  49. 3.1 Message Types
  50. There are six types of messages which are passed:
  51. 3.1.1 METADATA_UPDATED: informs other nodes that the metadata has
  52. been updated, and the node must re-read the md superblock. This is
  53. performed synchronously. It is primarily used to signal device
  54. failure.
  55. 3.1.2 RESYNCING: informs other nodes that a resync is initiated or
  56. ended so that each node may suspend or resume the region. Each
  57. RESYNCING message identifies a range of the devices that the
  58. sending node is about to resync. This overrides any previous
  59. notification from that node: only one ranged can be resynced at a
  60. time per-node.
  61. 3.1.3 NEWDISK: informs other nodes that a device is being added to
  62. the array. Message contains an identifier for that device. See
  63. below for further details.
  64. 3.1.4 REMOVE: A failed or spare device is being removed from the
  65. array. The slot-number of the device is included in the message.
  66. 3.1.5 RE_ADD: A failed device is being re-activated - the assumption
  67. is that it has been determined to be working again.
  68. 3.1.6 BITMAP_NEEDS_SYNC: if a node is stopped locally but the bitmap
  69. isn't clean, then another node is informed to take the ownership of
  70. resync.
  71. 3.2 Communication mechanism
  72. The DLM LVB is used to communicate within nodes of the cluster. There
  73. are three resources used for the purpose:
  74. 3.2.1 token: The resource which protects the entire communication
  75. system. The node having the token resource is allowed to
  76. communicate.
  77. 3.2.2 message: The lock resource which carries the data to
  78. communicate.
  79. 3.2.3 ack: The resource, acquiring which means the message has been
  80. acknowledged by all nodes in the cluster. The BAST of the resource
  81. is used to inform the receiving node that a node wants to
  82. communicate.
  83. The algorithm is:
  84. 1. receive status - all nodes have concurrent-reader lock on "ack".
  85. sender receiver receiver
  86. "ack":CR "ack":CR "ack":CR
  87. 2. sender get EX on "token"
  88. sender get EX on "message"
  89. sender receiver receiver
  90. "token":EX "ack":CR "ack":CR
  91. "message":EX
  92. "ack":CR
  93. Sender checks that it still needs to send a message. Messages
  94. received or other events that happened while waiting for the
  95. "token" may have made this message inappropriate or redundant.
  96. 3. sender writes LVB.
  97. sender down-convert "message" from EX to CW
  98. sender try to get EX of "ack"
  99. [ wait until all receivers have *processed* the "message" ]
  100. [ triggered by bast of "ack" ]
  101. receiver get CR on "message"
  102. receiver read LVB
  103. receiver processes the message
  104. [ wait finish ]
  105. receiver releases "ack"
  106. receiver tries to get PR on "message"
  107. sender receiver receiver
  108. "token":EX "message":CR "message":CR
  109. "message":CW
  110. "ack":EX
  111. 4. triggered by grant of EX on "ack" (indicating all receivers
  112. have processed message)
  113. sender down-converts "ack" from EX to CR
  114. sender releases "message"
  115. sender releases "token"
  116. receiver upconvert to PR on "message"
  117. receiver get CR of "ack"
  118. receiver release "message"
  119. sender receiver receiver
  120. "ack":CR "ack":CR "ack":CR
  121. 4. Handling Failures
  122. 4.1 Node Failure
  123. When a node fails, the DLM informs the cluster with the slot
  124. number. The node starts a cluster recovery thread. The cluster
  125. recovery thread:
  126. - acquires the bitmap<number> lock of the failed node
  127. - opens the bitmap
  128. - reads the bitmap of the failed node
  129. - copies the set bitmap to local node
  130. - cleans the bitmap of the failed node
  131. - releases bitmap<number> lock of the failed node
  132. - initiates resync of the bitmap on the current node
  133. md_check_recovery is invoked within recover_bitmaps,
  134. then md_check_recovery -> metadata_update_start/finish,
  135. it will lock the communication by lock_comm.
  136. Which means when one node is resyncing it blocks all
  137. other nodes from writing anywhere on the array.
  138. The resync process is the regular md resync. However, in a clustered
  139. environment when a resync is performed, it needs to tell other nodes
  140. of the areas which are suspended. Before a resync starts, the node
  141. send out RESYNCING with the (lo,hi) range of the area which needs to
  142. be suspended. Each node maintains a suspend_list, which contains the
  143. list of ranges which are currently suspended. On receiving RESYNCING,
  144. the node adds the range to the suspend_list. Similarly, when the node
  145. performing resync finishes, it sends RESYNCING with an empty range to
  146. other nodes and other nodes remove the corresponding entry from the
  147. suspend_list.
  148. A helper function, ->area_resyncing() can be used to check if a
  149. particular I/O range should be suspended or not.
  150. 4.2 Device Failure
  151. Device failures are handled and communicated with the metadata update
  152. routine. When a node detects a device failure it does not allow
  153. any further writes to that device until the failure has been
  154. acknowledged by all other nodes.
  155. 5. Adding a new Device
  156. For adding a new device, it is necessary that all nodes "see" the new
  157. device to be added. For this, the following algorithm is used:
  158. 1. Node 1 issues mdadm --manage /dev/mdX --add /dev/sdYY which issues
  159. ioctl(ADD_NEW_DISK with disc.state set to MD_DISK_CLUSTER_ADD)
  160. 2. Node 1 sends a NEWDISK message with uuid and slot number
  161. 3. Other nodes issue kobject_uevent_env with uuid and slot number
  162. (Steps 4,5 could be a udev rule)
  163. 4. In userspace, the node searches for the disk, perhaps
  164. using blkid -t SUB_UUID=""
  165. 5. Other nodes issue either of the following depending on whether
  166. the disk was found:
  167. ioctl(ADD_NEW_DISK with disc.state set to MD_DISK_CANDIDATE and
  168. disc.number set to slot number)
  169. ioctl(CLUSTERED_DISK_NACK)
  170. 6. Other nodes drop lock on "no-new-devs" (CR) if device is found
  171. 7. Node 1 attempts EX lock on "no-new-dev"
  172. 8. If node 1 gets the lock, it sends METADATA_UPDATED after
  173. unmarking the disk as SpareLocal
  174. 9. If not (get "no-new-dev" lock), it fails the operation and sends
  175. METADATA_UPDATED.
  176. 10. Other nodes get the information whether a disk is added or not
  177. by the following METADATA_UPDATED.
  178. 6. Module interface.
  179. There are 17 call-backs which the md core can make to the cluster
  180. module. Understanding these can give a good overview of the whole
  181. process.
  182. 6.1 join(nodes) and leave()
  183. These are called when an array is started with a clustered bitmap,
  184. and when the array is stopped. join() ensures the cluster is
  185. available and initializes the various resources.
  186. Only the first 'nodes' nodes in the cluster can use the array.
  187. 6.2 slot_number()
  188. Reports the slot number advised by the cluster infrastructure.
  189. Range is from 0 to nodes-1.
  190. 6.3 resync_info_update()
  191. This updates the resync range that is stored in the bitmap lock.
  192. The starting point is updated as the resync progresses. The
  193. end point is always the end of the array.
  194. It does *not* send a RESYNCING message.
  195. 6.4 resync_start(), resync_finish()
  196. These are called when resync/recovery/reshape starts or stops.
  197. They update the resyncing range in the bitmap lock and also
  198. send a RESYNCING message. resync_start reports the whole
  199. array as resyncing, resync_finish reports none of it.
  200. resync_finish() also sends a BITMAP_NEEDS_SYNC message which
  201. allows some other node to take over.
  202. 6.5 metadata_update_start(), metadata_update_finish(),
  203. metadata_update_cancel().
  204. metadata_update_start is used to get exclusive access to
  205. the metadata. If a change is still needed once that access is
  206. gained, metadata_update_finish() will send a METADATA_UPDATE
  207. message to all other nodes, otherwise metadata_update_cancel()
  208. can be used to release the lock.
  209. 6.6 area_resyncing()
  210. This combines two elements of functionality.
  211. Firstly, it will check if any node is currently resyncing
  212. anything in a given range of sectors. If any resync is found,
  213. then the caller will avoid writing or read-balancing in that
  214. range.
  215. Secondly, while node recovery is happening it reports that
  216. all areas are resyncing for READ requests. This avoids races
  217. between the cluster-filesystem and the cluster-RAID handling
  218. a node failure.
  219. 6.7 add_new_disk_start(), add_new_disk_finish(), new_disk_ack()
  220. These are used to manage the new-disk protocol described above.
  221. When a new device is added, add_new_disk_start() is called before
  222. it is bound to the array and, if that succeeds, add_new_disk_finish()
  223. is called the device is fully added.
  224. When a device is added in acknowledgement to a previous
  225. request, or when the device is declared "unavailable",
  226. new_disk_ack() is called.
  227. 6.8 remove_disk()
  228. This is called when a spare or failed device is removed from
  229. the array. It causes a REMOVE message to be send to other nodes.
  230. 6.9 gather_bitmaps()
  231. This sends a RE_ADD message to all other nodes and then
  232. gathers bitmap information from all bitmaps. This combined
  233. bitmap is then used to recovery the re-added device.
  234. 6.10 lock_all_bitmaps() and unlock_all_bitmaps()
  235. These are called when change bitmap to none. If a node plans
  236. to clear the cluster raid's bitmap, it need to make sure no other
  237. nodes are using the raid which is achieved by lock all bitmap
  238. locks within the cluster, and also those locks are unlocked
  239. accordingly.
  240. 7. Unsupported features
  241. There are somethings which are not supported by cluster MD yet.
  242. - change array_sectors.