Skip to main content

Remplacement d’un nœud de cluster

Si un nœud échoue dans un cluster GitHub Enterprise Server, ou si vous souhaitez ajouter un nouveau nœud avec plus de ressources, marquez les nœuds à remplacer comme hors connexion et ajoutez le nouveau nœud.

Qui peut utiliser cette fonctionnalité ?

GitHub détermine l’éligibilité au clustering et doit activer la configuration de la licence de votre instance. Le clustering nécessite une planification minutieuse et une surcharge administrative supplémentaire. Pour plus d’informations, consultez « À propos du clustering ».

À propos du remplacement de nœuds de cluster GitHub Enterprise Server

Vous pouvez remplacer un nœud fonctionnel dans un cluster GitHub Enterprise Server ou remplacer un nœud qui a échoué de manière inattendue.

Après avoir remplacé un nœud, votre instance GitHub Enterprise Server ne distribue pas automatiquement les travaux sur le nouveau nœud. Vous pouvez forcer votre instance à équilibrer les travaux entre les nœuds. Pour plus d’informations, consultez « Rééquilibrage des charges de travail de cluster ».

Avertissement : Pour éviter les conflits, ne réutilisez pas un nom d’hôte précédemment attribué à un nœud du cluster.

Remplacement d’un nœud fonctionnel

Vous pouvez remplacer un nœud fonctionnel existant dans votre cluster. Par exemple, vous voudrez peut-être fournir à une machine virtuelle des ressources de processeur, de mémoire ou de stockage supplémentaires.

Pour remplacer un nœud fonctionnel, installez l’appliance GitHub Enterprise Server sur une nouvelle machine virtuelle, configurez une adresse IP, ajoutez le nouveau nœud au fichier de configuration du cluster, initialisez le cluster et appliquez la configuration, puis mettez le nœud que vous avez remplacé hors connexion.

Remarque : si vous remplacez le nœud MySQL principal, consultez « Remplacement du nœud MySQL principal ».

  1. Provisionnez et installez GitHub Enterprise Server avec un nom d’hôte unique sur le nœud de remplacement.

  2. En utilisant l’interpréteur de commandes d’administration ou DHCP, configurez uniquement l’adresse IP du nœud de remplacement. Ne configurez pas d’autres paramètres.

  3. Pour ajouter le nœud de remplacement nouvellement provisionné, sur n’importe quel nœud, modifiez le fichier cluster.conf pour supprimer le nœud ayant échoué et ajouter le nœud de remplacement. Par exemple, ce fichier cluster.conf modifié remplace ghe-data-node-3 par le nœud nouvellement provisionné, ghe-replacement-data-node-3 :

    [cluster "ghe-replacement-data-node-3"]
      hostname = ghe-replacement-data-node-3
      ipv4 = 192.168.0.7
      # ipv6 = fd12:3456:789a:1::7
      git-server = true
      pages-server = true
      mysql-server = true
      elasticsearch-server = true
      redis-server = true
      memcache-server = true
      metrics-server = true
      storage-server = true
    
  4. À partir de l’interpréteur de commandes d’administration du nœud avec le cluster.conf modifié, exécutez ghe-cluster-config-init. Cette commande initialise le nœud nouvellement ajouté dans le cluster.

  5. À partir du même nœud, exécutez ghe-cluster-config-apply. Cette commande valide le fichier de configuration, le copie sur chaque nœud du cluster et configure chaque nœud en fonction du fichier cluster.conf modifié.

  6. Pour mettre hors connexion le nœud que vous remplacez à partir du nœud MySQL principal de votre cluster, exécutez la commande suivante.

    ghe-remove-node NODE-HOSTNAME
    

    Cette commande évacue les données de tous les services de données s’exécutant sur le nœud, marque le nœud comme hors connexion dans votre configuration et arrête le trafic acheminé vers le nœud. Pour plus d’informations, consultez « Utilitaires de ligne de commande ».

Remplacement d’un nœud en cas d’urgence

Vous pouvez remplacer un nœud défaillant dans votre cluster. Par exemple, un problème logiciel ou matériel peut affecter la disponibilité d’un nœud.

Remarque : si vous remplacez le nœud MySQL principal, consultez « Remplacement du nœud MySQL principal ».

