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 :
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 :
docker swarm init
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.
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 :
docker swarm init --advertise-addr 127.0.0.1
docker service create --name nginx --replicas 3 nginx
docker service update --update-delay 10s --update-parallelism 2 --update-fail-action restart nginx
docker containers stop
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!