NVMe-of Host-Konfiguration für Oracle Linux 8.9 mit ONTAP
NVMe over Fabrics (NVMe-of), einschließlich NVMe over Fibre Channel (NVMe/FC) und andere Übertragungen werden mit Oracle Linux 8.9 mit Asymmetric Namespace Access (ANA) unterstützt. In NVMe-of Umgebungen entspricht ANA ALUA Multipathing in iSCSI- und FC-Umgebungen und wird mit in-Kernel NVMe Multipath implementiert.
Die folgende Unterstützung ist für die NVMe-of Host-Konfiguration von Oracle Linux 8.9 mit ONTAP verfügbar:
-
Unterstützung für NVMe over TCP (NVMe/TCP) neben NVMe/FC Über das NetApp-Plug-in im nativen
nvme-cli
Paket werden die ONTAP-Details sowohl für NVMe/FC- als auch für NVMe/TCP-Namespaces angezeigt. -
Sowohl NVMe- als auch SCSI-Datenverkehr können auf demselben vorhandenen Host ausgeführt werden. Daher können Sie dm-Multipath für SCSI-mpath-Geräte für SCSI-LUNs konfigurieren, während Sie möglicherweise NVMe Multipath verwenden, um NVMe-of Namespace-Geräte auf dem Host zu konfigurieren.
-
Es gibt keine Unterstützung für NVMe-of für Sanlun. Daher wird für NVMe-of auf einem Oracle Linux 8.9 Host keine Host Utility-Unterstützung angeboten. Sie können sich auf das im nativen
nvme-cli
Paket enthaltene NetApp Plug-in für alle NVMe-of-Übertragungen verlassen.
Weitere Informationen zu unterstützten Konfigurationen finden Sie im "NetApp Interoperabilitäts-Matrix-Tool".
Funktionen
Oracle Linux 8.9 hat standardmäßig NVMe Multipath im Kernel für NVMe-Namespaces aktiviert. Daher sind keine expliziten Einstellungen erforderlich.
Bekannte Einschränkungen
Das Booten von SAN über das NVMe-of-Protokoll wird derzeit nicht unterstützt.
Validieren der Softwareversionen
Validieren Sie die unterstützten Mindestversionen von Oracle Linux 8.9.
-
Installieren Sie Oracle Linux 8.9 GA auf dem Server. Überprüfen Sie nach Abschluss der Installation, ob Sie den angegebenen Oracle Linux 8.9 GA-Kernel ausführen:
# uname -r
Beispielausgabe:
5.15.0-200.131.27.el8uek.x86_64
-
Installieren Sie den
nvme-cli
Paket:# rpm -qa|grep nvme-cli
Beispielausgabe:
nvme-cli-1.16-9.el8.x86_64
-
Überprüfen Sie auf dem Oracle Linux 8.9-Host den
hostnqn
String unter/etc/nvme/hostnqn
:# cat /etc/nvme/hostnqn
Beispielausgabe:
nqn.2014-08.org.nvmexpress:uuid:edd38060-00f7-47aa-a9dc-4d8ae0cd969a
-
Überprüfen Sie das
hostnqn
Die Zeichenfolge entspricht derhostnqn
String für das entsprechende Subsystem auf dem ONTAP-Array:::> vserver nvme subsystem host show -vserver vs_nvme177
Beispielausgabe:
Vserver Subsystem Host NQN ----------- --------------- ---------------------------------------------------------- vs_nvme177 nvme_ss_ol_1 nqn.2014-08.org.nvmexpress:uuid:edd38060-00f7-47aa-a9dc-4d8ae0cd969a
Wenn der hostnqn
Zeichenfolgen stimmen nicht überein. Sie können das verwendenvserver modify
Befehl zum Aktualisieren deshostnqn
Zeichenfolge auf dem entsprechenden ONTAP-Array-Subsystem, die dem entsprichthostnqn
Zeichenfolge von/etc/nvme/hostnqn
Auf dem Host. -
Starten Sie den Host neu.
Wenn Sie beabsichtigen, gleichzeitig NVMe- und SCSI-Datenverkehr auf demselben Host auszuführen, empfiehlt NetApp die Verwendung des NVMe Multipath im Kernel für ONTAP-Namespaces und
dm-multipath
Für ONTAP LUNs. Das bedeutet, dass die ONTAP-Namespaces von ausgeschlossen werden solltendm-multipath
Um zu verhinderndm-multipath
Diese Namespace-Geräte beanspruchen. Sie können die hinzufügenenable_foreign
Einstellung auf/etc/multipath.conf
Datei:# cat /etc/multipath.conf defaults { enable_foreign NONE }
Starten Sie den Multipathd-Daemon neu, indem Sie ein ausführen
systemctl restart multipathd
Befehl. Dadurch kann die neue Einstellung wirksam werden.
Konfiguration von NVMe/FC
Konfigurieren Sie NVMe/FC für Broadcom/Emulex-Adapter oder Marvell/Qlogic-Adapter.
-
Stellen Sie sicher, dass Sie das unterstützte Adaptermodell verwenden:
# cat /sys/class/scsi_host/host*/modelname
Beispielausgabe:
LPe32002-M2 LPe32002-M2
# cat /sys/class/scsi_host/host*/modeldesc
Beispielausgabe:
Emulex LightPulse LPe32002-M2 2-Port 32Gb Fibre Channel Adapter Emulex LightPulse LPe32002-M2 2-Port 32Gb Fibre Channel Adapter
-
Vergewissern Sie sich, dass Sie das empfohlene Broadcom verwenden
lpfc
Firmware und Inbox-Treiber:# cat /sys/class/scsi_host/host*/fwrev 14.2.539.16, sli-4:2:c 14.2.539.16, sli-4:2:c
# cat /sys/module/lpfc/version 0:14.2.0.5
Die aktuelle Liste der unterstützten Adaptertreiber- und Firmware-Versionen finden Sie unter "NetApp Interoperabilitäts-Matrix-Tool".
-
Verifizieren Sie das
lpfc_enable_fc4_type
Ist auf festgelegt3
:# cat /sys/module/lpfc/parameters/lpfc_enable_fc4_type 3
-
Vergewissern Sie sich, dass die Initiator-Ports ausgeführt werden und dass die Ziel-LIFs angezeigt werden:
# cat /sys/class/fc_host/host*/port_name 0x100000109b3c081f 0x100000109b3c0820
# cat /sys/class/fc_host/host*/port_state Online Online
Beispiel anzeigen
# cat /sys/class/scsi_host/host*/nvme_info NVME Initiator Enabled XRI Dist lpfc0 Total 6144 IO 5894 ELS 250 NVME LPORT lpfc0 WWPN x100000109b1c1204 WWNN x200000109b1c1204 DID x011d00 ONLINE NVME RPORT WWPN x203800a098dfdd91 WWNN x203700a098dfdd91 DID x010c07 TARGET DISCSRVC ONLINE NVME RPORT WWPN x203900a098dfdd91 WWNN x203700a098dfdd91 DID x011507 TARGET DISCSRVC ONLINE NVME Statistics LS: Xmt 0000000f78 Cmpl 0000000f78 Abort 00000000 LS XMIT: Err 00000000 CMPL: xb 00000000 Err 00000000 Total FCP Cmpl 000000002fe29bba Issue 000000002fe29bc4 OutIO 000000000000000a abort 00001bc7 noxri 00000000 nondlp 00000000 qdepth 00000000 wqerr 00000000 err 00000000 FCP CMPL: xb 00001e15 Err 0000d906 NVME Initiator Enabled XRI Dist lpfc1 Total 6144 IO 5894 ELS 250 NVME LPORT lpfc1 WWPN x100000109b1c1205 WWNN x200000109b1c1205 DID x011900 ONLINE NVME RPORT WWPN x203d00a098dfdd91 WWNN x203700a098dfdd91 DID x010007 TARGET DISCSRVC ONLINE NVME RPORT WWPN x203a00a098dfdd91 WWNN x203700a098dfdd91 DID x012a07 TARGET DISCSRVC ONLINE NVME Statistics LS: Xmt 0000000fa8 Cmpl 0000000fa8 Abort 00000000 LS XMIT: Err 00000000 CMPL: xb 00000000 Err 00000000 Total FCP Cmpl 000000002e14f170 Issue 000000002e14f17a OutIO 000000000000000a abort 000016bb noxri 00000000 nondlp 00000000 qdepth 00000000 wqerr 00000000 err 00000000 FCP CMPL: xb 00001f50 Err 0000d9f8
-
Der native Inbox qla2xxx Treiber, der im Oracle Linux 8.9 GA Kernel enthalten ist, verfügt über die neuesten Fixes, die für die ONTAP Unterstützung unerlässlich sind. Vergewissern Sie sich, dass der unterstützte Adaptertreiber und die unterstützten Firmware-Versionen ausgeführt werden:
# cat /sys/class/fc_host/host*/symbolic_name QLE2742 FW:v9.12.00 DVR:v10.02.08.100-k QLE2742 FW:v9.12.00 DVR:v10.02.08.100-k
-
Verifizieren Sie das
ql2xnvmeenable
Ist festgelegt. Dadurch kann der Marvell Adapter als NVMe/FC-Initiator verwendet werden:# cat /sys/module/qla2xxx/parameters/ql2xnvmeenable 1
1 MB I/O-Größe aktivieren (optional)
ONTAP meldet eine MDTS (MAX Data-Übertragungsgröße) von 8 in den Identifizieren von Controller-Daten. Das bedeutet, dass die maximale E/A-Anforderungsgröße bis zu 1 MB betragen kann. Um I/O-Anforderungen von Größe 1 MB für einen Broadcom-NVMe/FC-Host auszustellen, müssen Sie den lpfc
Wert des lpfc_sg_seg_cnt
Parameters ab dem Standardwert 64 auf 256 erhöhen.
-
Setzen Sie den
lpfc_sg_seg_cnt
Parameter auf 256:# cat /etc/modprobe.d/lpfc.conf options lpfc lpfc_sg_seg_cnt=256
-
Führen Sie einen
dracut -f
Befehl aus, und starten Sie den Host neu: -
Stellen Sie sicher, dass
lpfc_sg_seg_cnt
256:# cat /sys/module/lpfc/parameters/lpfc_sg_seg_cnt 256
Dies gilt nicht für Qlogic NVMe/FC-Hosts. |
Konfiguration von NVMe/TCP
NVMe/TCP verfügt nicht über eine automatische Verbindungsfunktion. Wenn also ein Pfad ausfällt und nicht innerhalb der standardmäßigen Time-Out-Frist von 10 Minuten wieder hergestellt wird, kann NVMe/TCP die Verbindung nicht automatisch wiederherstellen. Um dieses Szenario zu vermeiden, sollten Sie den Wiederholungszeitraum für Speicher-Failover-Ereignisse mit dem folgenden Verfahren festlegen.
-
Vergewissern Sie sich, dass der Initiator-Port die Daten der Erkennungsprotokollseite über die unterstützten NVMe/TCP-LIFs abrufen kann:
nvme discover -t tcp -w host-traddr -a traddr
Beispielausgabe anzeigen
# nvme discover -t tcp -w 192.168.6.13 -a 192.168.6.15 Discovery Log Number of Records 6, Generation counter 8 =====Discovery Log Entry 0====== trtype: tcp adrfam: ipv4 subtype: unrecognized treq: not specified portid: 0 trsvcid: 8009 subnqn: nqn.1992-08.com.netapp:sn.1c6ac66338e711eda41dd039ea3ad566:discovery traddr: 192.168.6.17 sectype: none =====Discovery Log Entry 1====== trtype: tcp adrfam: ipv4 subtype: unrecognized treq: not specified portid: 1 trsvcid: 8009 subnqn: nqn.1992-08.com.netapp:sn.1c6ac66338e711eda41dd039ea3ad566:discovery traddr: 192.168.5.17 sectype: none =====Discovery Log Entry 2====== trtype: tcp adrfam: ipv4 subtype: unrecognized treq: not specified portid: 2 trsvcid: 8009 subnqn: nqn.1992-08.com.netapp:sn.1c6ac66338e711eda41dd039ea3ad566:discovery traddr: 192.168.6.15 sectype: none =====Discovery Log Entry 3====== trtype: tcp adrfam: ipv4 subtype: nvme subsystem treq: not specified portid: 0 trsvcid: 4420 subnqn: nqn.1992-08.com.netapp:sn.1c6ac66338e711eda41dd039ea3ad566:subsystem.host_95 traddr: 192.168.6.17 sectype: none ..........
-
Vergewissern Sie sich, dass die anderen LIF-Kombinationen des NVMe/TCP-Initiators die Daten der Erkennungsprotokollseite erfolgreich abrufen können:
nvme discover -t tcp -w host-traddr -a traddr
Beispielausgabe:
# nvme discover -t tcp -w 192.168.6.1 -a 192.168.6.10 # nvme discover -t tcp -w 192.168.6.1 -a 192.168.6.11 # nvme discover -t tcp -w 192.168.5.1 -a 192.168.5.10 # nvme discover -t tcp -w 192.168.5.1 -a 192.168.5.11
-
Führen Sie die aus
nvme connect-all
Befehl über alle unterstützten NVMe/TCP Initiator-Ziel-LIFs der Nodes hinweg:nvme connect-all -t tcp -w host-traddr -a traddr -l <ctrl_loss_timeout_in_seconds>
Beispielausgabe:
# nvme connect-all -t tcp -w 192.168.5.1 -a 192.168.5.10 -l -1 # nvme connect-all -t tcp -w 192.168.5.1 -a 192.168.5.11 -l -1 # nvme connect-all -t tcp -w 192.168.6.1 -a 192.168.6.10 -l -1 # nvme connect-all -t tcp -w 192.168.6.1 -a 192.168.6.11 -l -1
NetApp empfiehlt die Einstellung ctrl-loss-tmo
Option auf-1
Damit der NVMe/TCP-Initiator versucht, sich im Falle eines Pfadverlusts auf unbestimmte Zeit erneut zu verbinden.
NVMe-of validieren
Zur Validierung von NVMe-of gehen Sie wie folgt vor.
-
Vergewissern Sie sich, dass in-Kernel NVMe Multipath aktiviert ist:
# cat /sys/module/nvme_core/parameters/multipath Y
-
Überprüfen Sie, ob die entsprechenden NVMe-of-Einstellungen (z. B.
model
Auf einstellenNetApp ONTAP Controller
Und Lastverteilungiopolicy
Auf einstellenround-robin
) Für die jeweiligen ONTAP-Namespaces werden auf dem Host korrekt wiedergegeben:# 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
-
Überprüfen Sie, ob die Namespaces auf dem Host erstellt und richtig erkannt wurden:
# nvme list
Beispielausgabe:
Node SN Model --------------------------------------------------------- /dev/nvme0n1 814vWBNRwf9HAAAAAAAB NetApp ONTAP Controller /dev/nvme0n2 814vWBNRwf9HAAAAAAAB NetApp ONTAP Controller /dev/nvme0n3 814vWBNRwf9HAAAAAAAB NetApp ONTAP Controller Namespace Usage Format FW Rev ----------------------------------------------------------- 1 85.90 GB / 85.90 GB 4 KiB + 0 B FFFFFFFF 2 85.90 GB / 85.90 GB 24 KiB + 0 B FFFFFFFF 3 85.90 GB / 85.90 GB 4 KiB + 0 B FFFFFFFF
-
Überprüfen Sie, ob der Controller-Status jedes Pfads aktiv ist und den korrekten ANA-Status aufweist:
NVMe/FC# nvme list-subsys /dev/nvme0n1
Beispielausgabe:
nvme-subsys0 - NQN=nqn.1992-08.com.netapp:sn.5f5f2c4aa73b11e9967e00a098df41bd:subsystem.nvme_ss_ol_1 \ +- nvme0 fc traddr=nn-0x203700a098dfdd91:pn-0x203800a098dfdd91 host_traddr=nn-0x200000109b1c1204:pn-0x100000109b1c1204 live non-optimized +- nvme1 fc traddr=nn-0x203700a098dfdd91:pn-0x203900a098dfdd91 host_traddr=nn-0x200000109b1c1204:pn-0x100000109b1c1204 live non-optimized +- nvme2 fc traddr=nn-0x203700a098dfdd91:pn-0x203a00a098dfdd91 host_traddr=nn-0x200000109b1c1205:pn-0x100000109b1c1205 live optimized +- nvme3 fc traddr=nn-0x203700a098dfdd91:pn-0x203d00a098dfdd91 host_traddr=nn-0x200000109b1c1205:pn-0x100000109b1c1205 live optimized
NVMe/TCPnvme list-subsys /dev/nvme1n22
Beispielausgabe
nvme-subsys0 - NQN=nqn.1992- 08.com.netapp: sn.44986b09cadc11eeb309d039eab31e9d:subsystem.ol_nvme \ +- nvme1 tcp traddr=192.168.5.11 trsvcid=4420 host_traddr=192.168.5.1 src_addr=192.168.5.1 live non-optimized +- nvme2 tcp traddr=192.168.5.10 trsvcid=4420 host_traddr=192.168.5.1 src_addr=192.168.5.1 live optimized +- nvme3 tcp traddr=192.168.6.11 trsvcid=4420 host_traddr=192.168.6.1 src_addr=192.168.6.1 live non-optimized +- nvme4 tcp traddr=192.168.6.10 trsvcid=4420 host_traddr=192.168.6.1 src_addr=192.168.6.1 live optimized
-
Vergewissern Sie sich, dass das NetApp Plug-in für jedes ONTAP Namespace-Gerät die richtigen Werte anzeigt:
Spalte# nvme netapp ontapdevices -o column
Beispielausgabe:
Device Vserver Namespace Path ------------ ---------- ----------------- /dev/nvme0n1 vs_nvme177 /vol/vol1/ns1 /dev/nvme0n2 vs_nvme177 /vol/vol2/ns2 /dev/nvme0n3 vs_nvme177 /vol/vol3/ns3 NSID UUID Size -------- -------------------------------------- ----------- 1 72b887b1-5fb6-47b8-be0b-33326e2542e2 85.90GB 2 04bf9f6e-9031-40ea-99c7-a1a61b2d7d08 85.90GB 3 264823b1-8e03-4155-80dd-e904237014a4 85.90GB
JSON# nvme netapp ontapdevices -o json
Beispielausgabe
{ "ONTAPdevices" : [ { "Device" : "/dev/nvme0n1", "Vserver" : "vs_nvme177", "Namespace_Path" : "/vol/vol1/ns1", "NSID" : 1, "UUID" : "72b887b1-5fb6-47b8-be0b-33326e2542e2", "Size" : "85.90GB", "LBA_Data_Size" : 4096, "Namespace_Size" : 5242880 }, { "Device" : "/dev/nvme0n2", "Vserver" : "vs_nvme177", "Namespace_Path" : "/vol/vol2/ns2", "NSID" : 2, "UUID" : "04bf9f6e-9031-40ea-99c7-a1a61b2d7d08", "Size" : "85.90GB", "LBA_Data_Size" : 4096, "Namespace_Size" : 20971520 }, { "Device" : "/dev/nvme0n3", "Vserver" : "vs_nvme177", "Namespace_Path" : "/vol/vol3/ns3", "NSID" : 3, "UUID" : "264823b1-8e03-4155-80dd-e904237014a4", "Size" : "85.90GB", "LBA_Data_Size" : 4096, "Namespace_Size" : 20971520 }, ] }
Bekannte Probleme
Die NVMe-of Hostkonfiguration für Oracle Linux 8.9 mit ONTAP-Release weist folgende bekannte Probleme auf:
NetApp Bug ID |
Titel |
Beschreibung |
Oracle Linux 8.9 NVMe-of Hosts erstellen doppelte PDCs |
Auf Oracle Linux 8.9 NVMe-of-Hosts werden Persistent Discovery Controller (PDCs) erstellt, indem die |