Partage via


Capacité de calcul Azure Stack Hub

Les tailles de machine virtuelle prises en charge sur Azure Stack Hub constituent une partie de celles prises en charge dans Azure. Azure impose des limites de ressources à différents niveaux pour éviter la consommation excessive des ressources (au niveau du service ou du serveur local). Si aucune limite n’est appliquée à la consommation des locataires, la surconsommation de ressources par certains locataires aurait un impact négatif sur l’expérience des autres locataires. Pour la sortie réseau de la machine virtuelle, il existe des limites de bande passante dans Azure Stack Hub correspondant aux limites d’Azure. Pour les ressources de stockage sur Azure Stack Hub, les limites d’IOPS de stockage évitent une surconsommation des ressources par les locataires pour l’accès au stockage.

Important

Azure Stack Hub Capacity Planner ne tient pas compte des performances d’IOPS et ne les garantit pas. Le portail administrateur affiche une alerte d’avertissement quand la consommation totale de la mémoire système a atteint 85 %. Vous pouvez remédier à cette alerte en ajoutant de la capacité supplémentaire ou en supprimant les machines virtuelles qui ne sont plus nécessaires.

Placement des machines virtuelles

Le moteur de placement Azure Stack Hub effectue le placement des machines virtuelles locataires sur les hôtes disponibles.

Azure Stack Hub détermine le placement des machines virtuelles selon deux critères. En premier lieu, y a-t-il suffisamment de mémoire sur l’hôte pour le type de machine virtuelle en question ? En second lieu, les machines virtuelles font-elles partie d’un groupe à haute disponibilité ou constituent-elles des groupes de machines virtuelles identiques ?

Pour garantir la haute disponibilité d’une charge de travail de production à plusieurs machines virtuelles dans Azure Stack Hub, ces machines virtuelles sont placées dans un groupe à haute disponibilité qui les répartit entre plusieurs domaines d’erreur. Un domaine d’erreur au sein d’un groupe à haute disponibilité est défini comme un nœud unique dans l’unité d’échelle. Azure Stack Hub prend ne charge les groupes à haute disponibilité avec un maximum de trois domaines d’erreur, pour rester cohérent avec Azure. Les machines virtuelles placées dans un groupe à haute disponibilité sont physiquement isolées les unes des autres grâce à une répartition aussi équilibrée que possible sur plusieurs domaines d’erreur (nœuds Azure Stack Hub). En cas de défaillance matérielle, les machines virtuelles du domaine défaillant sont redémarrées dans d’autres domaines d’erreur. Dans la mesure du possible, elles sont conservées dans des domaines d’erreur distincts des autres machines virtuelles du même groupe à haute disponibilité. Une fois l’hôte rétabli, les machines virtuelles sont rééquilibrées de façon à maintenir une haute disponibilité.

Les groupes de machines virtuelles identiques utilisent des groupes à haute disponibilité sur le back-end et veillent à ce que chacune de leurs instances soient placées dans un domaine d’erreur différent. Cela signifie qu’ils utilisent des nœuds d’infrastructure Azure Stack Hub distincts. Par exemple, dans un système Azure Stack Hub à quatre nœuds, il peut arriver que la création d’un groupe de machines virtuelles identiques de trois instances échoue en raison de l’absence de la capacité de quatre nœuds pour placer trois instances du groupe de machines virtuelles identiques sur trois nœuds Azure Stack Hub distincts. De plus, les nœuds Azure Stack Hub peuvent être remplis à des niveaux variables avant la tentative de placement.

Azure Stack Hub ne surengage pas la mémoire. En revanche, un surengagement du nombre de cœurs physiques est autorisé.

Étant donné que les algorithmes de placement ne considèrent pas le ratio de surprovisionnement cœurs virtuels/cœurs physiques comme un facteur déterminant, chaque hôte peut présenter un ratio différent. Microsoft ne fournit pas de conseils sur le ratio cœurs physiques/cœurs virtuels en raison des variations entre les charges de travail et les exigences de niveau de service.

Prise en compte du nombre total de machines virtuelles

Le nombre total de machines virtuelles pouvant être créées est limité. Le nombre maximal de machines virtuelles sur Azure Stack Hub est 700, et 60 par nœud d’unité d’échelle. Ainsi, la limite de machines virtuelles Azure Stack Hub pour huit serveurs sera de 480 (8 * 60). Pour une solution Azure Stack Hub de 12 à 16 serveurs, la limite serait de 700 machines virtuelles. Cette limite a été définie en gardant à l’esprit toutes les considérations relatives à la capacité de calcul, telles que la réserve de résilience et le rapport virtuel/physique du processeur qu’un opérateur souhaite conserver.

