使用ONTAP存储为 NVMe-oF 配置 RHEL 8.1
Red Hat Enterpirse Linux (RHEL) 主机支持具有非对称命名空间访问 (ANA) 的 NVMe over Fibre Channel (NVMe/FC) 和 NVMe over TCP (NVMe/TCP) 协议。 ANA 提供与 iSCSI 和 FCP 环境中的非对称逻辑单元访问 (ALUA) 等效的多路径功能。
了解如何为 RHEL 8.1 配置 NVMe over Fabrics (NVMe-oF) 主机。有关更多支持和功能信息,请参阅"NVME-oF 概述"。
RHEL 8.1 的 NVMe-oF 具有以下已知限制:
-
目前不支持使用 NVMe-oF 协议的 SAN 启动。
-
RHEL 8.1 中的 NVMe-oF 主机默认禁用内核 NVMe 多路径,因此您必须手动启用它。
-
本地人 `nvme-cli`套餐不包含 `nvme-fc auto-connect`脚本。您可以使用主机总线适配器 (HBA) 供应商提供的外部自动连接脚本。
-
默认情况下,循环负载平衡未启用。您可以通过编写 `udev`规则。
第1步:(可选)启用SAN启动
您可以配置主机以使用 SAN 启动来简化部署并提高可扩展性。使用"互操作性表工具"验证您的 Linux 操作系统、主机总线适配器 (HBA)、HBA 固件、HBA 启动 BIOS 和ONTAP版本是否支持 SAN 启动。
-
在服务器 BIOS 中为 SAN 启动命名空间映射到的端口启用 SAN 启动。
有关如何启用 HBA BIOS 的信息,请参见供应商专用文档。
-
重新启动主机并验证操作系统是否已启动并正在运行。
步骤 2:验证软件版本和 NVMe 配置
检查您的系统是否满足软件要求并验证 NVMe 包安装和主机配置。
-
在服务器上安装 RHEL 8.1。安装完成后,验证您是否正在运行所需的 RHEL 8.1 内核:
uname -r
RHEL 内核版本示例:
4.18.0-147.el8.x86_64
-
安装
nvme-cli-1.8.1-3.el8
软件包:rpm -qa|grep nvme-cli
以下示例显示了 nvme-cli 软件包版本:
nvme-cli-1.8.1-3.el8.x86_64
-
启用内核 NVMe 多路径。
grubby –args=nvme_core.multipath=Y –update-kernel /boot/vmlinuz-4.18.0-147.el8.x86_64
-
将以下字符串作为单独的UDEv规则添加到
/lib/udev/rules.d/71-nvme-iopolicy-netapp-ONTAP.rules
。这样可以为NVMe多路径启用循环负载平衡:Enable round-robin for NetApp ONTAP ACTION==”add”, SUBSYSTEM==”nvme-subsystem”, ATTR{model}==”NetApp ONTAP Controller”, ATTR{iopolicy}=”round-robin
-
在 RHEL 8.1 主机上,检查主机 NQN 字符串
/etc/nvme/hostnqn
:cat /etc/nvme/hostnqn
以下示例显示了 hostnqn 字符串:
nqn.2014-08.org.nvmexpress:uuid:75953f3b-77fe-4e03-bf3c-09d5a156fbcd
-
验证主机 NQN 字符串是否与ONTAP阵列上相应子系统的主机 NQN 字符串匹配:
vserver nvme subsystem host show -vserver vs_nvme_10
显示示例
*> vserver nvme subsystem host show -vserver vs_nvme_10 Vserver Subsystem Host NQN ------- --------- -------------------------------------- ----------- rhel_141_nvme_ss_10_0 nqn.2014-08.org.nvmexpress:uuid:75953f3b-77fe-4e03-bf3c-09d5a156fbcd
如果主机NQN字符串不匹配、请使用 vserver modify
命令更新相应ONTAP阵列子系统上的主机NQN字符串、以便与中的主机NQN字符串匹配/etc/nvme/hostnqn
在主机上。 -
重新启动主机。
步骤 3:为 Broadcom/Emulex 配置 NVMe/FC
您可以为 Broadcom/Emulex 配置 NVMe/FC。
-
验证您使用的适配器型号是否受支持:
-
显示模型名称:
cat /sys/class/scsi_host/host*/modelname
您应看到以下输出:
LPe32002-M2 LPe32002-M2
-
显示模型描述:
cat /sys/class/scsi_host/host*/modeldesc
您应该看到类似以下内容的输出:
Emulex LightPulse LPe32002-M2 2-Port 32Gb Fibre Channel Adapter Emulex LightPulse LPe32002-M2 2-Port 32Gb Fibre Channel Adapter
-
-
复制并安装Broadcom lpfc发件箱驱动程序和自动连接脚本:
tar -xvzf elx-lpfc-dd-rhel8-12.4.243.20-ds-1.tar.gz cd elx-lpfc-dd-rhel8-12.4.2453.20-ds-1 ./elx_lpfc_install-sh -i -n
与操作系统捆绑的本机驱动程序称为内置驱动程序。如果下载发件箱驱动程序(操作系统版本未附带的驱动程序)、则下载中会包含一个自动连接脚本、该脚本应在驱动程序安装过程中安装。 -
重新启动主机。
-
验证您是否正在使用推荐的 Broadcom 配置。
-
验证 lpfc 固件:
cat /sys/class/scsi_host/host*/fwrev
您应看到以下输出:
12.4.243.20, sil-4.2.c 12.4.243.20, sil-4.2.c
-
验证发件箱驱动程序:
cat /sys/module/lpfc/version
您应看到以下输出:
0:12.4.243.20
-
验证自动连接包版本:
rpm -qa | grep nvmefc
您应看到以下输出:
nvmefc-connect-12.6.61.0-1.noarch
-
-
验证的预期输出是否
lpfc_enable_fc4_type`设置为 `3
:cat /sys/module/lpfc/parameters/lpfc_enable_fc4_type
-
验证启动器端口是否已启动并正在运行,并且可以看到目标 LIF:
cat /sys/class/fc_host/host*/port_name
您应该看到类似以下内容的输出:
0x10000090fae0ec61 0x10000090fae0ec62
-
验证启动程序端口是否联机:
cat /sys/class/fc_host/host*/port_state
您应看到以下输出:
Online Online
-
验证NVMe/FC启动程序端口是否已启用且目标端口是否可见:
cat /sys/class/scsi_host/host*/nvme_info
显示示例
NVME Initiator Enabled XRI Dist lpfc0 Total 6144 NVME 2947 SCSI 2977 ELS 250 NVME LPORT lpfc0 WWPN x10000090fae0ec61 WWNN x20000090fae0ec61 DID x012000 ONLINE NVME RPORT WWPN x202d00a098c80f09 WWNN x202c00a098c80f09 DID x010201 TARGET DISCSRVC ONLINE NVME RPORT WWPN x203100a098c80f09 WWNN x202c00a098c80f09 DID x010601 TARGET DISCSRVC ONLINE NVME Statistics
步骤 4:(可选)为 NVMe/FC 启用 1MB I/O
ONTAP在识别控制器数据中报告最大数据传输大小 (MDTS) 为 8。这意味着最大 I/O 请求大小可达 1MB。要向 Broadcom NVMe/FC 主机发出 1MB 大小的 I/O 请求,您应该增加 `lpfc`的价值 `lpfc_sg_seg_cnt`参数从默认值 64 更改为 256。
|
这些步骤不适用于逻辑NVMe/FC主机。 |
-
将 `lpfc_sg_seg_cnt`参数设置为256:
cat /etc/modprobe.d/lpfc.conf
您应该会看到类似于以下示例的输出:
options lpfc lpfc_sg_seg_cnt=256
-
运行 `dracut -f`命令并重新启动主机。
-
验证的值是否 `lpfc_sg_seg_cnt`为256:
cat /sys/module/lpfc/parameters/lpfc_sg_seg_cnt
步骤 5:验证 NVMe-oF
验证内核NVMe多路径状态、ANA状态和ONTAP命名空间是否适用于NVMe-oF配置。
-
验证是否已启用内核NVMe多路径:
cat /sys/module/nvme_core/parameters/multipath
您应看到以下输出:
Y
-
验证相应ONTAP命名库的适当NVMe-oF设置(例如、型号设置为NetApp ONTAP控制器、负载平衡iopolicy设置为循环)是否正确反映在主机上:
-
显示子系统:
cat /sys/class/nvme-subsystem/nvme-subsys*/model
您应看到以下输出:
NetApp ONTAP Controller NetApp ONTAP Controller
-
显示策略:
cat /sys/class/nvme-subsystem/nvme-subsys*/iopolicy
您应看到以下输出:
round-robin round-robin
-
-
验证是否已在主机上创建并正确发现命名空间:
nvme list
显示示例
Node SN Model Namespace Usage Format FW Rev ---------------- -------------------- ----------------------- /dev/nvme0n1 80BADBKnB/JvAAAAAAAC NetApp ONTAP Controller 1 53.69 GB / 53.69 GB 4 KiB + 0 B FFFFFFFF
-
验证每个路径的控制器状态是否为活动状态且是否具有正确的ANA状态:
nvme list-subsys /dev/nvme0n1
显示示例
Nvme-subsysf0 – NQN=nqn.1992-08.com.netapp:sn.341541339b9511e8a9b500a098c80f09:subsystem.rhel_141_nvme_ss_10_0 \ +- nvme0 fc traddr=nn-0x202c00a098c80f09:pn-0x202d00a098c80f09 host_traddr=nn-0x20000090fae0ec61:pn-0x10000090fae0ec61 live optimized +- nvme1 fc traddr=nn-0x207300a098dfdd91:pn-0x207600a098dfdd91 host_traddr=nn-0x200000109b1c1204:pn-0x100000109b1c1204 live inaccessible +- nvme2 fc traddr=nn-0x207300a098dfdd91:pn-0x207500a098dfdd91 host_traddr=nn-0x200000109b1c1205:pn-0x100000109b1c1205 live optimized +- nvme3 fc traddr=nn-0x207300a098dfdd91:pn-0x207700a098dfdd91 host traddr=nn-0x200000109b1c1205:pn-0x100000109b1c1205 live inaccessible
-
验证NetApp插件是否为每个ONTAP 命名空间设备显示正确的值:
列nvme netapp ontapdevices -o column
显示示例
Device Vserver Namespace Path NSID UUID Size ------- -------- ------------------------- ------ ----- ----- /dev/nvme0n1 vs_nvme_10 /vol/rhel_141_vol_10_0/rhel_141_ns_10_0 1 55baf453-f629-4a18-9364-b6aee3f50dad 53.69GB
JSONnvme netapp ontapdevices -o json
显示示例
{ "ONTAPdevices" : [ { Device" : "/dev/nvme0n1", "Vserver" : "vs_nvme_10", "Namespace_Path" : "/vol/rhel_141_vol_10_0/rhel_141_ns_10_0", "NSID" : 1, "UUID" : "55baf453-f629-4a18-9364-b6aee3f50dad", "Size" : "53.69GB", "LBA_Data_Size" : 4096, "Namespace_Size" : 13107200 } ]
第6步:查看已知问题
没有已知问题。