了解如何设置和管理多个虚拟机,以确保 Azure 中 Windows 应用程序的高可用性。 也可以管理 Linux 虚拟机的可用性。

Note

Azure 具有用于创建和处理资源的两个不同的部署模型:Resource Manager 和经典。 这篇文章介绍了如何使用这两种模型,但 Azure 建议大多数最新部署使用 Resource Manager 模型。

有关在使用经典部署模型时创建和使用可用性集的说明,请参阅如何配置可用性集。

了解 VM 重启 - 维护和停机

有三种情况可能会导致 Azure 中的虚拟机受影响:计划外硬件维护、意外停机、计划内维护。

  • 当 Azure 平台预测硬件或者与物理计算机关联的任何平台组件即将发生故障时,就会发生计划外硬件维护事件。 当预测到故障时,平台会发出计划外硬件维护事件,以便减少对托管在该硬件上的虚拟机的影响。 Azure 使用实时迁移技术将虚拟机从故障硬件迁移到健康的物理计算机。 实时迁移是一项 VM 保留操作,只能短时间暂停虚拟机。 将会保留内存、打开的文件以及网络连接,但事件前后的性能可能会降低。 在无法使用实时迁移的情况下,VM 会出现意外停机,如下所述。

  • 意外停机很少发生在虚拟机所在硬件或物理基础结构出现某类故障的情况。 此类故障可能包括:本地网络故障、本地磁盘故障,或者其他机架级别的故障。 检测到此类故障时,Azure 平台会自动将虚拟机迁移到正常的物理计算机(进行修复)。 在修复过程中,虚拟机会经历停机(重启),在某些情况下会丢失临时驱动器。 始终会保留附加的 OS 和数据磁盘。

  • 计划内维护事件是指由 21Vianet 对底层 Azure平台进行定期更新,以改进虚拟机运行时所在的平台基础结构的总体可靠性、性能和安全性。 大多数此类更新在执行时不会影响虚拟机或云服务(请参阅 VM 保留维护)。 虽然 Azure 平台会尝试在所有可能的情况下都使用 VM 保留维护,但在罕见情况下,这些更新需要重启虚拟机,否则无法将所需更新应用到底层基础结构。 在这种情况下,可以在合适的时间窗口为 VM 启动维护,通过“维护-重新部署”操作来执行 Azure 计划内维护。 有关详细信息,请参阅虚拟机的计划内维护。

要减轻一个或多个此类事件引发的停机所造成的影响,我们建议遵循以下最佳做法以提高虚拟机的可用性:

  • 在可用性集中配置多个虚拟机以确保冗余
  • 在可用性集中对 VM 使用托管磁盘
  • 使用计划事件对影响事件的 VM 进行主动响应
  • 将每个应用程序层配置到不同的可用性集中
  • 将负载均衡器与可用性集组合在一起

在可用性集中配置多个虚拟机以确保冗余

要为应用程序提供冗余,建议你将两个或更多虚拟机组合到一个可用性集中。 这种配置可以确保在发生计划内或计划外维护事件时,至少有一个虚拟机可用,并满足 99.95% 的 Azure SLA 要求。 有关详细信息,请参阅虚拟机的 SLA。

Important

避免将单实例虚拟机单独地置于可用性集中。 此配置中的 VM 并不符合 SLA 保证,在出现 Azure 计划内维护事件时会停机,除非某个 VM 正在使用 Azure 高级存储。 对于使用高级存储的单一 VM,Azure SLA 适用。

基础 Azure 平台为可用性集中的每个虚拟机分配一个更新域和一个容错域。 对于给定的可用性集,默认情况下会分配五个非用户可配置的更新域(可以增加 Resource Manager 部署以最多提供 20 个更新域),以指示可同时重新启动的虚拟机和底层物理硬件组。 如果单个可用性集中配置了超过 5 个虚拟机,第 6 个虚拟机放置在第 1 个虚拟机所在的更新域中,第 7 个虚拟机放置在第 2 个虚拟机所在的更新域中,依此类推。 在计划内维护期间,更新域的重启顺序可能不会按序进行,但一次只重启一个更新域。 重启的更新域有 30 分钟的时间进行恢复,此时间过后,就会在另一更新域上启动维护操作。

