在 OpenStack 上配置具有 SR-IOV 的 Citrix ADC VPX 实例

您可以在 OpenStack 上部署使用单根 I/O 虚拟化 (SR-IOV) 技术的高性能 Citrix ADC VPX 实例。

您可以通过三个步骤在 OpenStack 上部署使用 SR-IOV 技术的 Citrix ADC VPX 实例:

  • 在主机上启用 SR-IOV 虚拟功能 (VF)。
  • 配置 VF 并使其可用于 OpenStack。
  • 在开放式堆栈上配置 Citrix ADC VPX。

必备条件

确保您:

  • 向主机中添加 Intel 82599 网络接口卡 (NIC)。
  • 从 Intel 下载并安装最新的 IXGBE 驱动程序。
  • 在主机上将 IXGBEVF 驱动程序列入黑名单。在 /etc/modprobe.d/黑名单.conf 文件中添加以下条目:黑名单 ixgbevf

注意

ixgbE 驱动程序版本应至少为 5.0.4。

在主机上启用 SR-IOV VF

执行以下步骤之一启用 SR-IOV VF:

  • <number_of_VFs>如果您使用的是早于 3.8 的内核版本,请将以下条目添加到 /etc/modprobe.d/ixgbe 文件中,然后重新启动主机:选项 ixgbe max_vfs=

  • 如果使用的是内核 3.8 版或更高版本,请使用以下命令创建 VF:

    echo <number_of_VFs> > /sys/class/net/<device_name>/device/sriov_numvfs

其中,

  • number_of_VFs 是要创建的虚拟功能数。
  • 设备名称是接口名称。

重要

创建 SR-IOV VF 过程中,请务必不要将 MAC 地址分配给 VF。

下面是创建四个 VF 的示例。

本地化后的图片

使 VF 持久化,将用于创建 VF 的命令添加到 rc.local 文件中。下面是一个显示 rc.local 文件内容的示例。

本地化后的图片

有关详细信息,请参阅英特尔 SR-IOV 配置指南

配置 VF 并使其可用于 OpenStack

按照以下链接给出的步骤在 OpenStack 上配置 SR-IOV:https://wiki.openstack.org/wiki/SR-IOV-Passthrough-For-Networking

在 OpenStack 上预配置 Citrix ADC VPX 实例

您可以使用 OpenStack CLI 在开放堆栈环境中置备 Citrix ADC VPX 实例。

配置 VPX 实例(可选)涉及使用配置驱动器中的数据。配置驱动器是一个在启动时附加到实例的特殊配置驱动器。在为实例配置网络设置之前,可以使用此配置驱动器将网络连接配置信息(例如管理 IP 地址、网络掩码和默认网关等)传递到实例。

当 OpenStack 预配置 VPX 实例时,它首先通过读取指示 OpenStack 的特定 BIOS 字符串(OpenStack 基础)来检测该实例是否在 OpenStack 环境中启动。对于 Redhat Linux 发行版,该字符串存储在 /etc/nova/release 中。这是在基于 KVM 虚拟机管理程序平台的所有 OpenStack 实现中提供的标准机制。该驱动器应具有特定的 OpenStack 标签。如果检测到配置驱动器,实例将尝试从在 nova boot 命令中指定的文件名中读取以下信息。在下面的过程中,该文件被称为“userdata.txt”。

  • Management IP address(管理 IP 地址)
  • 网络掩码
  • Default gateway(默认网关)

参数成功读取后,将填入 NetScaler 堆栈。这有助于远程管理实例。如果参数未成功读取,或者配置驱动器不可用,实例将转换为默认行为,即:

  • 实例尝试从 DHCP 中检索 IP 地址信息。
  • 如果 DHCP 失败或超时,实例将提供默认网络配置 (192.168.100.1/16)。

通过 CLI 在 OpenStack 上预配置 Citrix ADC VPX 实例

您可以使用 OpenStack CLI 在 OpenStack 环境中预配置 VPX 实例。以下是在 OpenStack 上置备 Citrix ADC VPX 实例的步骤摘要:

  1. 从 .tgz 文件中提取 .qcow2 文件

  2. 基于 qcow2 映像构建 OpenStack 映像

  3. 配置 VPX 实例

