遠端直接記憶體存取(簡稱 RDMA)可以讓網路裝置在另外一個系統上的應用程式記憶體中直接傳輸資料、增加輸出量、並且在特定網路環境中減少延遲性。
最主要的不同點是 iWARP 能透過 TCP 執行 RDMA,而 RoCEv2 則是使用 UDP 來執行。
在具有 RDMA 功能的裝置上,下列作業系統可支援 RDMA:
為了避免遺失封包造成的效能降低,可以在所有的網路介面和交換器上啟用連結層的流量控制或優先順序流量控制。
注意:
|
對於在 Linux 或 FreeBSD 上支援 RDMA 的 Intel 乙太網路裝置,請使用下表所列的驅動程式。
裝置 | Linux | FreeBSD | 支援的通訊協定 | ||
---|---|---|---|---|---|
基礎驅動程式 | RDMA 驅動程式 | 基礎驅動程式 | RDMA 驅動程式 | ||
Intel® 乙太網路 800 系列 | ice | irdma | ice | irdma | RoCEv2、iWARP |
Intel® 乙太網路 X722 系列 | i40e | irdma | ixl | iw_ixl | iWARP |
概括地說,在 Linux 或 FreeBSD 上安裝和配置 RDMA 包括以下步驟。完整詳細資訊請參閱適當的 RDMA 驅動程式 tarball 中的讀我檔案。
搭載 Intel 乙太網路 800 系列的裝置,於支援之 Windows 或 Linux 主機上,支援 Linux VF 內的 RDMA。如需如何在 Linux VF 載入及設定 RDMA 的詳細資訊,請參考 Linux RDMA 驅動程式 tarball 內的讀我檔案。
使用 Network Direct (ND),使用者模式應用程式就可以使用 RDMA 功能。
注意:使用者模式應用程式可能有預先安裝的要求條件,例如 Microsoft HPC Pack 或 Intel MPI Library,請參考您的應用程式說明文件來了解詳細資料。 |
「Intel® 乙太網路使用者模式 RDMA 供應商」受到 Microsoft Windows Server 2012 R2 或更新版本的支援。
請遵照下面的步驟來安裝使用者模式的 Network Direct (ND) 功能。
注意:如果「Windows 防火牆」已停用或者您使用的是第三方的防火牆,就需要以手動方式來新增這條規則。 |
RDMA Network Direct Kernel (NDK) 功能已經包括在 Intel 基礎網路驅動程式,而且不需安裝其它功能。
如果您要讓所有的子網路都能使用 NDK 的 RDMA 功能,就需要在基礎驅動程式安裝期間,於 RDMA 組態選項螢幕中,選取「在整個 IP 子網路中啟用 RDMA 路由功能」。
為了避免遺失封包造成的效能降低,可以在所有的網路介面和交換器上啟用優先順序流量控制 (PFC) 或連結層的流量控制。
注意:在執行 Microsoft Windows Server 作業系統的系統上,啟用 *QoS/優先順序流量控制將會停用連結層的流量控制。 |
請使用下列 PowerShell* 指令,以啟用 Microsoft Windows Server 上的 PFC:
Install-WindowsFeature -Name Data-Center-Bridging -IncludeManagementTools
New-NetQoSPolicy "SMB" -NetDirectPortMatchCondition 445 -PriorityValue8021Action 3
Enable-NetQosFlowControl -Priority 3
Disable-NetQosFlowControl -Priority 0,1,2,4,5,6,7
New-NetQosTrafficClass -Name "SMB" -Priority 3 -BandwidthPercentage 60 -Algorithm ETS
Set-NetQosDcbxSetting -Willing $FALSE
Enable-NetAdapterQos -Name "Slot1 4 2 Port 1"
您可以使用下面的 Microsoft PowerShell 指令來確定網路介面上的 RDMA 是否已啟用:
Get-NetAdapterRDMA
請使用以下的 PowerShell 指令來檢查網路介面是否具備 RDMA 功能,並且已啟用多通道:
Get-SmbClientNetworkInterface
請使用以下的 PowerShell 指令來檢查作業系統中的 Network Direct 是否已啟用:
Get-NetOffloadGlobalSetting | 選取 NetworkDirect
請使用 netstat 來檢查每個具備 RDMA 功能的網路介面在第 445 連接埠有一個接聽程式(支援 RDMA 的 Windows 用戶端作業系統可能不會公布接聽程式)。例如:
netstat.exe -xan | ? {$_ -match "445"}
若要在連接至 VMSwitch 的虛擬介面卡上啟用 RDMA 功能,您必須:
在特定情況下,您可以預設停用這些設定。您可以在 Intel PROSet ACU 的「介面卡設定」面板內,其介面卡屬性對話框「進階」分頁中,或以下列 PowerShell 指令,手動設定這些選項:
Set-NetAdapterAdvancedProperty -Name <nic_name> -RegistryKeyword *SRIOV -RegistryValue 1
Set-NetAdapterAdvancedProperty -Name <nic_name> -RegistryKeyword *VMQ -RegistryValue 1
Set-NetAdapterAdvancedProperty -Name <nic_name> -RegistryKeyword RdmaMaxVfsEnabled -RegistryValue <1-32>
「NDK 模式 3」可讓核心模式 Windows 元件使用 Hyper-V 訪客分割區內的 RDMA 功能。若要在 Intel 乙太網路裝置上啟用 NDK 模式 3,請執行以下的步驟:
New-VMSwitch -Name <switch_name> -NetAdapterName <device_name>
-EnableIov $true
Set-NetAdapterAdvancedProperty -Name <device_name> -RegistryKeyword RdmaMaxVfsEnabled -RegistryValue <Value: 0 - 32>
Get-NetAdapterRdma | Disable-NetAdapter
Get-NetAdapterRdma | Enable-NetAdapter
Add-VMNetworkAdapter -VMName <vm_name> -VMNetworkAdapterName <device_name> -SwitchName <switch_name>
Set-VMNetworkAdapterRdma -VMName <vm_name> -VMNetworkAdapterName <device_name> -RdmaWeight 100
Set-VMNetworkAdapter -VMName <vm_name> -VMNetworkAdapterName <device_name> -IovWeight 100
Set-NetAdapterAdvancedProperty -Name <device_name> -RegistryKeyword RdmaVfEnabled -RegistryValue 1
Get-NetAdapterRdma | Enable-NetAdapterRdma
NDK 可讓 Windows 元件(例如「SMB 直接傳輸」儲存)使用 RDMA 功能。
這個部分介紹了適用於測試 Intel 乙太網路功能性的 RDMA 和 Microsoft Windows 作業系統效能的建議方法。
請注意,因為「SMB 直接傳輸」是一種儲存負載,其效能指標可能會受到儲存裝置的限制,而不是受限於被測試的網路介面。Intel 建議使用最快的儲存,這樣可測試出受測之網路裝置的真實功能。
測試說明:
New-SmbShare -Name <SMBsharename> -Path <SMBsharefilepath> -FullAccess <domainname>\Administrator,Everyone
New-SmbShare -Name RAMDISKShare -Path R:\RAMDISK -FullAccess group\Administrator,Everyone
.\diskspd.exe -b4K -d60 -h -L -o16 -t16 -r -w0 -c10G \\<SMBserverTestIP>\<SMBsharename>\test.dat
版權所有 (C) 2019 - 2022,Intel 公司。保留一切權利。
Intel 公司不對本文件中的錯誤或疏失負責。Intel 亦不對此處包含的資訊做任何更新承諾。
Intel 是 Intel 公司或其子公司在美國及/或其它國家的商標。
*其他名稱與品牌可能業經宣告為他人之財產。
本軟體係根據授權提供,且只得根據本授權的條款進行使用或複製。本手冊中的資訊僅以資訊使用目的提供、可能在不另行通知的情況下修改、並且不應被讀解為 Intel 公司的承諾。對於本文件或與本文件相關而提供之任何軟體中若有任何錯誤或不正確之處,Intel 公司不承擔任何責任或義務。除了此授權許可的部份外,事先未經 Intel 公司的明確書面同意,不得以任何格式或方法對本文件的任何部份進行複製、儲存在可擷取的系統中、或傳輸。