容错域定义一组共用一个通用电源和网络交换机的虚拟机。 默认情况下,在可用性集中配置的虚拟机隔离在 Resource Manager 部署的最多三个容错域(经典部署的两个容错域)中。 虽然将虚拟机置于可用性集中并不能让应用程序免受特定于操作系统或应用程序的故障的影响,但可以限制潜在物理硬件故障、网络中断或电源中断的影响。

在可用性集中对 VM 使用托管磁盘

如果当前使用的 VM 没有托管磁盘,则强烈建议在可用性集中转换 VM,以便使用托管磁盘。

通过确保可用性集中的 VM 的磁盘彼此之间完全隔离以避免单点故障,托管磁盘为可用性集提供了更佳的可靠性。 它通过自动将磁盘放置在不同的存储群集中来实现这一点。 如果某个存储群集因硬件或软件故障而失败,则只有其磁盘在该模块上的 VM 实例会失败。

Important

托管可用性集的容错域的数目因区域而异 - 每个区域两到三个。 下表显示了每个区域的数目

每个区域的容错域数

区域 最大容错域数
中国东部 3
中国北部 3

如果计划使用包含非托管磁盘的 VM,请按下述针对存储帐户的最佳做法进行操作。在这些存储帐户中,VM 的虚拟硬盘 (VHD) 以页 Blob 形式存储。

  1. 将与同一 VM 关联的所有磁盘(OS 和数据)放置在同一存储帐户中
  2. 在向存储帐户添加更多 VHD 之前,请查看存储帐户中非托管磁盘的数量限制
  3. 为可用性集中的每个 VM 使用单独的存储帐户。 同一可用性集中的多个 VM 不能共享存储帐户。 不同可用性集中的 VM 共享存储帐户是可以接受的,只要遵循上述最佳做法即可

将每个应用程序层配置到不同的可用性集中

如果虚拟机几乎都是相同的,并且对应用程序的用途是一样的,我们建议针对每个应用程序层配置可用性集。 如果将两个不同的层置于同一可用性集中,则同一应用程序层中的所有虚拟机可以同时重启。 通过在可用性集中为每个层配置至少两个虚拟机,可以确保每个层中至少有一个虚拟机可用。

例如,可以将运行 IIS、Apache、Nginx 的应用程序前端的所有虚拟机置于单个可用性集中。 请确保仅将前端虚拟机置于同一可用性集中。 同样,请确保仅将数据层虚拟机置于其自身的可用性集中,例如已复制的 SQL Server 虚拟机或 MySQL 虚拟机。

将负载均衡器与可用性集组合在一起

将 Azure 负载均衡器与可用性集组合在一起,以获取最大的应用程序复原能力。 Azure 负载均衡器将流量分布到多个虚拟机中。 对于标准层虚拟机来说,Azure 负载均衡器已包括在内。 并非所有虚拟机层都包括 Azure 负载均衡器。 有关对虚拟机进行负载均衡的更多信息,请阅读对虚拟机进行负载均衡。

如果没有将负载均衡器配置为对多个虚拟机上的流量进行平衡,则任何计划内维护事件都会影响唯一的那个处理流量的虚拟机,导致应用程序层中断。 将同一层的多个虚拟机置于相同的负载均衡器和可用性集下可以确保至少有一个虚拟机实例能够持续处理流量。

后续步骤

若要了解对虚拟机进行负载均衡的详细信息,请参阅对虚拟机进行负载均衡。

立即访问http://market.azure.cn