Si la limite de mise à l’échelle de la machine virtuelle a été atteinte, les codes d’erreur suivants sont retournés comme résultat : VMsPerScaleUnitLimitExceeded, VMsPerScaleUnitNodeLimitExceeded.

Notes

Une partie de ce maximum de 700 machines virtuelles est réservée aux machines virtuelles de l’infrastructure Azure Stack Hub. Pour plus d’informations, consultez Azure Stack Hub Capacity Planner.

Considération pour le déploiement par lots de machines virtuelles

Dans les versions antérieures à 2002, 2 à 5 machines virtuelles par lot avec un écart de 5 minutes entre les lots fournissaient des déploiements de machines virtuelles fiables pour atteindre une échelle de 700 machines virtuelles. Depuis la version 2005 d’Azure Stack Hub, nous pouvons approvisionner de manière fiable des machines virtuelles par lots de 40, avec un intervalle de 5 minutes entre les déploiements de lots. Les opérations de démarrage, d’arrêt-désallocation et de mise à jour doivent être effectuées à une taille de lot de 30, ce qui laisse 5 minutes entre chaque lot.

Considération pour les machines virtuelles GPU

Azure Stack Hub réserve de la mémoire pour le basculement des machines virtuelles de l’infrastructure et du locataire. Contrairement à d’autres machines virtuelles, les machines virtuelles GPU s’exécutent en mode non-HA (haute disponibilité) et ne basculent donc pas. Par conséquent, la mémoire réservée pour un tampon uniquement de machine virtuelle GPU est ce que l’infrastructure requiert pour le basculement, par opposition à la prise en compte également de la mémoire de la machine virtuelle du locataire HA.

Mémoire Azure Stack Hub

Azure Stack Hub est conçu pour maintenir opérationnelles les machines virtuelles correctement approvisionnées. Par exemple, si un hôte est hors connexion en raison d’une défaillance matérielle, Azure Stack Hub tente de redémarrer cette machine virtuelle sur un autre hôte. Un deuxième exemple se voit pendant la correction et la mise à jour des logiciels Azure Stack Hub. S’il est nécessaire de redémarrer un hôte physique, une tentative est effectuée pour déplacer les machines virtuelles qui s’exécutent sur cet hôte vers un autre hôte disponible dans la solution.

Cette stratégie de gestion ou de migration des machines virtuelles est possible uniquement s’il existe une capacité de mémoire réservée à ces opérations de redémarrage ou de migration. Une partie de la mémoire hôte totale est réservée et indisponible pour le placement des machines virtuelles des locataires.

Dans le portail d’administration, vous pouvez consulter un graphique en secteurs indiquant la mémoire libre et utilisée dans Azure Stack Hub. Le diagramme suivant montre la capacité de mémoire physique sur une unité d’échelle Azure Stack Hub dans Azure Stack Hub :

Capacité de mémoire physique dans une unité d’échelle Azure Stack Hub

La mémoire utilisée inclut plusieurs composants. Les composants suivants consomment la mémoire dans la section Utilisation du graphique en secteurs :

  • Utilisation ou réserve du système d’exploitation hôte : il s’agit de la mémoire utilisée par le système d’exploitation sur l’hôte, les tables de pages mémoire virtuelle, les processus qui s’exécutent sur le système d’exploitation hôte et le cache de mémoire des espaces de stockage direct. Dans la mesure où cette valeur dépend de la mémoire utilisée par les différents processus Hyper-V exécutés sur l’hôte, elle peut varier.
  • Services d’infrastructure : il s’agit des machines virtuelles d’infrastructure qui composent Azure Stack Hub. Comme nous l’avons vu précédemment, ces machines virtuelles font partie du maximum de 700 machines virtuelles. L’utilisation de la mémoire du composant Services d’infrastructure pourra varier, car nous essayons de rendre nos services d’infrastructure plus évolutifs et résilients. Pour plus d’informations, consultez Azure Stack Hub Capacity Planner.
  • Réserve de résilience : Azure Stack Hub réserve une partie de la mémoire aux locataires en cas de défaillance d’un seul hôte, ainsi que pendant l’application de correctifs ou de mises à jour pour garantir la réussite des migrations dynamiques de machines virtuelles.
  • Machines virtuelles de locataire : il s’agit des machines virtuelles de locataire créées par les utilisateurs Azure Stack Hub. La mémoire est consommée, non seulement par les machines virtuelles en cours d’exécution, mais aussi par toutes les machines virtuelles qui ont atterri sur la structure fabric. Cela signifie que les machines virtuelles qui ont l’état « Création en cours » ou « Échec » ou bien qui sont arrêtées à partir de l’invité consomment de la mémoire. En revanche, les machines virtuelles libérées à l’aide de l’option d’arrêt appropriée du portail, de PowerShell ou de CLI ne consomment pas de mémoire d’Azure Stack Hub.
  • Fournisseurs de ressources à valeur ajoutée : il s’agit des machines virtuelles déployées pour les fournisseurs de ressources à valeur ajoutée, comme SQL, MySQL, App Service, etc.

