Chinaunix首页 | 论坛 | 博客
  • 博客访问: 5488598
  • 博文数量: 890
  • 博客积分: 12876
  • 博客等级: 上将
  • 技术积分: 10760
  • 用 户 组: 普通用户
  • 注册时间: 2004-10-04 14:18
个人简介

猝然临之而不惊,无故加之而不怒。

文章分类

全部博文(890)

文章存档

2016年(1)

2014年(18)

2013年(41)

2012年(48)

2011年(65)

2010年(84)

2009年(121)

2008年(101)

2007年(129)

2006年(95)

2005年(118)

2004年(69)

分类: LINUX

2005-06-16 14:29:06

Software RAID For Linux

http://andyy2573.52blog.net/more.asp?name=kernel&id=174024

我想大家也聽過RAID 吧! 它能夠保護你的資料, 或是增加讀取的效能,或是把數個硬碟結合在一起。正如大家所知道RAID 也有Hardware RAID Software RAID 之分。Hardware RAID 是透過硬體的支援令OS 認為它是一個device。而Software RAID 則是利用OS 的功能來模擬RAID。由於在Linux 下支援的RAID 卡實在不多, 所以在Linux 下要用IDE RAID 便只能用Software RAID 的方法了。

 

RAID 主要分為Linear RAID 0 to 5 各種Level 我想大家也很清楚其分別吧, 所以只會簡介一下 Linear mode 是會把2 個或以上的Harddisk 連起來, 寫完一個再寫一個。RAID-0 Linear 差不多, 但資料會同時寫在那數個harddisk 上。好處是能夠增進讀寫效能,壞處則是只要其中一個harddisk 有問題則整個RAID-0 partition 的資料也會不見了(~ 筆者家中的電腦舊harddisk 壞了, 所有資料全部失去.. 但和RAID-0 無關 ^^) RAID-1 則會把資料重複寫進harddisk 好處當然是能夠保護資料, 即使一個harddisk 有問題另一個仍然會保留了應有的資料。 壞處便是效能可能會下降。

至於RAID4 5 都必須有3harddisk 以上才能執行。 它們在儲存資料時會同時儲存一寫計算出來的資料。那麼3harddisk 中其中一個有問題時便能夠靠那寫特點計算的資料重新建立數據。4 5 的不同之處在於,RAID-4 會把所有計算出來資料存儲在一個 harddisk 上, 但如果所有harddisk 均同速的話那便會拖慢整個RAID-4 partition。而 RAID-5 則會把計算出來的資料分開。

值得一提的是在同一RAID partition 內的harddisk 最好速度一樣, 大小也一樣。除了 Linear mode 外其他level RAID 在使用不同速度和大小的 harddisk時都可能會令到效能下降。

另外在RAID-45 中我們常常會加進一個spare disks spare disks 在平常是不會被讀寫的,只有在其中一個harddisk fail spare disks 才會代替原有harddisk 的功能。

最後, Swap parition 是不需要RAID 的,因為linux kernel 本身已經能夠同時控制多個 swap parition 的存取來增進效能了。

Kernel Setting

Linux 中設定Software RAID 其實是十分簡單的,首先你必需重新compile 一個support RAID kernel。最新的kernel 2.4.x 已經內建RAID support 了。

你必需要enable 以下的RAID 選項:

Multidevice support ->

 

Multiple devices driver support (RAID and LVM) -- y

RAID support -- y

Linear (append mode) -- y (如果你用linear mode)

RAID-0 (striping) mode -- y (如果你用RAID - 0)

RAID-1 (mirroring) mode -- y (如果你用RAID - 1)

RAID-4 /RAID-5 mode --y (如果你用RAID 4 5)

以上的選項如果你的RAID partition 將會是root paritition 的話請必定要選y 而不是 compile modules。但如果不是的話(例如只有/home RAID paritition),那用modules 也無問題。

然後compile kernel 也不用教吧 ^^

make dep;make bzImage;make modules;make modules_install

設定RAID tools

現在reboot 一下, 看看有沒有問題, 沒有的話便要裝raidtools 了多數的distribution 也附有raidtools 的, 如果沒有的話, debian 的請安裝raidtools2

apt-get install raidtools2

RPM 的話便自己到rpmfind.net 下載了並安裝 ,或到ftp 下載sources compile~ (對不起~ 筆者也中了Debian ^^)