在 Azure 中管理 Windows 虚拟机的可用性相关推荐

  1. 在组织中管理 Windows Hello 企业版

    在组织中管理 Windows Hello 企业版 https://docs.microsoft.com/zh-cn/windows/security/identity-protection/hello ...

  2. linux中安装Windows虚拟机(使用VMware player)

    文章目录 一.下载和安装VMware 二.启动和配置VMware player 2.1 在Linux主机上安装VMware player 2.2 启动VMplayer 2.3 从官方下载Windows ...

  3. mac中的Windows虚拟机字体太小解决办法

    mac中的Windows虚拟机字体太小解决办法 - vue技术交流群(864583465) 1.关闭虚拟机 2.找到虚拟机的设置界面 3.点击显示器,在出现的窗口中勾选掉"Retina全分辨 ...

  4. 详细故障排除步骤:针对 Azure 中到 Windows VM 的远程桌面连接问题

    本文提供详细的故障排除步骤,用于为基于 Windows 的 Azure 虚拟机诊断和修复复杂的远程桌面错误. Important 若要消除更常见的远程桌面错误,请务必先阅读远程桌面的基本故障排除文章, ...

  5. 如何使用PowerShell在Azure中创建SQL虚拟机

    介绍 ( Introduction ) The first time that you create your VM in Azure manually using the UI is a very ...

  6. Openstack中给windows虚拟机加载virtion驱动

    通过qemu-img将windows虚拟机的vmdk文件转换成qcow2,并将文件上传至openstack中时,发现虚拟机无法启动. 经过分析,原因是openstack默认使用的是virtio驱动,而 ...

  7. KVM中给windows虚拟机安装virtio驱动

    KVM下windows虚拟机默认disk使用的是Qemu IDE硬盘,网卡默认是e1000网卡.为了使kvm主机在相同的配置下,有更好的效率,需要命名用半虚拟化将驱动改为为了virtio ,使硬盘工作 ...

  8. 谷歌chrome xp_在Google Chrome中管理Windows Live帐户

    谷歌chrome xp Do you need a nice simple way to manage your Windows Live account without maintaining a ...

  9. 【网络成长记】vmware中安装windows虚拟机

    文章目录 下载windows镜像 安装 下载windows镜像 msdn 打开迅雷软件,会自动复制链接进行下载 安装 VMware Workstation Pro虚拟机安装Windows 10 系统 ...

最新文章

  1. python入门小练习_python入门题目小练
  2. java培训要学习多久?
  3. R计算赤信息指标(Akaike information criterion,AIC)
  4. SQL Server 2005 学习笔记之触发器简介[转]
  5. winpcap编程 解析数据包
  6. 一个简单的FreeMarker案例
  7. C#中dynamic、ExpandoObject 的正确用法
  8. calico 跨主机容器网络通信
  9. 利用Java实现串口全双工通讯
  10. 五年后存储会是什么样子
  11. OD使用教程20 - 调试篇20
  12. Qt下拉对话框 ComboBox的用法
  13. django 1.8 官方文档翻译: 2-6-4 数据库访问优化
  14. php下载css图片,PHP实现下载CSS文件中的图片
  15. 数论_埃氏筛法(求区间内多少素数)
  16. MapReduce 切片源码中SPLIT_SLOP等于1.1的原因分析(TextInputFormat)
  17. java毕业设计基于的高校教室申请管理系统mybatis+源码+调试部署+系统+数据库+lw
  18. vue+js练手前端项目->游戏平台(贪吃蛇、俄罗斯方块、飞机大战、飞翔的小鸟、2048、五子棋)
  19. Oracle的异构数据迁移工具 - OMW及ODI
  20. 池化层(汇聚层)的通道变化

热门文章

  1. Spline interpolation and Savitzki-Golay smoothing
  2. mytag.class.php,织梦CMS/dedecms织梦模板留言板调用{dede:}标签的头部尾部的方法
  3. python画七边形的角度_python之turtle模块-生化危机
  4. 开发安卓app游戏_游戏陪玩系统APP开发平台
  5. java ftp 判断文件是否存在_FTP判断文件是否存在
  6. IDEA配置GitHub报错GitHub Invalid authentication data.404 Not Found-Not Found
  7. node.js 出现cannot find module ‘xxx‘ 解决办法
  8. React 开发环境搭建
  9. iOS base64 MD5
  10. 浮动布局会受父框滚动条影响