Pour remplacer un nœud en cas d’urgence, vous allez mettre le nœud défaillant hors connexion, ajouter votre nœud de remplacement au cluster, puis exécuter des commandes pour supprimer les références aux services de données sur le nœud supprimé.

  1. Pour supprimer le nœud qui rencontre des problèmes du cluster à partir du nœud MySQL principal de votre cluster, exécutez la commande suivante. Remplacez NODE-HOSTNAME par le nom d’hôte du nœud que vous mettez hors connexion.

    ghe-remove-node --no-evacuate NODE-HOSTNAME 
    

    Cette commande marque le nœud comme étant hors connexion dans votre configuration et arrête le trafic acheminé vers le nœud. Vous pouvez exécuter cette commande en mode no-evacuate maintenant, car, plus loin dans cette procédure, vous allez exécuter des commandes qui indiquent aux services de données sur le nœud de copier tous les réplicas sur les autres nœuds disponibles dans le cluster. Pour plus d’informations, consultez « Utilitaires de ligne de commande ».

  2. Ajoutez votre nœud de remplacement au cluster.

    1. Provisionnez et installez GitHub Enterprise Server avec un nom d’hôte unique sur le nœud de remplacement.
  3. En utilisant l’interpréteur de commandes d’administration ou DHCP, configurez uniquement l’adresse IP du nœud de remplacement. Ne configurez pas d’autres paramètres.

    1. Pour ajouter le nœud de remplacement nouvellement provisionné, sur n’importe quel nœud, modifiez le fichier cluster.conf pour ajouter le nœud de remplacement. Par exemple, ce fichier cluster.conf modifié ajoute le nœud nouvellement provisionné ghe-replacement-data-node-3 :

      [cluster "ghe-replacement-data-node-3"]
        hostname = ghe-replacement-data-node-3
        ipv4 = 192.168.0.7
        # ipv6 = fd12:3456:789a:1::7
        git-server = true
        pages-server = true
        mysql-server = true
        elasticsearch-server = true
        redis-server = true
        memcache-server = true
        metrics-server = true
        storage-server = true
      
    2. À partir de l’interpréteur de commandes d’administration du nœud avec le cluster.conf modifié, exécutez ghe-cluster-config-init. Cette commande initialise le nœud nouvellement ajouté dans le cluster.

  4. À partir du même nœud, exécutez ghe-cluster-config-apply. Cette commande valide le fichier de configuration, le copie sur chaque nœud du cluster et configure chaque nœud en fonction du fichier cluster.conf modifié.

  5. Supprimez les références aux services de données sur le nœud que vous avez supprimé.

    1. Recherchez l’UUID du nœud que vous avez supprimé. Pour rechercher l’UUID, exécutez la commande suivante, en remplaçant HOSTNAME par le nom d’hôte du nœud. Vous aurez besoin de cet UUID lors de l’étape suivante.

      ghe-config cluster.HOSTNAME.uuid
      
    2. Pour supprimer des références aux services de données, exécutez les commandes suivantes. Remplacez UUID par l’UUID du nœud.

      Ces commandes indiquent à chaque service que le nœud est définitivement supprimé. Les services recréent tous les réplicas contenus dans le nœud sur les nœuds disponibles dans le cluster.

      Remarque : ces commandes peuvent entraîner une charge accrue sur le serveur pendant que les données sont rééquilibrées entre les réplicas.

      Pour le service git-server (utilisé pour les données du référentiel) :

      ghe-spokesctl server destroy git-server-UUID
      

      Pour le service pages-server (utilisé pour les versions de sites GitHub Pages) :

      ghe-dpages remove pages-server-UUID
      

      Pour le service storage-server (utilisé pour les données LFS Git, les images avatar, les pièces jointes de fichiers et les archives de publication) :

      ghe-storage destroy-host storage-server-UUID --force
      
  6. Si vous le souhaitez, supprimez l’entrée du nœud supprimé dans votre fichier cluster.conf. Cela permet de conserver votre fichier cluster.conf organisé et de gagner du temps pendant les exécutions ultérieures config-apply.

    1. Pour supprimer l’entrée du fichier, exécutez la commande suivante, en remplaçant HOSTNAME par le nom d’hôte du nœud supprimé.

      ghe-config --remove-section "cluster.HOSTNAME"
      
    2. Pour copier la configuration vers d’autres nœuds du cluster à partir du shell d’administration du nœud où vous avez modifié cluster.conf, exécutez ghe-cluster-config-apply.

Remplacement du nœud MySQL principal

Pour fournir des services de base de données, votre cluster nécessite un nœud MySQL principal et au moins un nœud MySQL secondaire. Pour plus d’informations, consultez « À propos des nœuds de cluster ».

