4.6. 进行 Microsoft Azure 部署所需的配置更改


在将自定义基础镜像部署到 Azure 之前,您必须执行额外的配置更改,以确保虚拟机(VM)可以在 Azure 中正常工作。

流程

  1. 登录到虚拟机。
  2. 注册虚拟机并启用 Red Hat Enterprise Linux 9 软件仓库。

    # subscription-manager register
    Installed Product Current Status:
    Product Name: Red Hat Enterprise Linux for x86_64
    Status: Subscribed
    Copy to Clipboard Toggle word wrap
  3. 确保安装了 cloud-inithyperv-daemons 软件包。

    # dnf install cloud-init hyperv-daemons -y
    Copy to Clipboard Toggle word wrap
  4. 创建与 Azure 服务集成所需的 cloud-init 配置文件:

    1. 要启用对 Hyper-V Data Exchange Service(KVP)的日志记录,请创建 /etc/cloud/cloud.cfg.d/10-azure-kvp.cfg 配置文件,并将以下行添加到该文件中。

      reporting:
          logging:
              type: log
          telemetry:
              type: hyperv
      Copy to Clipboard Toggle word wrap
    2. 要将 Azure 添加为数据源,请创建 /etc/cloud/cloud.cfg.d/91-azure_datasource.cfg 配置文件,并将以下行添加到该文件中。

      datasource_list: [ Azure ]
      datasource:
          Azure:
              apply_network_config: False
      Copy to Clipboard Toggle word wrap
    3. 要在临时磁盘上配置交换空间,请创建 /etc/cloud/cloud.cfg.d/00-azure-swap.cfg 配置文件并添加以下行。

      重要

      临时磁盘是临时存储。因此,当虚拟机被取消或移动时,存储的数据(包括交换空间)将会丢失。将临时磁盘仅用于临时数据,如交换空间。

      #cloud-config
      disk_setup:
        ephemeral0:
          table_type: gpt
          layout: [66, [33,82]]
          overwrite: true
      fs_setup:
        - device: ephemeral0.1
          filesystem: ext4
        - device: ephemeral0.2
          filesystem: swap
      mounts:
        - ["ephemeral0.1", "/mnt"]
        - ["ephemeral0.2", "none", "swap", "sw,nofail,x-systemd.requires=cloud-init.service", "0", "0"]
      Copy to Clipboard Toggle word wrap
  5. 要确保特定内核模块自动被阻止加载,请编辑或创建 /etc/modprobe.d/blocklist.conf 文件,并将以下行添加到该文件中。

    blacklist nouveau
    blacklist lbm-nouveau
    blacklist floppy
    blacklist amdgpu
    blacklist skx_edac
    blacklist intel_cstate
    Copy to Clipboard Toggle word wrap
  6. 修改 udev 网络设备规则:

    1. 如果存在,请删除以下持久性网络设备规则。

      # rm -f /etc/udev/rules.d/70-persistent-net.rules
      # rm -f /etc/udev/rules.d/75-persistent-net-generator.rules
      # rm -f /etc/udev/rules.d/80-net-name-slot-rules
      Copy to Clipboard Toggle word wrap
    2. 要确保在 Azure 上的加速网络按预期工作,请创建一个新的网络设备规则 /etc/udev/rules.d/68-azure-sriov-nm-unmanaged.rules,并将以下行添加到其中。

      SUBSYSTEM=="net", DRIVERS=="hv_pci", ACTION=="add", ENV{NM_UNMANAGED}="1"
      Copy to Clipboard Toggle word wrap
  7. sshd 服务设置为自动启动。

    # systemctl enable sshd
    # systemctl is-enabled sshd
    Copy to Clipboard Toggle word wrap
  8. 修改内核引导参数:

    1. 打开 /etc/default/grub 文件,并确保 GRUB_TIMEOUT 行有以下值:

      GRUB_TIMEOUT=10
      Copy to Clipboard Toggle word wrap
    2. 如果存在的话,从 GRUB_CMDLINE_LINUX 行的末尾删除以下选项。

      rhgb quiet
      Copy to Clipboard Toggle word wrap
    3. 确保 /etc/default/grub 文件包含具有所有指定选项的以下行:

      GRUB_CMDLINE_LINUX="loglevel=3 crashkernel=auto console=tty1 console=ttyS0 earlyprintk=ttyS0 rootdelay=300"
      GRUB_TIMEOUT_STYLE=countdown
      GRUB_TERMINAL="serial console"
      GRUB_SERIAL_COMMAND="serial --speed=115200 --unit=0 --word=8 --parity=no --stop=1"
      Copy to Clipboard Toggle word wrap
      注意

      如果您没有在 HDD 上运行工作负载,请将 elevator=none 添加到 GRUB_CMDLINE_LINUX 行的末尾。这会将 I/O 调度程序设置为 none,这可以提高基于 SSD 的系统上的 I/O 性能。

    4. 重新生成 grub.cfg 文件。

      • 在基于 BIOS 的机器上:

        • 在 RHEL 9.2 及更早版本中:

          # grub2-mkconfig -o /boot/grub2/grub.cfg
          Copy to Clipboard Toggle word wrap
        • 在 RHEL 9.3 及更高版本中:

          # grub2-mkconfig -o /boot/grub2/grub.cfg --update-bls-cmdline
          Copy to Clipboard Toggle word wrap
      • 在基于 UEFI 的机器上:

        • 在 RHEL 9.2 及更早版本中:

          # grub2-mkconfig -o /boot/grub2/grub.cfg
          Copy to Clipboard Toggle word wrap
        • 在 RHEL 9.3 及更高版本中:

          # grub2-mkconfig -o /boot/grub2/grub.cfg --update-bls-cmdline
          Copy to Clipboard Toggle word wrap
          警告

          对于基于 BIOS 和 UEFI 的机器,重建 grub.cfg 的路径是一样的。实际的 grub.cfg 只在 BIOS 路径中存在。UEFI 路径有一个 stub 文件,不能使用 grub2-mkconfig 命令修改或重新创建。

          如果您的系统对 grub.cfg 使用非默认位置,请相应地调整命令。

  9. 配置 Windows Azure Linux 代理(WALinuxAgent):

    1. 安装并启用 WALinuxAgent 软件包。

      # dnf install WALinuxAgent -y
      # systemctl enable waagent
      Copy to Clipboard Toggle word wrap
    2. 要在 WALinuxAgent 中禁用交换配置(在使用 cloud-init 管理交换时必需),请编辑 /etc/waagent.conf 文件中的以下行。

      Provisioning.DeleteRootPassword=y
      ResourceDisk.Format=n
      ResourceDisk.EnableSwap=n
      ResourceDisk.SwapSizeMB=0
      Copy to Clipboard Toggle word wrap
      注意

      通过在 WALinuxAgent 中禁用 swap,您可以启用 cloud-init 来管理临时磁盘上的交换配置。

  10. 为 Azure 置备准备虚拟机:

    1. 从 Red Hat Subscription Manager 取消注册虚拟机。

      # subscription-manager unregister
      Copy to Clipboard Toggle word wrap
    2. 清理现有置备详情。

      # waagent -force -deprovision
      Copy to Clipboard Toggle word wrap
      注意

      这个命令会产生警告,这是预期的,因为 Azure 会自动处理虚拟机的置备。

    3. 清理 shell 历史记录并关闭虚拟机。

      # export HISTSIZE=0
      # poweroff
      Copy to Clipboard Toggle word wrap
Red Hat logoGithubredditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。 了解我们当前的更新.

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

Theme

© 2026 Red Hat
返回顶部