Les utilisateurs de compte de cloud Google Cloud Platform (GCP) dans vRealize Automation peuvent configurer des équilibreurs de charge pour prendre en charge des solutions personnalisées, notamment la haute disponibilité.
Les utilisateurs de compte de cloud GCP dans vRealize Automation peuvent paramétrer plusieurs aspects de la configuration de l'équilibreur de charge pour prendre en charge des exigences spécifiques. Ces fonctionnalités peuvent prendre en charge l'infrastructure de provisionnement pour SAP NetWeaver et SAP Hana, par exemple.
Paramétrage d'une configuration d'équilibreur de charge haute disponibilité avec un compte de cloud GCP
Les utilisateurs de vRealize Automation disposant d'un compte de cloud GCP peuvent paramétrer plusieurs aspects de la configuration de l'équilibreur de charge pour prendre en charge des exigences spécifiques, telles que la haute disponibilité. Ces fonctionnalités peuvent prendre en charge l'infrastructure de provisionnement pour SAP NetWeaver et SAP Hana, par exemple.
Cette configuration vous permet de déployer différentes instances d'équilibreur de charge dans différentes zones de disponibilité. Pour paramétrer cela, vous devez configurer les composants suivants dans GCP :
- Réserver des adresses IP virtuelles
- Provisionner des contrôles de santé
- Créer une règle de pare-feu pour prendre en charge les contrôles de santé
Après avoir configuré le côté GCP, vous devez configurer les composants appropriés dans vRealize Automation, comme décrit ci-dessous :
- Créez un compte de cloud GCP si vous n'en avez pas déjà un.
- Configurez le type et le mappage d'image en fonction de votre environnement.
- Créez un profil réseau par défaut et balisez-le afin de pouvoir l'appeler à partir d'un modèle de cloud.
- Créez des zones de disponibilité de calcul et balisez-les de manière appropriée. Cela vous permet d'indiquer à vRealize Automation de provisionner des instances et des groupes d'instances à des zones de disponibilité spécifiques dans un modèle de cloud.
Une fois que vous avez configuré tous ces composants, vous pouvez accéder à l'onglet Conception de Cloud Assembly et créer un modèle de cloud. Ce modèle doit modéliser la configuration d'équilibreur de charge appropriée avec les spécifications pour le contrôle de santé ainsi que les instances et les groupes d'instances le cas échéant. À des fins de haute disponibilité, vous devez configurer plusieurs équilibreurs de charge. Le modèle de cloud doit également spécifier les machines virtuelles appropriées et les zones de disponibilité dans lesquelles elles doivent être déployées.
L'exemple de modèle de cloud suivant montre comment paramétrer une configuration d'équilibreur de charge haute disponibilité pour NetWeaver.
formatVersion: 1 inputs: {} resources: Cloud_LoadBalancer_1: type: Cloud.LoadBalancer properties: routes: - healthCheckConfiguration: healthyThreshold: 2 unhealthyThreshold: 2 timeoutSeconds: 10 intervalSeconds: 10 port: 65000 protocol: TCP protocol: TCP port: 1000 instancePort: 1000 network: ${resource.Cloud_Network_1.id} instances: - ${resource.Cloud_GCP_Machine_1.id} - ${resource.Cloud_GCP_Machine_2.id} internetFacing: false fallbackInstanceGroupsByInstanceNames: - ${resource.Cloud_GCP_Machine_2.resourceName} Cloud_LoadBalancer_2: type: Cloud.LoadBalancer properties: routes: - healthCheckConfiguration: healthyThreshold: 2 unhealthyThreshold: 2 timeoutSeconds: 10 intervalSeconds: 10 port: 65000 protocol: TCP protocol: TCP port: 1000 instancePort: 1000 network: ${resource.Cloud_Network_1.id} instances: - ${resource.Cloud_GCP_Machine_1.id} - ${resource.Cloud_GCP_Machine_2.id} internetFacing: false useInstanceGroupsFrom: ${resource.Cloud_LoadBalancer_1.resourceName} fallbackInstanceGroupsByInstanceNames: - ${resource.Cloud_GCP_Machine_1.resourceName} Cloud_GCP_Machine_2: type: Cloud.GCP.Machine properties: image: image flavor: flavor networks: - network: ${resource.Cloud_Network_1.id} constraints: - tag: zone-b Cloud_Network_1: type: Cloud.Network properties: networkType: existing constraints: - tag: default Cloud_GCP_Machine_1: type: Cloud.GCP.Machine properties: image: image flavor: flavor networks: - network: ${resource.Cloud_Network_1.id} constraints: - tag: zone-a
Options de configuration d'équilibreur de charge supplémentaires
Les utilisateurs de vRealize Automation peuvent, au moyen de configurations de modèle de cloud, configurer les aspects supplémentaires suivants de la configuration de l'équilibreur de charge.
- Partager les groupes d'instances entre les équilibreurs de charge
- Configurer les groupes d'instances de basculement
- Configurer les équilibreurs de charge pour accepter le trafic sur tous les ports
Partager des groupes d'instances
Pour partager des groupes d'instances entre les équilibreurs de charge, les utilisateurs doivent le déclarer explicitement dans le Blueprint. Étant donné qu'il n'y a pas d'accès direct aux groupes d'instances dans le Blueprint, les clients doivent utiliser la propriété useInstanceGroupsFrom
. vRealize Automation provisionnera ainsi le premier équilibreur de charge et réutilisera les groupes d'instances dans les autres équilibreurs de charge.
L'exemple suivant illustre la manière dont vous pouvez utiliser un modèle de cloud pour configurer deux équilibreurs de charge dans lesquels le second utilise les groupes d'instances du premier :
Cloud_LoadBalancer_1: type: Cloud.LoadBalancer properties: routes: - healthCheckConfiguration: healthyThreshold: 2 unhealthyThreshold: 2 timeoutSeconds: 10 intervalSeconds: 10 port: 65000 protocol: TCP protocol: TCP network: ${resource.Cloud_Network_1.id} instances: - ${resource.Cloud_GCP_Machine_1.id} - ${resource.Cloud_GCP_Machine_2.id} internetFacing: false Cloud_LoadBalancer_2: type: Cloud.LoadBalancer properties: routes: - healthCheckConfiguration: healthyThreshold: 2 unhealthyThreshold: 2 timeoutSeconds: 10 intervalSeconds: 10 port: 65000 protocol: TCP protocol: TCP network: ${resource.Cloud_Network_1.id} instances: - ${resource.Cloud_GCP_Machine_1.id} - ${resource.Cloud_GCP_Machine_2.id} internetFacing: false useInstanceGroupsFrom: ${resource.Cloud_LoadBalancer_1.resourceName}
Configurer les groupes d'instances de basculement
Pour configurer des groupes d'instances de basculement pour chaque équilibreur de charge GCP, vous devez le déclarer explicitement dans le modèle de cloud. Du fait qu'il n'existe pas d'accès direct aux groupes d'instances dans le modèle, vous devez utiliser la propriété failoverInstanceGroupsByInstanceNames
qui indique à vRealize Automation de rechercher le groupe d'instances par machine qui est contenue dans ce groupe d'instances.
L'exemple suivant illustre la configuration d'un équilibreur de charge qui dispose d'un groupe principal et d'un groupe d'instances de basculement :
Cloud_LoadBalancer_1: type: Cloud.LoadBalancer properties: routes: - healthCheckConfiguration: healthyThreshold: 2 unhealthyThreshold: 2 timeoutSeconds: 10 intervalSeconds: 10 port: 65000 protocol: TCP protocol: TCP network: ${resource.Cloud_Network_1.id} instances: - ${resource.Cloud_GCP_Machine_1.id} - ${resource.Cloud_GCP_Machine_2.id} internetFacing: false failoverInstanceGroupsByInstanceNames: - ${resource.Cloud_GCP_Machine_2.resourceName}
Configurer pour le trafic sur tous les ports
Pour configurer un équilibreur de charge afin qu'il accepte le trafic sur tous les ports, vous pouvez omettre la propriété de port de la configuration de route. Vous pouvez afficher un exemple de modèle de cloud qui utilise les trois fonctionnalités récemment créées et qui provisionne l'infrastructure pour cette configuration https://cloud.google.com/solutions/sap/docs/netweaver-ha-config-rhel#configure_the_failover_support
formatVersion: 1 inputs: {} resources: Cloud_LoadBalancer_1: type: Cloud.LoadBalancer properties: routes: - healthCheckConfiguration: healthyThreshold: 2 unhealthyThreshold: 2 timeoutSeconds: 10 intervalSeconds: 10 port: 65000 protocol: TCP protocol: TCP network: ${resource.Cloud_Network_1.id} instances: - ${resource.Cloud_GCP_Machine_1.id} - ${resource.Cloud_GCP_Machine_2.id} internetFacing: false failoverInstanceGroupsByInstanceNames: - ${resource.Cloud_GCP_Machine_2.resourceName} address: 10.132.0.72 Cloud_LoadBalancer_2: type: Cloud.LoadBalancer properties: routes: - healthCheckConfiguration: healthyThreshold: 2 unhealthyThreshold: 2 timeoutSeconds: 10 intervalSeconds: 10 port: 65000 protocol: TCP protocol: TCP network: ${resource.Cloud_Network_1.id} instances: - ${resource.Cloud_GCP_Machine_1.id} - ${resource.Cloud_GCP_Machine_2.id} internetFacing: false useInstanceGroupsFrom: ${resource.Cloud_LoadBalancer_1.resourceName} failoverInstanceGroupsByInstanceNames: - ${resource.Cloud_GCP_Machine_1.resourceName} address: 10.132.0.64 Cloud_GCP_Machine_2: type: Cloud.GCP.Machine properties: image: image flavor: flavor networks: - network: ${resource.Cloud_Network_1.id} constraints: - tag: zone-c Cloud_Network_1: type: Cloud.Network properties: networkType: existing constraints: - tag: default Cloud_GCP_Machine_1: type: Cloud.GCP.Machine properties: image: image flavor: flavor networks: - network: ${resource.Cloud_Network_1.id} constraints: - tag: zone-b