La meilleure façon de comprendre la consommation de mémoire sur le portail consiste à utiliser Azure Stack Hub Capacity Planner pour voir l’impact des différentes charges de travail. Le calcul suivant est identique à celui utilisé par le planificateur.

Il permet d’obtenir la capacité de mémoire totale disponible qui peut être utilisée pour le placement des machines virtuelles des locataires. Cette capacité de mémoire est calculée pour l’intégralité de l’unité d’échelle Azure Stack Hub.

Mémoire disponible pour le placement des machines virtuelles = mémoire totale de l’hôte - réserve de résilience - mémoire utilisée par les machines virtuelles des locataires en cours d’exécution - surcharge de l’infrastructure Azure Stack Hub 1

  • Mémoire totale de l’hôte = somme de la mémoire de tous les nœuds
  • Réserve de résilience = H + R * ((N-1) * H) + V * (N-2)
  • Mémoire utilisée par les machines virtuelles du locataire = mémoire réelle consommée par la charge de travail du locataire, indépendamment de la configuration de haute disponibilité
  • Surcharge de l’infrastructure Azure Stack Hub = 268 Go (4 Go x N)

Où :

  • H = taille de la mémoire d’un seul serveur
  • N = taille de l’unité d’échelle (nombre de serveurs)
  • R = réserve de système d’exploitation pour la surcharge du système d’exploitation, à savoir 0,15 dans cette formule2
  • V = machine virtuelle HA la plus grande dans l’unité d’échelle

1 Surcharge de l’infrastructure Azure Stack Hub = 268 Go (4 Go x nombre de nœuds). Quelque 31 machines virtuelles sont utilisées pour héberger l’infrastructure d’Azure Stack Hub. Celles-ci consomment au total environ 268 Go (4 Go x nombre de nœuds) de mémoire et 146 cœurs virtuels. Le nombre de machines virtuelles est lié à la nécessité de séparer les différents services pour répondre aux exigences de sécurité, de scalabilité, de maintenance et d’action corrective. Grâce à cette structure de service interne, de nouveaux services d’infrastructure peuvent être intégrés à mesure qu’ils sont développés.

2 Réserve de système d’exploitation pour la surcharge = 15 % (0,15) de la mémoire de nœud. La valeur de la réserve de système d’exploitation est une estimation et varie en fonction de la capacité de mémoire physique du serveur et de la surcharge générale du système d’exploitation.

La valeur V pour la machine virtuelle HA la plus grande dans l’unité d’échelle, est basée de façon dynamique sur la plus grande taille de mémoire de machine virtuelle de locataire. Par exemple, la valeur la plus grande de machine virtuelle HA est au minimum de 12 Go (en tenant compte de la machine virtuelle d’infrastructure) ou de 112 Go, ou de toute autre taille de mémoire de machine virtuelle prise en charge dans la solution Azure Stack Hub. Le changement de la plus grande machine virtuelle HA sur l’infrastructure Azure Stack Hub entraîne une augmentation de la réserve de résilience ainsi qu’une augmentation de la mémoire de la machine virtuelle proprement dite. N’oubliez pas que les machines virtuelles GPU s’exécutent en mode non-HA.

Exemple de calcul

