将 iSCSI LUN 挂载到 Windows 客户端 - FSx for ONTAP

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

将 iSCSI LUN 挂载到 Windows 客户端

这些过程中提供的示例使用以下设置:

  • 正在挂载到 Windows 主机的 iSCSI LUN 已创建。有关更多信息,请参阅 创建 iSCSI LUN

  • 正在挂载 iSCSI LUN 的 Microsoft Windows 主机是运行 Microsoft Windows Server 2019 亚马逊机器映像(AMI)的 Amazon EC2 实例。为允许入站和出站流量,它已配置 VPC 安全组,如 使用 Amazon VPC 进行文件系统访问控制 中所述。

    您可能需要在设置过程中使用不同的 Microsoft Windows AMI。

  • 客户端和文件系统位于同一 VPC 和 AWS 账户中。如果客户端位于其他 VPC 中,则可以使用 VPC 对等或 AWS Transit Gateway 向其他 VPC 授予访问 iSCSI 终端节点的权限。有关更多信息,请参阅 从部署 VPC 外部访问数据

    我们建议您将 EC2 实例与文件系统的首选子网放入同一个可用区,如下图所示。

该图显示了适用于 NetApp ONTAP 的 Amazon FSx 文件系统,该文件系统具有 iSCSI LUN,Amazon EC2 实例与文件系统的首选子网位于同一个可用区。

在 Windows 客户端上配置 iSCSI

  1. 使用 Windows 远程桌面连接到要在其上挂载 iSCSI LUN 的 Windows 客户端。有关更多信息,请参阅《Amazon Elastic Compute Cloud 用户指南》中的使用 RDP 连接到 Windows 实例

  2. 以管理员 PowerShell 身份打开窗口。使用以下命令在 Windows 实例上启用 iSCSI,并将 iSCSI 服务配置为自动启动。

    PS C:\> Start-Service MSiSCSI PS C:\> Set-Service -Name msiscsi -StartupType Automatic
  3. 检索您的 Windows 实例的启动程序名称。您将使用 ONTAP CLI 在 FSx 上为 ONTAP 文件系统配置 iSCSI 时使用此值。 NetApp

    PS C:\> (Get-InitiatorPort).NodeAddress

    系统使用启动程序端口做出响应。

    iqn.1991-05.com.microsoft:ec2amaz-abc123d
  4. 您需要在 Windows 实例上安装 Multipath-IO(MPIO),以使客户端能够在文件服务器之间自动进行失效转移。使用以下命令:

    PS C:\> Install-WindowsFeature Multipath-IO
  5. Multipath-IO 安装完成后重启 Windows 实例。保持您的 Windows 实例处于打开状态,以便执行后续部分中的 iSCSI LUN 挂载步骤。

在 FSx for ONTAP 文件系统上配置 iSCSI

  1. 使用以下命令连接到您在 NetApp 其中创建 iSCSI LUN 的 FSx for ONTAP 文件系统上的 ONTAP CLI。有关更多信息,请参阅 使用 NetApp ONTAP CLI

    ~$ ssh fsxadmin@your_management_endpoint_ip
  2. 使用 NetApp ONTAP CLI lun igroup create创建启动程序组,或。igroup启动程序组会映射到 iSCSI LUN,并控制哪些启动程序(客户端)可以访问 LUN。将 host_initiator_name 替换为在上一过程中从 Windows 主机中检索到的启动程序名称。

    ::> lun igroup create -vserver svm_name -igroup igroup_name -initiator host_initiator_name -protocol iscsi -ostype windows

    如果要使映射到此 igroup 的 LUN 可供多个主机使用,您可以指定多个启动程序名称,以逗号分隔。有关更多信息,请参阅 NetApp ONTAP 文档中心lun igroup create中的。

  3. 使用以下命令确认已成功创建 igroup

    ::> lun igroup show

    系统将使用以下输出做出响应:

    Vserver Igroup Protocol OS Type Initiators --------- ------------ -------- -------- ------------------------------------ svm_name igroup_name iscsi windows iqn.1994-05.com.windows:abcdef12345

    创建 igroup 后,您就可以创建 LUN 并将其映射到 igroup

  4. 此步骤假定您已创建了 iSCSI LUN。如果没有,创建 iSCSI LUN请参见以 step-by-step 获取操作说明。

    从 LUN 创建一个新 LUN 的映射到 igroup

    ::> lun mapping create -vserver svm_name -path /vol/vol_name/lun_name -igroup igroup_name -lun-id lun_id
  5. 使用以下命令确认 LUN 已创建、已联机且已映射:

    ::> lun show -path /vol/vol_name/lun_name Vserver Path State Mapped Type Size --------- ------------------------------- ------- -------- -------- -------- svm_name /vol/vol_name/lun_name online mapped windows 10GB

    现在,您可以在 Windows 实例上添加 iSCSI 目标。

  6. 使用以下命令检索 SVM 的 iscsi_1iscsi_2 接口的 IP 地址:

    ::> network interface show -vserver svm_name
    Logical Status Network Current Current Is Vserver Interface Admin/Oper Address/Mask Node Port Home ----------- ---------- ---------- ------------------ ------------- ------- ---- svm_name iscsi_1 up/up 172.31.0.143/20 FSxId0123456789abcdef8-01 e0e true iscsi_2 up/up 172.31.21.81/20 FSxId0123456789abcdef8-02 e0e true nfs_smb_management_1 up/up 198.19.250.177/20 FSxId0123456789abcdef8-01 e0e true 3 entries were displayed.

    在此示例中,iscsi_1 的 IP 地址是 172.31.0.143iscsi_2 的IP 地址是 172.31.21.81