Si vous voulez fournir la machine virtuelle à votre nœud MySQL principal doté de plus de ressources ou si le nœud échoue, vous pouvez remplacer le nœud. Pour réduire le temps d’arrêt, ajoutez le nouveau nœud à votre cluster, répliquez les données MySQL, puis promouvez le nœud. Un certain temps d’arrêt est nécessaire pendant la promotion.

  1. Provisionnez et installez GitHub Enterprise Server avec un nom d’hôte unique sur le nœud de remplacement.

  2. En utilisant l’interpréteur de commandes d’administration ou DHCP, configurez uniquement l’adresse IP du nœud de remplacement. Ne configurez pas d’autres paramètres.

  3. Pour vous connecter à votre instance GitHub Enterprise Server, connectez-vous avec SSH à l’un des nœuds de votre cluster. À partir de votre station de travail, exécutez la commande suivante. Remplacez HOSTNAME par le nom d’hôte du nœud. Pour plus d’informations, consultez « Accès à l’interpréteur de commandes d’administration (SSH) ».

    Shell
    ssh -p 122 admin@HOSTNAME
    
  4. Ouvrez le fichier de configuration de groupement sur /data/user/common/cluster.conf dans un éditeur de texte. Par exemple, vous pouvez utiliser Vim. Créez une sauvegarde du fichier cluster.conf avant de modifier le fichier.

    Shell
    sudo vim /data/user/common/cluster.conf
    
  5. Le fichier de configuration du cluster répertorie chaque nœud sous un titre [cluster "HOSTNAME"]. Ajoutez un nouveau titre pour le nœud et entrez les paires clé-valeur pour la configuration, en remplaçant les espaces réservés par des valeurs réelles.

    • Veillez à inclure la mysql-server = true paire clé-valeur.
    • La section suivante est un exemple et la configuration de votre nœud peut être différente.
    ...
    [cluster "HOSTNAME"]
      hostname = HOSTNAME
      ipv4 = IPV4-ADDRESS
      # ipv6 = IPV6-ADDRESS
      consul-datacenter = PRIMARY-DATACENTER
      datacenter = DATACENTER
      mysql-server = true
      redis-server = true
      ...
    ...
    
  6. À partir de l’interpréteur de commandes d’administration du nœud avec le cluster.conf modifié, exécutez ghe-cluster-config-init. Cette commande initialise le nœud nouvellement ajouté dans le cluster.

  7. À partir de l’interpréteur de commandes d’administration du nœud où vous avez modifié cluster.conf, exécutez ghe-cluster-config-apply. Cette commande valide le fichier de configuration, le copie sur chaque nœud du cluster et marque le nœud comme étant hors connexion.

  8. Attendez la fin de la réplication MySQL. Pour surveiller la réplication MySQL à partir de n’importe quel nœud du cluster, exécutez ghe-cluster-status -v.

    Peu de temps après l’ajout du nœud au cluster, il est possible qu’une erreur sur l’état de réplication s’affiche pendant que la réplication se rattrape. La réplication peut prendre des heures selon la charge de l’instance et de la dernière fois que l’instance a généré une valeur initiale de base de données.

  9. Pendant votre fenêtre de maintenance planifiée, activez le mode maintenance. Pour plus d’informations, consultez « Activation et planification du mode de maintenance ».

  10. Vérifiez que la réplication MySQL est terminée à partir de n’importe quel nœud du cluster en exécutant ghe-cluster-status -v.

    Avertissement : si vous n’attendez pas la fin de la réplication MySQL, vous risquez de perdre des données sur votre instance.

  11. Pour définir le nœud principal MySQL actuel en mode lecture seule, exécutez la commande suivante à partir des nœuds de l’instance.

    Shell
    echo "SET GLOBAL super_read_only = 1;" | sudo mysql
    
  12. Attendez que les identificateurs de transaction globaux (GTID) définis sur les nœuds MySQL principaux et secondaires soient identiques. Pour vérifier les GTID, exécutez la commande suivante à partir de l’un des nœuds de l’instance.

    Shell
    ghe-cluster-each -r mysql -- 'echo "SELECT @@global.gtid_executed;" | sudo mysql'
    
  13. Une fois que les GTID sur les nœuds MySQL principaux et secondaires correspondent, mettez à jour la configuration du cluster en ouvrant le fichier de configuration du cluster à /data/user/common/cluster.conf dans un éditeur de texte.

    • Créez une sauvegarde du fichier cluster.conf avant de modifier le fichier.
    • Dans la section de niveau supérieur [cluster], supprimez le nom d’hôte du nœud que vous avez remplacé de la paire clé-valeur mysql-master, puis affectez le nouveau nœud à la place. Si le nouveau nœud est également un nœud Redis principal, ajustez la paire clé-valeur redis-master.
    [cluster]
      mysql-master = NEW-NODE-HOSTNAME
      redis-master = NEW-NODE-HOSTNAME
      primary-datacenter = primary
    ...
    
  14. À partir de l’interpréteur de commandes d’administration du nœud où vous avez modifié cluster.conf, exécutez ghe-cluster-config-apply. Cette commande valide le fichier de configuration, le copie sur chaque nœud du cluster et marque le nœud comme étant hors connexion.

  15. Vérifiez l’état de la réplication MySQL à partir de n’importe quel nœud du cluster en exécutant ghe-cluster-status -v.

  16. Si la réplication MySQL est terminée, à partir de n’importe quel nœud du cluster, désactivez le mode de maintenance. Pour plus d’informations, consultez « Activation et planification du mode de maintenance ».