Prenons un petit déploiement Azure Stack Hub à quatre nœuds de 768 Go de RAM chacun. Nous prévoyons d’effectuer la sélection élective d’une machine virtuelle pour SQL Server comportant 128 Go de RAM (Standard_E16_v3). Quelle est la mémoire disponible pour la sélection élective de la machine virtuelle ?

  • Mémoire totale de l’hôte = somme de la mémoire de tous les nœuds = 4 x 768 Go = 3 072 Go
  • Réserve de résilience =H + R x ((N - 1) x H) + V x (N - 2) = 768 + 0,15 x ((4 - 1) x 768) + 128 x (4 - 2) = 1 370 Go
  • Mémoire utilisée par les machines virtuelles du locataire = mémoire réelle consommée par la charge de travail du locataire, indépendamment de la configuration de haute disponibilité = 0 Go
  • Surcharge de l’infrastructure Azure Stack Hub = 268 Go (4 Go x N) = 268 + (4 x 4) = 284 Go

Mémoire disponible pour la sélection élective de la machine virtuelle = mémoire totale de l’hôte - réserve de résilience - mémoire utilisée par les machines virtuelles du locataire en cours d’exécution - surcharge de l’infrastructure Azure Stack Hub

Mémoire disponible pour la sélection élective de la machine virtuelle = 3 072 - 1 370 - 0 - 284 = 1 418 Go

Considérations relatives à la désallocation

Quand une machine virtuelle est dans l’état désalloué, les ressources mémoire ne sont pas utilisées. Cela permet de placer d’autres machines virtuelles dans le système.

Si la machine virtuelle désallouée est ensuite redémarrée, l’allocation ou l’utilisation de la mémoire est traitée comme une nouvelle machine virtuelle placée dans le système, et la mémoire disponible est consommée. Si aucune mémoire n’est disponible, la machine virtuelle ne démarre pas.

Les machines virtuelles de grande taille actuellement déployées montrent que la mémoire allouée est de 112 Go alors que la demande de mémoire de ces machines virtuelles se situe entre 2 et 3 Go.

Nom Mémoire affectée (Go) Demande de mémoire (Go) ComputerName
ca7ec2ea-40fd-4d41-9d9b-b11e7838d508 112 2.2392578125 LISSA01P-NODE01
10cd7b0f-68f4-40ee-9d98-b9637438ebf4 112 2.2392578125 LISSA01P-NODE01
2e403868-ff81-4abb-b087-d9625ca01d84 112 2.2392578125 LISSA01P-NODE04

Il existe trois façons de libérer de la mémoire pour la sélection élective d’une machine virtuelle à l’aide de la formule Réserve de résilience = H + R * ((N-1) * H) + V * (N-2) :

  • Réduire la taille de la plus grande machine virtuelle
  • Augmenter la mémoire d’un nœud
  • Ajouter un nœud

Réduire la taille de la plus grande machine virtuelle

Réduire la taille de la plus grande machine virtuelle à la plus petite machine virtuelle suivante dans le tampon (24 Go) réduit la taille de la réserve de résilience.

Réduire la taille de la machine virtuelle

Réserve de résilience = 384 + 172,8 + 48 = 604,8 Go

Mémoire totale Infra - Go Locataire - Go Réserve de résilience Mémoire totale réservée Total de Go disponibles pour la sélection élective
1536 Go 258 Go 329,25 Go 604,8 Go 258 + 329,25 + 604,8 = 1 168 Go ~344 Go

Ajouter un nœud

L’ajout d’un nœud Azure Stack Hub libère de la mémoire en répartissant équitablement la mémoire entre les deux nœuds.

Ajouter un nœud

Réserve de résilience = 384 + (0.15) ((5)*384) + 112 * (3) = 1008 Go

Mémoire totale Infra - Go Locataire - Go Réserve de résilience Mémoire totale réservée Total de Go disponibles pour la sélection élective
1536 Go 258 Go 329,25 Go 604,8 Go 258 + 329,25 + 604,8 = 1 168 Go ~ 344 Go

Augmenter la mémoire de chaque nœud jusqu’à 512 Go

Augmenter la mémoire de chaque nœud augmente la mémoire totale disponible.

Augmenter la taille du nœud

Réserve de résilience = 512 + 230.4 + 224 = 966,4 Go

Mémoire totale Infra - Go Locataire - Go Réserve de résilience Mémoire totale réservée Total de Go disponibles pour la sélection élective
2048 (4*512) Go 258 Go 505,75 Go 966,4 Go 1730,15 Go ~ 318 Go

Forum Aux Questions (FAQ)

