
Linux配置多路径技术实现高可用性
在企业级互联网应用中,保证服务高可用性是非常重要的,因为一旦服务宕机,可能会带来巨大的损失。而多路径技术是一种常用的技术,它可以大大增加系统的可靠性,从而保证服务的高可用性。
Linux操作系统的多路径技术可以在整个存储路径中提供冗余备份机制。当磁盘故障或通道故障发生,多路径技术会自动转移到另一路径。这种技术实现起来实际上非常简单,只需要逐步完成以下步骤即可。
之一步:检查是否支持多路径技术
我们需要检查是否拥有使用多路径技术所需要的硬件和软件条件。我们需要确认是否拥有支持多路径技术的存储设备和驱动程序,同时需要确认 Linux版本是否支持多路径技术。我们可以通过以下命令来检查多路径技术的支持情况:
# multipath -h
如果系统无法执行此命令,则说明多路径技术不支持该系统。
第二步:安装多路径软件
如果系统支持多路径技术,则需要安装多路径软件。Linux系统中比较常见的多路径软件有 Multipath Tools and Device Mapper Multipathing 。这两种软件都是开源软件,可以通过Linux的软件包管理器进行安装。
第三步:配置多路径软件
安装完成多路径软件后,我们需要进行相关的配置操作。在多路径软件的配置文件中,需要配置可重定向I/O (I/O redirects) 、若干优先级等相关选项,从而定义系统如何处理多路径设备。
配置文件的位置和格式因软件而异,以Multipath Tools为例,其默认配置文件位于 /etc/multipath.conf 。在此文件中,我们可以设定多路径的优先级,Load Balance算法,以及设备规则(例如:名字,路径,WWN等)。存储设备的规则和优先级根据硬件和需求而异,具体的配置方法可以参考设备的用户手册。
第四步:检查多路径是否生效
我们需要确保多路径配置正确并生效。可以通过以下命令来测试:
# multipath -ll
此命令将显示系统交互的路径,以及所有设备的状态。如果多路径技术配置正确,则每个设备都将显示许多路径。我们也可以使用其他命令来检查多路径技术是否正常运行,例如使用命令来监控多路径设备的状态。
多路径技术是一种实用的技术,它可以通过冗余备份的方式提高系统的可靠性,从而保证服务的高可用性。Linux操作系统作为开源操作系统,支持多路径技术,且配置过程非常简单。虽然可能会遇到硬件和软件的限制,但多路径技术仍是一种值得推广和应用的技术。
相关问题拓展阅读:
- 如何使用Linux自带多路径DM
如何使用Linux自带多路径DM
一、多路径解释
多路径,顾名春桥轮思义就是有多种选择的路径。在SAN或IPSAN环境,主机和存储之间外加了光纤交换机,这就导致主机和存储之间交换速度和效率增强,一条路径肯定是不行的,也是不安全不稳定的。多路径就是要来解决从主机到磁盘之间最快,更高效的问题。主要实现如下几个功能
故障的切换和恢复
IO流量的负载均衡
磁盘的虚拟化
多路径之前一直是存储厂商负责解决,竟来被拆分出来单独卖钱了。消扒
构架基本是这样的:存储,多路径软件,光纤交换机,主机,主机系统。
二、LINUX下的multipath
1、查看是否自带安装?
# rpm -qa|grep device
device-mapper-1.02.39-1.el5
device-mapper-1.02.39-1.el5
device-mapper-multipath-0.4.7-34.el5
device-mapper-event-1.02.39-1.el5
#
2、安装
rpm -ivh device-mapper-1.02.39-1.el5.rpm #安装映射包
rpm -ivh device-mapper-multipath-0.4.7-34.el5.rpm #安装多路径包
外加加入开机启动
chkconfig –level 2345 multipathd on#设置成开机自启动multipathd
lod |grep dm_multipath#来检查安装是扒信否正常
3、配置
# on the default devices.
blacklist {
devnode “^(ram|raw|loop|fd|md|dm-|sr|sr|scd|st)*”
devnode “^hd”
}
devices {
device {
vendor “HP”
path_grouping_policy multibus
features “1 queue_if_no_path”
path_checker readsector()
failback immediate
}
}
完整的配置如下:
blacklist {
devnode “^sda”
}
defaults {
user_friendly_names no
}
multipaths {
multipath {
wwida67854c6270b4359c66c272e2f356321
alias iscsi-dm0
path_grouping_policy multibus
path_checkertur
path_selector”round-robin 0″
}
multipath {
wwiddcca2eda91d70b81edbcfce2357f99ee
alias iscsi-dm1
path_grouping_policy multibus
path_checkertur
path_selector”round-robin 0″
}
multipath {
wwidf763489c3957ed96
alias iscsi-dm2
path_grouping_policy multibus
path_checkertur
path_selector”round-robin 0″
}
multipath {
wwidca813020a195422ba3663e1f03cc3
alias iscsi-dm3
path_grouping_policy multibus
path_checkertur
path_selector”round-robin 0″
}
}
devices {
device {
vendor “iSCSI-Enterprise”
product “Virtual disk”
path_grouping_policy multibus
getuid_callout”/in/scsi_id -g -u -s /block/%n”
path_checkerreadsector0
path_selector”round-robin 0″
}
}
4、命令
# multipath -h
multipath-tools v0.4.7 (03/12, 2023)
Usage: multipath
v levelverbosity level
no output
print created devmap names only
default verbosity
print debug information
hprint this usage text
b filebindings file location
ddry run, do not create or update devmaps
lshow multipath topology (sysfs and DM info)
llshow multipath topology (maximum info)
fflush a multipath device map
Fflush all multipath device maps
rforce devmap reload
p policyforce all maps to specified policy :
failover path per priority group
multibusall paths in 1 priority group
group_by_serialpriority group per serial
group_by_priopriority group per priority lvl
group_by_node_name 1 priority group per target node
devicelimit scope to the device’s multipath
(udev-style $DEVNAME reference, eg /dev/sdb
or major:minor or a device map name)
#
5、启动关闭
# /etc/init.d/multipathd start #开启mulitipath服务
service multipath start
service multipath restart
service multipath shutdown
6、如何获取wwid
1、
# cat /var/lib/multipath/bindings
# Multipath bindings, Version : 1.0
# NOTE: this file is automatically maintained by the multipath program.
# You should not need to edit this file in normal circumstances.
#
# Format:
# alias wwid
#
mpathd50ec912de11
mpathd50ec912de11
mpathd50ec912de11
mpathd50ec912de11
mpathd50e003a744871c912de11
2、
# multipath -v3 |grep 3600
sdb: uid =d50e003a744871c912de11 (callout)
sdc: uid =d50e003a744871c912de11 (callout)
sdd: uid =d50e003a744871c912de11 (callout)
sde: uid =d50e003a744871c912de11 (callout)
d50e003a744871c912de11 1:0:0:0 sdb 8: DGC,RAI
d50e003a744871c912de11 1:0:1:0 sdc 8: DGC,RAI
d50e003a744871c912de11 2:0:0:0 sdd 8: DGC,RAI
d50e003a744871c912de11 2:0:1:0 sde 8: DGC,RAI
Found matching wwid in bindings file.
比较详细的文字:
RHEL官网资料:
关于linux配置multipath的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
香港服务器首选树叶云,2H2G首月10元开通。
树叶云(www.IDC.Net)提供简单好用,价格厚道的香港/美国云服务器和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。
文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/163015.html<