要在 OpenStack 环境中配置 VPX 实例,请执行以下步骤。

  1. 通过键入以下命令从 .tqz 文件中提取 .qcow2 文件:

    tar xvzf <TAR file>
    
    tar xvzf NSVPX-KVM-12.0-26.2_nc.tgz
    NSVPX-KVM.xml
    NSVPX-KVM-12.0-26.2_nc.qcow2
    
  2. 通过键入以下命令,使用在步骤 1 中提取的 .qcoz2 文件构建 OpenStack 映像:

    <name of the qcow2 file>一目了然的图像创建 <name of the OpenStack image> —name =””"— 属性 hw_disk_总线= IDE — 是公开的 = 真的 — 容器格式 = 裸磁盘格式 = qcow2<
    
    glance image-create --name="NS-VPX-12-0-26-2" --property hw_disk_bus=ide --is-public= true --container-format=bare --disk-format=qcow2< NSVPX-KVM-12.0-26.2_nc.qcow2
    

    下图提供了 glance image-create 命令的示例输出。

    本地化后的图片

  3. 创建 OpenStack 映像后,请置备 Citrix ADC VPX 实例实例。

    nova boot --image NSVPX-KVM-12.0-26.2 --config-drive=true --userdata
    ./userdata.txt --flavor m1. medium --nic net-id=3b258725-eaae-
    455e-a5de-371d6d1f349f --nic port-id=218ba819-9f55-4991-adb6-
    02086a6bdee2 NSVPX-10
    

    在上面的命令中,userdata.txt 是包含 VPX 实例的 IP 地址、网络掩码和默认 Gateway 等详细信息的文件。用户数据文件是可由用户自定义的文件。NSVPX-KVM-12.0-26.2 是要置备的虚拟设备的名称。–nic port-id=218ba819-9f55-4991-adb6-02086a6bdee2 是 OpenStack VF。

    下图提供了 nova boot 命令的示例输出。

    本地化后的图片

    下图显示了 userdata.txt 文件的示例。<PropertySection></PropertySection> 标记内部的值是用户可配置的值,用于配置 IP 地址、网络掩码和默认网关等信息。

    <?xml version="1.0" encoding="UTF-8" standalone="no"?>
    <Environment xmlns:oe="http://schemas.dmtf.org/ovf/environment/1"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    oe:id=""
    xmlns="http://schemas.dmtf.org/ovf/environment/1">
    <PlatformSection>
    <Kind>NOVA</Kind>
    <Version>2013.1</Version>
    <Vendor>Openstack</Vendor>
    <Locale>en</Locale>
    </PlatformSection>
    <PropertySection>
    <Property oe:key="com.citrix.netscaler.ovf.version" oe:value="1.0"/>
    <Property oe:key="com.citrix.netscaler.platform" oe:value="vpx"/>
    citrix.com 4
    <Property oe:key="com.citrix.netscaler.orch_env"
    oe:value="openstack-orch-env"/>
    <Property oe:key="com.citrix.netscaler.mgmt.ip"
    oe:value="10.1.0.100"/>
    <Property oe:key="com.citrix.netscaler.mgmt.netmask"
    oe:value="255.255.0.0"/>
    <Property oe:key="com.citrix.netscaler.mgmt.gateway"
    oe:value="10.1.0.1"/>
    </PropertySection>
    </Environment>
    

其他受支持的配置:从主机在 SR-IOV VF 上创建和删除 VLAN

键入以下命令在 SR-IOV VF 上创建 VLAN:

ip link show enp8s0f0 vf 6 vlan 10

在上面的命令“enp8s0f0”是物理功能的名称。

示例:vlan 10,在 Vf 6 上创建

本地化后的图片

键入以下命令在 SR-IOV VF 上删除 VLAN:

ip link show enp8s0f0 vf 6 vlan 0

示例:vlan 10,从 Vf 6 中删除

本地化后的图片

这些步骤完成了在 OpenStack 上部署使用 SRIOV 技术的 Citrix ADC VPX 实例的过程。

在 OpenStack 上配置具有 SR-IOV 的 Citrix ADC VPX 实例