Q : Mon locataire a déployé une nouvelle machine virtuelle. Combien de temps faut-il pour que la capacité restante soit reflétée dans le graphique de capacité sur le portail d’administration ?

R : Prenez en compte que le panneau de capacité est actualisé toutes les 15 minutes.

Q : Comment puis-je voir les cœurs disponibles et les cœurs attribués ?

R : Dans PowerShell, exécutez test-azurestack -include AzsVmPlacement -debug, qui génère une sortie semblable à celle-ci :

    Starting Test-AzureStack
    Launching AzsVmPlacement
     
    Azure Stack Scale Unit VM Placement Summary Results
     
    Cluster Node    VM Count VMs Running Physical Core Total Virtual Co Physical Memory Total Virtual Mem
    ------------    -------- ----------- ------------- ---------------- --------------- -----------------
    LNV2-Node02     20       20          28            66               256             119.5            
    LNV2-Node03     17       16          28            62               256             110              
    LNV2-Node01     11       11          28            47               256             111              
    LNV2-Node04     10       10          28            49               256             101              
    
    PASS : Azure Stack Scale Unit VM Placement Summary

Q : Le nombre de machines virtuelles déployées sur mon infrastructure Azure Stack Hub n’a pas changé, mais la capacité fluctue. Pourquoi ?

R : La mémoire disponible pour le placement des machines virtuelles dépend de plusieurs facteurs, dont la réserve du système d’exploitation hôte. Cette valeur dépend de la mémoire utilisée par les différents processus Hyper-V exécutés sur l’hôte, qui n’est pas une valeur constante.

Q : Quel état doivent avoir les machines virtuelles locataires pour consommer de la mémoire ?

R : La mémoire est consommée, non seulement par les machines virtuelles en cours d’exécution, mais aussi par toutes les machines virtuelles qui ont atterri sur la structure fabric. Cela signifie que les machines virtuelles qui ont l’état « Création en cours » ou « Échec » consomment de la mémoire. Les machines virtuelles arrêtées à partir de l’invité consomment également de la mémoire, contrairement à celles qui sont libérées par l’option d’arrêt appropriée depuis le portail, PowerShell ou l’interface CLI.

Q : J’ai une infrastructure Azure Stack Hub comportant quatre hôtes. Mon locataire a trois machines virtuelles qui consomment 56 Go de RAM (D5_v2) chacune. L’une de ces machines virtuelles est redimensionnée à 112 Go de RAM (D14_v2), et les rapports sur la mémoire disponibles dans le tableau de bord montrent un pic d’utilisation de 168 Go dans le panneau de capacité. Le redimensionnement ultérieur des deux autres machines virtuelles D5_v2 à D14_v2 a entraîné une augmentation de la RAM de 56 Go uniquement sur chacune. Pourquoi ?

R : La mémoire disponible est fonction de la réserve de résilience conservée par Azure Stack Hub. La réserve de résilience est fonction de la taille de la plus grande machine virtuelle sur le tampon Azure Stack Hub. Dans un premier temps, la machine virtuelle la plus grande sur le tampon avait une capacité de 56 Go de mémoire. Quand la machine virtuelle a été redimensionnée, la machine virtuelle la plus grande sur le tampon est passée à 112 Go de mémoire, ce qui a non seulement augmenté la mémoire utilisée par cette machine virtuelle locataire, mais également augmenté la réserve de résilience. Cette modification a entraîné une augmentation de 56 Go (augmentation de la mémoire de 56 Go à 112 Go sur la machine virtuelle locataire) ainsi qu’une augmentation de la mémoire de résilience de réserve qui est passée à 112 Go. Quand les autres machines virtuelles ont ensuite été redimensionnées, la taille de la plus grande machine virtuelle est restée à la taille de la machine virtuelle de 112 Go et par conséquent, il n’y a pas eu d’augmentation de la réserve de résilience. L’augmentation de la consommation de mémoire s’est limitée à l’augmentation de la mémoire de la machine virtuelle (56 Go).

Notes

Les exigences de planification de la capacité pour la mise en réseau sont minimes car seule la taille de l’adresse IP virtuelle publique est configurable. Pour plus d’informations sur la manière d’ajouter des adresses IP publiques à Azure Stack Hub, consultez Ajouter des adresses IP publiques.

Étapes suivantes

Apprenez-en davantage sur le Stockage Azure Stack Hub