詳解Linux Multipath多路徑配置:概念、配置、常用維護(hù)命令等
在Linux平臺一部分存儲產(chǎn)品使用操作系統(tǒng)自帶的多路徑軟件,包括最常見的HP和IBM的部分存儲產(chǎn)品,在Linux自帶的多路徑軟件叫做multipath。
那么問題就來了,到底什么是多路徑?
普通的電腦主機(jī)都是一個硬盤掛接到一個總線上,這里是一對一的關(guān)系。而到了有光纖組成的SAN環(huán)境,或者由iSCSI組成的IPSAN環(huán)境,由于主機(jī)和存儲通過了光纖交換機(jī)或者多塊網(wǎng)卡及IP來連接,這樣的話,就構(gòu)成了多對多的關(guān)系。也就是說,主機(jī)到存儲可以有多條路徑可以選擇。主機(jī)到存儲之間的IO由多條路徑可以選擇。每個主機(jī)到所對應(yīng)的存儲可以經(jīng)過幾條不同的路徑,如果是同時使用的話,I/O流量如何分配?其中一條路徑壞掉了,如何處理?從在操作系統(tǒng)的角度來看,每條路徑,操作系統(tǒng)會認(rèn)為是一個實際存在的物理盤,但實際上只是通向同一個物理盤的不同路徑而已,這樣是在使用的時候,就給用戶帶來了困惑。多路徑軟件就是為了解決上面的問題。
1. multipath介紹
在redhat中,安裝操作系統(tǒng)的時候multipath已經(jīng)默認(rèn)被安裝,查看安裝情況
- # rpm -qa | grep device-mapper
說明:
(1) device-mapper-multipath:即multipath-tools。主要提供multipathd和multipath等工具和 multipath.conf等配置文件。創(chuàng)建的多路徑設(shè)備會在/dev/mapper中。
(2) device-mapper:主要包括兩大部分:內(nèi)核部分和用戶部分。
內(nèi)核部分主要包括device mapper核心(dm.ko)和一些target driver(md-multipath.ko)。核心完成設(shè)備的映射,而target根據(jù)映射關(guān)系和自身特點具體處理從mappered device 下來的i/o。
用戶空間部分主要包括device-mapper這個包。其中包括dmsetup工具和一些幫助創(chuàng)建和配置mappered device的庫。這些庫主要抽象,封裝了與ioctr通信的接口,以便方便創(chuàng)建和配置mappered device。multipath-tool的程序中就需要調(diào)用這些庫。
(3) dm-multipath.ko和dm.ko:dm.ko是device mapper驅(qū)動。它是實現(xiàn)multipath的基礎(chǔ)。dm-multipath其實是dm的一個target驅(qū)動。
(4) scsi_id: 包含在udev程序包中,可以在multipath.conf中配置該程序來獲取scsi設(shè)備的序號。通過序號,便可以判斷多個路徑對應(yīng)了同一設(shè)備。這個是多路徑實現(xiàn)的關(guān)鍵。multipath程序在創(chuàng)建multipath設(shè)備時,會調(diào)用scsi_id,從其標(biāo)準(zhǔn)輸出中獲得該設(shè)備的scsi id。在改寫時,需要修改scsi_id程序的返回值為0。因為在multipath程序中,會檢查該值來確定scsi id是否已經(jīng)成功得到。
2. multipath詳細(xì)配置
因為在安裝操作系統(tǒng)的時候,multipath的軟件包已經(jīng)那裝好了,所以這里就不在需要安裝,如果沒有安裝的話,需要手動的進(jìn)行安裝。
1、檢查安裝是否正常
- # lsmod |grep dm_multipath
如果模塊沒有加載成功,使用下面的命令初始化DM:
- #modprobe dm-multipath
- #modprobe dm-round-robin
- #service multipathd start
- #multipath –v2
2. 編輯配置文件
- # cat /etc/multipath.conf
- blacklist {
- devnode "^sda"
- }
- defaults {
- user_friendly_names no
- }
- multipaths {
- multipath {
- wwid 3600508b4000892b90002a00000050000 #磁盤的WWID
- alias comsys-dm0 #映射后的別名,自己命名
- path_grouping_policy multibus #路徑組策略
- path_checker tur #決定路徑狀態(tài)的方法
- path_selector "round-robin 0" #選擇那一條路徑進(jìn)行下次IO操作
- }
- multipath {
- wwid 3600508b4000892b90002a00000090000
- alias comsys-dm1
- path_grouping_policy multibus
- path_checker tur
- path_selector "round-robin 0"
- }
- multipath {
- wwid 3600508b4000892b90002a00000140000
- alias comsys-backup
- path_grouping_policy multibus
- path_checker tur
- path_selector "round-robin 0"
- }
- }
- devices {
- device {
- vendor "HP" #廠商名稱,可通過multipath –v3獲取到
- product "HSV300" #產(chǎn)品型號
- path_grouping_policy multibus #默認(rèn)的路徑組策略
- getuid_callout "/sbin/scsi_id -g -u -s /block/%n" #獲得唯一設(shè)備號使用的默認(rèn)程序
- path_checker readsector0 #決定路徑狀態(tài)的方法
- path_selector "round-robin 0" #選擇那條路徑進(jìn)行下一個IO操作的方法
- #failback immediate #故障恢復(fù)的模式
- #no_path_retry queue #在disable queue之前系統(tǒng)嘗試使用失效路徑的次數(shù)的數(shù)值
- #rr_min_io 100 #在當(dāng)前的用戶組中,在切換到另外一條路徑之前的IO請求的數(shù)目
- }
- }
ps:其中 wwid,vendor,product, getuid_callout這些參數(shù)可以通過:multipath -v3命令來獲取。如果在/etc/multipath.conf中有設(shè)定各wwid別名,別名會覆蓋此設(shè)定。
3. 如何獲取WWID
(1) 使用 /etc/multipath/bindings
/etc/multipath/bindings內(nèi)的配置設(shè)定具體每個多路徑設(shè)備名,如果在/etc/multipath.conf中有設(shè)定各wwid 別名,別名會覆蓋此設(shè)定。
- # cat /etc/multipath/bindings
(2) 通過multipath -v3命令來獲取
- # multipath -v3
4. 啟動multipathd服務(wù)并設(shè)置其自動啟動
- #service multipathd restart
- #chkconfig --level 345 multipathd on
- #chkconfig --list | grep multipathd
5. 檢查multipath聚合后的設(shè)備名,以及設(shè)備對應(yīng)的鏈路情況
這個命令很重要
- # multipath -ll
6. 檢查配置是否成功
如果配置正確的話就會在/dev/mapper/目錄下多出mpath0、mpath1(自動分配的名稱)等之類設(shè)備,不過如果在配置的時候起了別名,會使用別名來代替自動分配的名稱
- # ll /dev/mapper/
用fdisk -l命令可以看到多路徑軟件創(chuàng)建的磁盤
- # fdisk -l
篇幅有限,關(guān)于Linux多路徑配置方面的內(nèi)容就介紹到這了。