完成安裝了嗎? 那麼便要設定 /etc/raidtab 了,現在你應該沒有這個file 的,但mkraid 預設是會讀取這個設定檔。

Linear mode 的範例設定檔:

raiddev /dev/md0               <--device

       raid-level       linear              <--Raidlevel linear

       nr-raid-disks      2            <--會被加進partition 的總parition

       chunk-size       32          

       persistent-superblock       1

       device            /dev/hde1       <--0parition

       raid-disk  0

       device            /dev/hdf1       <--1parition

       raid-disk  1

至於chunk-size persistent-superblock 是什麼呢? chunk-size 是指寫進單一個 partition 的大小, 例如在RAID-0 中把一個file同時寫進兩個或以上parition 時, 會把 file 分成多大才寫進一其中一個partition 呢? (總不能1 bit 寫在這, 1bit 寫在那吧) chunk-size linear mode 中也許沒意義, 但在其他level RAID-0 對效能是會有影響的。至於persistent-superblock 加上許是為了令kernel 在開機時能直接detect 到那 partition

RAID-0 的範例設定檔:

raiddev /dev/md0

       raid-level 0

       nr-raid-disks      2

       chunk-size       32

       persistent-superblock       1

       device            /dev/hde1

       raid-disk  0

       device            /dev/hdf1

       raid-disk  1

RAID-1 的範例設定檔:

raiddev /dev/md0

       raid-level 1

       nr-raid-disks      2

       nr-spare-disks    1            <-- 還記得剛才說過的spare-disks ?

       chunk-size       4

       persistent-superblock       1

       device            /dev/hde1

       raid-disk  0

       device            /dev/hdf1

       raid-disk  1

       device            /dev/hdh1

       spare-disk       0

RAID-4 的範例設定檔:

raiddev /dev/md0

       raid-level 4

       nr-raid-disks      3            <-- 最少要有3partition

       nr-spare-disks    1

       persistent-superblock       1

       chunk-size       32

       device            /dev/hde1

       raid-disk  0

       device            /dev/hdf1

       raid-disk  1

       device            /dev/hdg1

       raid-disk  2

       device            /dev/hdh1

       spare-disk       0

RAID-5 的範例設定檔:

raiddev /dev/md0

       raid-level 5

       nr-raid-disks      3

       nr-spare-disks    1

       persistent-superblock       1

       chunk-size       32

       parity-algorithm       left-symmetric

       device            /dev/hde1

       raid-disk  0

       device            /dev/hdf1

       raid-disk  1

       device            /dev/hdg1

       raid-disk  2

       device            /dev/hdh1

       spare-disk       0

怎麼樣? 很簡單吧!

寫完你的設定檔後便執行:

mkraid /dev/md0

那麼你的RAID parition 便建立起來了!看一看 /proc/mdstat 吧! ^^

chpapa@power:~$ sudo cat /proc/mdstat

Personalities : [linear] [raid0] [raid1] [raid5]

read_ahead 1024 sectors

md0 : active raid5 hdh1[3] hdg1[2] hdf1[1] hde4[0]

      80418048 blocks level5, 32k chunk, algorithm 2 [3/3] [UUU]

 

unused devices:

跑起來了, 很爽吧!

(順帶一提, 筆者測試是用HPT370 RAID Card,在Linux Kernel 中選用HPT366 driver 便能認得出各devices )

哈哈~ 但那些沒看完文章便走去mount /dev/md0 的人該打了, 你還未format partition 呀!

mke2fs -b 4096 /dev/md0

(如果是用RAID 4, 5 的話, mke2fs 是有特點options 的: -R stride=8, 為什麼是8? chunksize 除以 blocksize)

假如你的RAID parition 是要在開機時能夠讓Linux 自動Detect (例如是要做root partition) 的話, 你還有一些事情要做的。

首先當然是要有kernel support 吧, 如果是root partition 的話請compile 成內建而不是modules。另外要有persistent-superblock, 剛才便已經有了。最後是每個parition type 都要為Linux raid autodetect。

頭兩項剛才已經列明了做法, 至於要把partition type 轉為Linux raid autodetect...

首先用raidstop 暫停raid partition /dev/md0

power:/# raidstop /dev/md0

power:/# fdisk /dev/h                                   
阅读(1061) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~