Vérification de la préparation de MySQL dans les conteneurs Docker
Lors du déploiement de plusieurs conteneurs Docker, il est essentiel de déterminer la disponibilité des services avant de procéder à d'autres tâches. Les conteneurs MySQL sont particulièrement sensibles aux problèmes de timing en raison de leurs scripts d'initialisation. Cela peut entraîner des erreurs si les scripts tentent d'accéder à la base de données avant qu'elle ne soit complètement prête.
Pour relever ce défi, une alternative à l'utilisation de Bash sleep consiste à exploiter l'utilitaire mysqladmin, inclus dans le package mysql-client. . En combinant mysqladmin avec une boucle d'attente, vous pouvez vérifier de manière fiable la préparation de MySQL.
Voici comment l'implémenter :
while ! mysqladmin ping -h"$DB_HOST" --silent; do sleep 1 done
Dans ce script, la commande ping tente d'établir une connexion à MySQL et renvoie un statut non nul si le service n'est pas encore disponible. L'option --silent supprime la sortie, ce qui la rend idéale pour les vérifications répétitives.
En incorporant cette boucle d'attente, vous pouvez garantir que les scripts suivants ne s'exécuteront qu'une fois que MySQL sera entièrement opérationnel et prêt à accepter les requêtes, éliminant ainsi les erreurs potentielles. et améliorer votre flux de déploiement.
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!