Linux中國

在 Linux 下使用 RAID(七):在 RAID 中擴展現有的 RAID 陣列和刪除故障的磁碟

擴展 RAID 陣列和刪除故障的磁碟

假設磁碟中的一個有問題了需要刪除該磁碟,但我們需要在刪除磁碟前添加一個備用磁碟來擴展該鏡像,因為我們需要保存我們的數據。當磁碟發生故障時我們需要從陣列中刪除它,這是這個主題中我們將要學習到的。

擴展 RAID 的特性

  • 我們可以增加(擴展)任意 RAID 集合的大小。
  • 我們可以在使用新磁碟擴展 RAID 陣列後刪除故障的磁碟。
  • 我們可以擴展 RAID 陣列而無需停機。

要求

  • 為了擴展一個RAID陣列,我們需要一個已有的 RAID 組(陣列)。
  • 我們需要額外的磁碟來擴展陣列。
  • 在這裡,我們使用一塊磁碟來擴展現有的陣列。

在我們了解擴展和恢復陣列前,我們必須了解有關 RAID 級別和設置的基本知識。點擊下面的鏈接了解這些。

我的伺服器設置

操作系統    :   CentOS 6.5 Final
IP地址      :   192.168.0.230
主機名     :   grow.tecmintlocal.com
2 塊現有磁碟   :   1 GB
1 塊額外磁碟   :   1 GB

在這裡,我們已有一個 RAID ,有2塊磁碟,每個大小為1GB,我們現在再增加一個磁碟到我們現有的 RAID 陣列中,其大小為1GB。

擴展現有的 RAID 陣列

1、 在擴展陣列前,首先使用下面的命令列出現有的 RAID 陣列。

# mdadm --detail /dev/md0

Check Existing Raid Array

檢查現有的 RAID 陣列

注意: 以上輸出顯示,已經有了兩個磁碟在 RAID 陣列中,級別為 RAID 1。現在我們增加一個磁碟到現有的陣列里。

2、 現在讓我們添加新的磁碟「sdd」,並使用fdisk命令來創建分區。

# fdisk /dev/sdd

請使用以下步驟為 /dev/sdd 創建一個新的分區。

  • n 創建新的分區。
  • 然後按 P 選擇主分區。
  • 接下來選擇分區號為1。
  • 只需按兩次回車鍵選擇默認值即可。
  • 然後,按 P 來列印創建好的分區。
  • L,列出所有可用的類型。
  • t 去修改分區。
  • 鍵入 fd 設置為 Linux 的 RAID 類型,然後按回車確認。
  • 然後再次使用p查看我們所做的更改。
  • 使用w保存更改。

Create New Partition in Linux

為 sdd 創建新的分區

3、 一旦新的 sdd 分區創建完成後,你可以使用下面的命令驗證它。

# ls -l /dev/ | grep sd

Confirm sdd Partition

確認 sdd 分區

4、 接下來,在添加到陣列前先檢查磁碟是否有 RAID 分區。

# mdadm --examine /dev/sdd1

Check Raid on sdd Partition

在 sdd 分區中檢查 RAID

注意:以上輸出顯示,該盤有沒有發現 super-blocks,意味著我們可以將新的磁碟添加到現有陣列。

5、 要添加新的分區 /dev/sdd1 到現有的陣列 md0,請使用以下命令。

# mdadm --manage /dev/md0 --add /dev/sdd1

Add Disk To Raid-Array

添加磁碟到 RAID 陣列

6、 一旦新的磁碟被添加後,在我們的陣列中檢查新添加的磁碟。

# mdadm --detail /dev/md0

Confirm Disk Added to Raid

確認將新磁碟添加到 RAID 中

注意: 在上面的輸出,你可以看到磁碟已經被添加作為備用的。在這裡,我們的陣列中已經有了2個磁碟,但我們期待陣列中有3個磁碟,因此我們需要擴展陣列。

7、 要擴展陣列,我們需要使用下面的命令。

# mdadm --grow --raid-devices=3 /dev/md0

Grow Raid Array

擴展 Raid 陣列

現在我們可以看到第三塊磁碟(sdd1)已被添加到陣列中,在第三塊磁碟被添加後,它將從另外兩塊磁碟上同步數據。

# mdadm --detail /dev/md0

Confirm Raid Array

確認 Raid 陣列

注意: 對於大容量磁碟會需要幾個小時來同步數據。在這裡,我們使用的是1GB的虛擬磁碟,所以它非常快在幾秒鐘內便會完成。

從陣列中刪除磁碟

8、 在數據被從其他兩個磁碟同步到新磁碟sdd1後,現在三個磁碟中的數據已經相同了(鏡像)。

正如我前面所說的,假定一個磁碟出問題了需要被刪除。所以,現在假設磁碟sdc1出問題了,需要從現有陣列中刪除。

在刪除磁碟前我們要將其標記為失效,然後我們才可以將其刪除。

# mdadm --fail /dev/md0 /dev/sdc1
# mdadm --detail /dev/md0

Disk Fail in Raid Array

在 RAID 陣列中模擬磁碟故障

從上面的輸出中,我們清楚地看到,磁碟在下面被標記為 faulty。即使它是 faulty 的,我們仍然可以看到 raid 設備有3個,1個損壞了,狀態是 degraded。

現在我們要從陣列中刪除 faulty 的磁碟,raid 設備將像之前一樣繼續有2個設備。

# mdadm --remove /dev/md0 /dev/sdc1

Remove Disk in Raid Array

在 Raid 陣列中刪除磁碟

9、 一旦故障的磁碟被刪除,然後我們只能使用2個磁碟來擴展 raid 陣列了。

# mdadm --grow --raid-devices=2 /dev/md0
# mdadm --detail /dev/md0

Grow Disks in Raid Array

在 RAID 陣列擴展磁碟

從上面的輸出中可以看到,我們的陣列中僅有2台設備。如果你需要再次擴展陣列,按照如上所述的同樣步驟進行。如果你需要添加一個磁碟作為備用,將其標記為 spare,因此,如果磁碟出現故障時,它會自動頂上去並重建數據。

結論

在這篇文章中,我們已經看到了如何擴展現有的 RAID 集合,以及如何在重新同步已有磁碟的數據後從一個陣列中刪除故障磁碟。所有這些步驟都可以不用停機來完成。在數據同步期間,系統用戶,文件和應用程序不會受到任何影響。

在接下來的文章我將告訴你如何管理 RAID,敬請關注更新,不要忘了寫評論。

via: http://www.tecmint.com/grow-raid-array-in-linux/

作者:Babin Lonston 譯者:strugglingyouth 校對:wxy

本文由 LCTT 原創翻譯,Linux中國 榮譽推出


本文轉載來自 Linux 中國: https://github.com/Linux-CN/archive

對這篇文章感覺如何?

太棒了
0
不錯
0
愛死了
0
不太好
0
感覺很糟
0
雨落清風。心向陽

    You may also like

    Leave a reply

    您的郵箱地址不會被公開。 必填項已用 * 標註

    此站點使用Akismet來減少垃圾評論。了解我們如何處理您的評論數據

    More in:Linux中國