在 Windows 客户端上挂载 iSCSI LUN

  1. 在你的 Windows 实例上,以管理员身份打开 PowerShell 终端。

  2. 您将创建一个用于执行以下操作的 .ps1 脚本:

    • 连接到文件系统的每个 iSCSI 接口。

    • 为 iSCSI 添加和配置 MPIO。

    • 为每个 iSCSI 连接建立 8 个会话,使客户端能够向 iSCSI LUN 提供高达 40Gb/s(5000Mb/s)的聚合吞吐量。建立 8 个会话可确保单个客户端能够以为最高级别的 FSx for ONTAP 吞吐能力提供最大量的 4000 MB/s 的吞吐容量。您可以选择增加或减少会话数(每个会话提供高达 625MB/s 的吞吐量),方法是将 #Establish iSCSI connection 步骤中的脚本的 for 循环从 1..8 修改为另一个上限。有关更多信息,请参阅《Amazon Elastic Compute Cloud 用户指南(适用于 Windows 实例)》中的 Amazon EC2 实例网络带宽

    将以下一组命令复制到文件中,创建 .psl 脚本。

    • iscsi_1iscsi_2 替换为在上一步中检索到的 IP 地址。

    • ec2_ip 替换为 Windows 实例的 IP 地址。

    #iSCSI IP addresses for Preferred and Standby subnets $TargetPortalAddresses = @("iscsi_1","iscsi_2") #iSCSI Initator IP Address (Local node IP address) $LocaliSCSIAddress = "ec2_ip" #Connect to FSx for NetApp ONTAP file system Foreach ($TargetPortalAddress in $TargetPortalAddresses) { New-IscsiTargetPortal -TargetPortalAddress $TargetPortalAddress -TargetPortalPortNumber 3260 -InitiatorPortalAddress $LocaliSCSIAddress } #Add MPIO support for iSCSI New-MSDSMSupportedHW -VendorId MSFT2005 -ProductId iSCSIBusType_0x9 #Establish iSCSI connection 1..8 | %{Foreach($TargetPortalAddress in $TargetPortalAddresses) {Get-IscsiTarget | Connect-IscsiTarget -IsMultipathEnabled $true -TargetPortalAddress $TargetPortalAddress -InitiatorPortalAddress $LocaliSCSIAddress -IsPersistent $true}} #Set the MPIO Policy to Round Robin Set-MSDSMGlobalDefaultLoadBalancePolicy -Policy RR
  3. 启动 Windows 的“磁盘管理”应用程序。打开 Windows 的“运行”对话框,输入 diskmgmt.msc,然后按 Enter。然后,“磁盘管理”应用程序随之打开。

    系统会显示 Windows 的“磁盘管理”窗口。
  4. 找到未分配的磁盘,那个就是 iSCSI LUN。在此示例中,“Disk 1”即为 iSCSI 磁盘。其处于离线状态。

    将光标放在磁盘 1 上方时显示的面板。

    将光标悬停在 Disk 1 上方,单击右键,然后选择联机,即可使该卷联机。

    注意

    您可以修改存储区域网络(SAN)策略,以使新卷能够自动联机。有关更多信息,请参阅 Microsoft Windows Server 命令参考中的 SAN 策略

  5. 要初始化磁盘,请右键单击 Disk 1,然后选择初始化。系统将显示“初始化”对话框。选择确定即可初始化磁盘。

  6. 像往常一样格式化磁盘。格式化完成后,iSCSI 驱动器就会在 Windows 客户端上显示为可用驱动器。

正在验证您的 iSCSI 配置

我们提供了一个脚本来检查您的 iSCSI 设置是否配置正确。该脚本检查会话计数、节点分布和多路径 I/O (MPIO) 状态等参数。以下任务说明了如何安装和使用该脚本。

验证您的 iSCSI 配置
  1. 打开窗户 PowerShell 窗口。

  2. 使用以下命令下载脚本。

    PS C:\> Invoke-WebRequest "https://docs.aws.amazon.com/fsx/latest/ONTAPGuide/samples/CheckiSCSI.zip" -OutFile "CheckiSCSI.zip"
  3. 使用以下命令展开 zip 文件。

    PS C:\> Expand-Archive -Path ".\CheckiSCSI.zip" -DestinationPath "./"
  4. 使用以下命令运行脚本。

    PS C:\> ./CheckiSCSI.ps1
  5. 查看输出以了解您的配置的当前状态。以下示例演示了成功的 iSCSI 配置。

    PS C:\> ./CheckiSCSI.ps1 This script checks the iSCSI configuration on the local instance. It will provide information about the number of connected sessions, connected file servers, and MPIO status. MPIO is installed on this server. Initiator: 'iqn.1991-05.com.microsoft:ec2amaz-d2cebnb' to Target: 'iqn.1992-08.com.netapp:sn.13266b10e61411ee8bc0c76ad263d613:vs.3' has 16 total sessions (16 active, 0 non-active) spread across 2 node(s). MPIO: Yes