一文掌握Linux Multipath多路徑配置,值得收藏

2019-07-29     波波說運維

概述

在Linux平台一部分存儲產品使用作業系統自帶的多路徑軟體,包括最常見的HP和IBM的部分存儲產品,在Linux自帶的多路徑軟體叫做multipath。

那麼問題就來了,到底什麼是多路徑?

普通的電腦主機都是一個硬碟掛接到一個總線上,這裡是一對一的關係。而到了有光纖組成的SAN環境,或者由iSCSI組成的IPSAN環境,由於主機和存儲通過了光纖交換機或者多塊網卡及IP來連接,這樣的話,就構成了多對多的關係。也就是說,主機到存儲可以有多條路徑可以選擇。主機到存儲之間的IO由多條路徑可以選擇。每個主機到所對應的存儲可以經過幾條不同的路徑,如果是同時使用的話,I/O流量如何分配?其中一條路徑壞掉了,如何處理?從在作業系統的角度來看,每條路徑,作業系統會認為是一個實際存在的物理盤,但實際上只是通向同一個物理盤的不同路徑而已,這樣是在使用的時候,就給用戶帶來了困惑。多路徑軟體就是為了解決上面的問題。


01

multipath介紹

在redhat中,安裝作業系統的時候multipath已經默認被安裝,查看安裝情況:

# rpm -qa | grep device-mapper

說明:

1)device-mapper-multipath:即multipath-tools。主要提供multipathd和multipath等工具和 multipath.conf等配置文件。創建的多路徑設備會在/dev/mapper中。

2) device-mapper:主要包括兩大部分:內核部分和用戶部分。

內核部分主要包括device mapper核心(dm.ko)和一些target driver(md-multipath.ko)。核心完成設備的映射,而target根據映射關係和自身特點具體處理從mappered device 下來的i/o。

用戶空間部分主要包括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設備的序號。通過序號,便可以判斷多個路徑對應了同一設備。這個是多路徑實現的關鍵。multipath程序在創建multipath設備時,會調用scsi_id,從其標準輸出中獲得該設備的scsi id。在改寫時,需要修改scsi_id程序的返回值為0。因為在multipath程序中,會檢查該值來確定scsi id是否已經成功得到。


02

multipath詳細配置

因為在安裝作業系統的時候,multipath的軟體包已經那裝好了,所以這裡就不在需要安裝,如果沒有安裝的話,需要手動的進行安裝。

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 #決定路徑狀態的方法
path_selector "round-robin 0" #選擇那一條路徑進行下次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" #產品型號
path_grouping_policy multibus #默認的路徑組策略
getuid_callout "/sbin/scsi_id -g -u -s /block/%n" #獲得唯一設備號使用的默認程序
path_checker readsector0 #決定路徑狀態的方法
path_selector "round-robin 0" #選擇那條路徑進行下一個IO操作的方法
#failback immediate #故障恢復的模式
#no_path_retry queue #在disable queue之前系統嘗試使用失效路徑的次數的數值
#rr_min_io 100 #在當前的用戶組中,在切換到另外一條路徑之前的IO請求的數目
}
}

ps:其中 wwid,vendor,product, getuid_callout這些參數可以通過:multipath -v3命令來獲取。如果在/etc/multipath.conf中有設定各wwid別名,別名會覆蓋此設定。


03

如何獲取WWID

1、使用 /etc/multipath/bindings

/etc/multipath/bindings內的配置設定具體每個多路徑設備名,如果在/etc/multipath.conf中有設定各wwid 別名,別名會覆蓋此設定。

# cat /etc/multipath/bindings

2、通過multipath -v3命令來獲取

# multipath -v3


04

啟動multipathd服務並設置其自動啟動

#service multipathd restart
#chkconfig --level 345 multipathd on
#chkconfig --list | grep multipathd


05

檢查multipath聚合後的設備名,以及設備對應的鏈路情況

這個命令很重要

# multipath -ll


06

檢查配置是否成功

如果配置正確的話就會在/dev/mapper/目錄下多出mpath0、mpath1(自動分配的名稱)等之類設備,不過如果在配置的時候起了別名,會使用別名來代替自動分配的名稱

# ll /dev/mapper/

用fdisk -l命令可以看到多路徑軟體創建的磁碟

# fdisk -l


篇幅有限,關於Linux多路徑配置方面的內容就介紹到這了,下周會對ASM擴容,剛好也會用多路徑的方式,到時再單獨做一個擴容的整體方案吧,感興趣的朋友可以關注下!

文章來源: https://twgreatdaily.com/zh-hk/BeB4QWwB8g2yegNDL-2k.html