优化 Azure 虚拟机网络吞吐量

Azure 虚拟机 (VM) 的默认网络设置可以进一步针对网络吞吐量进行优化。 本文介绍如何优化 Azure 的 Windows 和 Linux VM(包括 Ubuntu、CentOS 和 Red Hat 等主要发行版)的网络吞吐量。

Windows VM

与不使用 RSS 的 VM 相比,使用接收方缩放 (RSS) 的 VM 可达到更高的最大吞吐量。 RSS 在 Windows VM 中默认已禁用。 完成以下步骤可确定是否已启用 RSS,并在禁用的情况下将它启用。

  1. 使用 Get-NetAdapterRss PowerShell 命令查看是否为网络适配器启用了 RSS。 从 Get-NetAdapterRss返回的以下示例输出中可以看出,RSS 未启用。

    Name                    : Ethernet
    InterfaceDescription    : Microsoft Hyper-V Network Adapter
    Enabled                 : False
    
  2. 若要启用 RSS,请输入以下命令:

    Get-NetAdapter | % {Enable-NetAdapterRss -Name $_.Name}
    

    前一个命令没有输出。 该命令更改了 NIC 设置,导致出现暂时性连接断开大约一分钟。 连接断开期间会显示“重新连接”对话框。 通常在第三次尝试后,连接会恢复。

  3. 再次输入 Get-NetAdapterRss 命令,确认 RSS 是否在 VM 中启用。 如果成功,则返回以下示例输出:

    Name                    : Ethernet
    InterfaceDescription    : Microsoft Hyper-V Network Adapter
    Enabled                  : True
    

Linux VM

默认情况下,RSS 在 Azure Linux VM 中始终启用。 自 2017 年 12 月以后发布的 Linux 内核均包含新的网络优化选项,可使 Linux VM 实现更高的网络吞吐量。

用于新部署的 Ubuntu

Ubuntu Azure 内核在 Azure 上提供最佳网络性能,并且自 2017 年 9 月 21 日起已成为默认内核。 若要获得此内核,请首先安装 16.04-LTS 的最新支持版本,如下所述:

"Publisher": "Canonical",
"Offer": "UbuntuServer",
"Sku": "16.04-LTS",
"Version": "latest"

创建完成后,输入以下命令获取最新更新。 这些步骤也适用于当前正在运行 Ubuntu Azure 内核的 VM。

#run as root or preface with sudo
apt-get -y update
apt-get -y upgrade
apt-get -y dist-upgrade

对于已经有了 Azure 内核但由于出错而无法进一步更新的现有 Ubuntu 部署,以下可选命令集可能会非常有用。

#optional steps may be helpful in existing deployments with the Azure kernel
#run as root or preface with sudo
apt-get -f install
apt-get --fix-missing install
apt-get clean
apt-get -y update
apt-get -y upgrade
apt-get -y dist-upgrade

现有 VM 的 Ubuntu Azure 内核升级

重要的吞吐量性能可通过升级到 Azure Linux 内核来实现。 若要验证是否具有此内核,请检查你的内核版本。

#Azure kernel name ends with "-azure"
uname -r

#sample output on Azure kernel:
#4.11.0-1014-azure

如果 VM 没有 Azure 内核,版本号将通常以“4.4”开头。 如果 VM 没有 Azure 内核,请以 root 身份运行以下命令:

#run as root or preface with sudo
apt-get update
apt-get upgrade -y
apt-get dist-upgrade -y
apt-get install "linux-azure"
reboot

CentOS

若要获得最新优化,最好通过指定以下参数,创建具有最新支持版本的 VM:

"Publisher": "OpenLogic",
"Offer": "CentOS",
"Sku": "7.4",
"Version": "latest"

新的和现有的 VM 可受益于安装最新 Linux Integration Services (LIS)。 从 4.2.2-2 开始,吞吐量优化位于 LIS 中,尽管更高版本包含更多改进。 输入以下命令以安装最新 LIS:

sudo yum update
sudo reboot
sudo yum install microsoft-hyper-v

Red Hat

若要获得优化,最好通过指定以下参数,创建具有最新支持版本的 VM:

"Publisher": "RedHat"
"Offer": "RHEL"
"Sku": "7-RAW"
"Version": "latest"

新的和现有的 VM 可受益于安装最新 Linux Integration Services (LIS)。 吞吐量优化功能在从 4.2 开始的 LIS 中。 输入以下命令下载并安装 LIS:

mkdir lis4.2.3-1
cd lis4.2.3-1
wget https://download.microsoft.com/download/6/8/F/68FE11B8-FAA4-4F8D-8C7D-74DA7F2CFC8C/lis-rpms-4.2.3-1.tar.gz
tar xvzf lis-rpms-4.2.3-1.tar.gz
cd LISISO
install.sh #or upgrade.sh if prior LIS was previously installed

查看下载页,详细了解适用于 Hyper-V 的 Linux Integration Services 版本 4.2。

后续步骤