原文轉自:http://rootking.blog.51cto.com/2619611/476212
一、什麼是多路徑
普通的電腦主機都是一個硬碟挂接到一個總線上,這裡是一對一的關系。而到了有光纖組成的SAN環境,或者由iSCSI組成的IPSAN環境,由于主機和存儲通過了光纖交換機或者多塊網卡及IP來連接配接,這樣的話,就構成了多對多的關系。也就是說,主機到存儲可以有多條路徑可以選擇。主機到存儲之間的IO由多條路徑可以選擇。
每個主機到所對應的存儲可以經過幾條不同的路徑,如果是同時使用的話,I/O流量如何配置設定?其中一條路徑壞掉了,如何處理?還有在作業系統的角度來看,每條路徑,作業系統會認為是一個實際存在的實體盤,但實際上隻是通向同一個實體盤的不同路徑而已,這樣是在使用的時候,就給使用者帶來了困惑。多路徑軟體就是為了解決上面的問題應運而生的。
多路徑的主要功能就是和儲存設備一起配合實作如下功能:
1.故障的切換和恢複
2.IO流量的負載均衡
3.磁盤的虛拟化
由于多路徑軟體是需要和存儲在一起配合使用的,不同的廠商基于不同的作業系統,都提供了不同的版本。并且有的廠商,軟體和硬體也不是一起賣的,如果要使用多路徑軟體的話,可能還需要向廠商購買license才行。比如EMC公司基于linux下的多路徑軟體,就需要單獨的購買license。好在, RedHat和Suse的2.6的核心中都自帶了免費的多路徑軟體包,并且可以免費使用,同時也是一個比較通用的包,可以支援大多數存儲廠商的裝置,即使是一些不是出名的廠商,通過對配置檔案進行稍作修改,也是可以支援并運作的很好的。
二、Linux下multipath介紹,需要以下工具包:
在CentOS 5中,最小安裝系統時multipath已經被安裝,檢視multipath是否安裝如下:
[root@rac1 ~]# rpm -aq|grep mapper
device-mapper-multipath-0.4.7-34.el5
device-mapper-event-1.02.39-1.el5
device-mapper-1.02.39-1.el5
[root@rac1 ~]#
1、device-mapper-multipath:即multipath-tools。主要提供multipathd和multipath等工具和 multipath.conf等配置檔案。這些工具通過device mapper的ioctr的接口建立和配置multipath裝置(調用device-mapper的使用者空間庫。建立的多路徑裝置會在/dev
/mapper中)。
2、 device-mapper:主要包括兩大部分:核心部分和使用者部分。核心部分主要由device mapper核心(dm.ko)和一些target driver(md-multipath.ko)。核心完成裝置的映射,而target根據映射關系和自身特點具體處理從mappered
device 下來的I/O。同時,在核心部分,提供了一個接口,使用者通過ioctr可和核心部分通信,以指導核心驅動的行為,比如如何建立mappered device,這些divece的屬性等。linux device mapper的使用者空間部分主要包括device-mapper這個包。其中包括dmsetup工具和一些幫助建立和配置mappered device的庫。這些庫主要抽象,封裝了與ioctr通信的接口,以便友善建立和配置mappered device。multipath-tool的程式中就需要調用這些庫。
3、dm-multipath.ko和dm.ko:dm.ko是device mapper驅動。它是實作multipath的基礎。dm-multipath其實是dm的一個target驅動。
4、scsi_id: 包含在udev程式包中,可以在multipath.conf中配置該程式來擷取scsi裝置的序号。通過序号,便可以判斷多個路徑對應了同一裝置。這個是多路徑實作的關鍵。scsi_id是通過sg驅動,向裝置發送EVPD page80或page83
的inquery指令來查詢scsi裝置的辨別。但一些裝置并不支援EVPD 的inquery指令,是以他們無法被用來生成multipath裝置。但可以改寫scsi_id,為不能提供scsi裝置辨別的裝置虛拟一個辨別符,并輸出到标準輸出。multipath程式在建立multipath裝置時,會調用scsi_id,從其标準輸出中獲得該裝置的scsi id。在改寫時,需要修改scsi_id程式的傳回值為0。因為在multipath程式中,會檢查該直來确定scsi id是否已經成功得到。
三、multipath在CentOS5中的基本配置過程:
1、安裝和加載多路徑軟體包
# yum –y install device-mapper device-mapper-multipath
# chkconfig –level 2345 multipathdon #設定成開機自啟動multipathd
# lsmod |grep dm_multipath #來檢查安裝是否正常
dm_multipath 56153 0
scsi_dh 41665 1 dm_multipath
dm_mod 101521 4 dm_mirror,dm_multipath,dm_raid45,dm_log
如果子產品沒有加載成功請使用下列命初始化DM,或重新開機系統
---Use the following commands to initialize and start DM for the firsttime:
# modprobe dm-multipath
# modprobe dm-round-robin
# service multipathd start
# multipath –v2
[root@rac1 ~]#
service multipathd status
multipathd is stopped
2、配置multipath:
Multipath的配置檔案是/etc/multipath.conf ,
如需要multipath正常工作隻需要如下配置即可:(如果需要更加詳細的配置,請看本文後續的介紹)
blacklist {
devnode "^sda"
}
defaults {
user_friendly_names yes
path_grouping_policy multibus
failback immediate
no_path_retry fail
# vi /etc/multipath.conf