Maison > Opération et maintenance > exploitation et maintenance Linux > Comment utiliser Docker pour la récupération après panne de conteneur et le redémarrage automatique

Comment utiliser Docker pour la récupération après panne de conteneur et le redémarrage automatique

WBOY
Libérer: 2023-11-07 16:28:47
original
1150 Les gens l'ont consulté

Comment utiliser Docker pour la récupération après panne de conteneur et le redémarrage automatique

Docker, en tant que plate-forme de virtualisation légère basée sur la technologie des conteneurs, a été largement utilisée dans divers scénarios. Dans un environnement de production, la haute disponibilité et la récupération automatique des conteneurs en cas de panne sont cruciales. Cet article explique comment utiliser Docker pour la récupération après panne de conteneur et le redémarrage automatique, y compris des exemples de code spécifiques.

1. Configuration du redémarrage automatique du conteneur

Dans Docker, la fonction de redémarrage automatique du conteneur peut être activée en utilisant l'option --restart lors de l'exécution du conteneur. Les options courantes sont :

  • non : Ne pas redémarrer automatiquement. Options par défaut ;
  • toujours : redémarrez toujours automatiquement ;
  • en cas d'échec : redémarrez automatiquement uniquement lorsque le conteneur se ferme en raison d'un statut non-0 ;
  • sauf arrêt : redémarrez toujours automatiquement à moins d'être arrêté manuellement ;

Voici un exemple d'activation du redémarrage automatique du conteneur en utilisant l'option --restart :

docker run -d --restart always nginx

Dans cet exemple, nous démarrons un conteneur Docker nommé nginx et configurons le conteneur pour qu'il soit toujours redémarrez automatiquement via l'option --restart.

Il convient de noter que l'option --restart ne prendra effet que lorsque le conteneur se fermera en raison d'une panne. Si un conteneur est arrêté manuellement, il ne sera pas redémarré automatiquement. Si vous souhaitez activer le redémarrage automatique même après l'arrêt manuel du conteneur, vous pouvez utiliser l'option sauf arrêt.

2. Configuration de la récupération en cas de panne de conteneur

Dans Docker, la récupération en cas de panne de conteneur fait généralement référence à l'utilisation d'outils de gestion de cluster tels que Docker Swarm pour reprogrammer automatiquement les conteneurs afin de garantir la disponibilité du service. Voici un exemple qui montre comment configurer le basculement automatique dans Docker Swarm :

  1. Créez un cluster Docker Swarm :

docker swarm init

  1. Créez un service dans le cluster :

docker service create --name nginx --replicas 3 nginx

Dans cet exemple, nous créons un service appelé nginx et définissons son nombre de répliques sur 3.

  1. Activer la récupération après échec dans le service :

docker service update --update-delay 10s --update-parallelism 2 --update-failure-action restart nginx

L'option --update-delay spécifiée ici Le délai temps entre les opérations de mise à jour ; l'option --update-parallelism spécifie le nombre d'instances simultanées pour chaque mise à jour ; l'option --update-failure-action spécifie l'action à entreprendre lorsque la mise à jour échoue, nous la définissons ici pour redémarrer le conteneur. .

Il est à noter que la fonction de récupération après panne ne peut prendre effet que lors de l'utilisation d'outils de gestion de cluster tels que Docker Swarm. Si vous utilisez directement la commande docker run pour démarrer le conteneur, nous ne pouvons utiliser que l'option --restart pour redémarrer automatiquement le conteneur.

3. Exemple de code pour la récupération en cas de panne de conteneur et le redémarrage automatique

Ce qui suit est un exemple de code complet qui montre comment implémenter la récupération en cas de panne de conteneur et le redémarrage automatique à l'aide de l'option --restart et d'outils de gestion de cluster tels que Docker Swarm :

  1. Créez un cluster Docker Swarm nommé docker-demo :

docker swarm init --advertise-addr 127.0.0.1

  1. Créez un service nommé nginx dans le cluster et définissez son nombre de répliques sur 3 Chacun :

docker service create --name nginx --replicas 3 nginx

  1. Activer la récupération après échec dans le service :

docker service update --update-delay 10s --update-parallelism 2 --update-fail-action restart nginx

  1. Après avoir attendu un moment, arrêtez manuellement un conteneur :

docker containers stop

  1. Après avoir attendu un moment, vérifiez si le conteneur est automatiquement redémarré :

docker containers ls

Si le Le conteneur est automatiquement redémarré, son statut doit être en cours d'exécution.

Il convient de noter que les méthodes de mise en œuvre spécifiques de la récupération en cas de panne de conteneur et du redémarrage automatique sont différentes, et différents scénarios nécessitent la mise en œuvre de différentes méthodes. Les exemples ci-dessus sont uniquement à titre de référence et la mise en œuvre spécifique doit être ajustée en fonction de la situation réelle.

Résumé

La récupération après panne de conteneur et le redémarrage automatique sont des moyens importants pour garantir la haute disponibilité des conteneurs Docker. En configurant correctement les fonctions de redémarrage automatique et de récupération après panne de Docker, vous pouvez réduire efficacement le temps d'interruption de service provoqué par une panne de conteneur. Cet article explique comment utiliser l'option --restart et les outils de gestion de cluster tels que Docker Swarm pour implémenter les fonctions de récupération après panne de conteneur et de redémarrage automatique, et fournit des exemples de code spécifiques. J'espère que cet article pourra être utile à tout le monde lors de l'utilisation de Docker.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal