Maison >Opération et maintenance >Docker >Comment Docker résout le problème de l'échec du démarrage de MySQL

Comment Docker résout le problème de l'échec du démarrage de MySQL

PHPz
PHPzoriginal
2023-03-31 18:20:256619parcourir

Lorsque vous utilisez Docker pour déployer MySQL, vous pouvez rencontrer un échec de démarrage. Cet article expliquera en détail comment résoudre cette situation.

1. Description du problème

Mysql est une base de données relationnelle très populaire et Docker est une technologie de conteneur. L'utilisation de Docker nous permet de déployer facilement la base de données Mysql, mais parfois le démarrage du conteneur Mysql échoue. Nous avons constaté que le démarrage a échoué lors de l'utilisation de la commande Docker suivante pour démarrer le conteneur Mysql :

docker run --name mysql -e MYSQL_ROOT_PASSWORD=mypassword -d mysql:5.7

2. Analyse du problème

Lors du démarrage du conteneur selon la commande ci-dessus, le paramètre -e spécifie la variable d'environnement, où MYSQL_ROOT_PASSWORD est le mot de passe de l'utilisateur root Mysql. mysql : 5.7 est une version miroir de la base de données Mysql. Cependant, nous rencontrons parfois un échec de démarrage du conteneur. À ce stade, nous pouvons analyser la cause de l'erreur en consultant le journal du conteneur de démarrage.

docker logs mysql

a constaté que le conteneur Mysql s'est écrasé au démarrage. Nous devons donc trouver la cause de l’erreur.

3. Résolution des problèmes

Nous pouvons résoudre ce problème en suivant les étapes suivantes :

1. Vérifiez si le conteneur est en cours d'exécution

docker ps

Si le conteneur est déjà en cours d'exécution, il nous suffit de vérifier le journal du conteneur.

2. Vérifiez le journal du conteneur

docker logs mysql

Le message d'erreur suivant peut être trouvé dans le journal :

[ERROR] [MY-012144] [InnoDB] ./ibdata1 can't be opened in read-write mode
[ERROR] [MY-012930] [InnoDB] Plugin initialization aborted with error Generic error. 
[ERROR] [MY-010334] [Server] Failed to initialize DD Storage Engine: 0
[ERROR] [MY-010020] [Server] Data Dictionary initialization failed.
[ERROR] [MY-010119] [Server] Aborting

En analysant le journal des erreurs, nous pouvons voir que la raison de l'échec du démarrage de Mysql est que le répertoire de données n'est pas accessible en écriture. Pour résoudre ce problème, nous devons trouver où se trouve le répertoire de données et définir ses autorisations sur écriture.

3. Affichez le répertoire de données du conteneur Mysql

docker inspect mysql | grep -i datadir

Dans le résultat de sortie, nous pouvons trouver le répertoire de données du conteneur Mysql, comme indiqué ci-dessous :

"DataDir": "/var/lib/mysql"

Nous devons définir ses autorisations en écriture, veuillez utiliser le commande suivante pour afficher et modifier les autorisations du répertoire :

docker exec -it mysql bash
chmod -R 777 /var/lib/mysql
exit

Ensuite, nous pouvons redémarrer le conteneur :

docker start mysql

Après les étapes ci-dessus, lorsque nous redémarrons le conteneur Mysql, il peut démarrer avec succès.

4. Résumé

Cet article propose une solution à l'échec de Docker à démarrer Mysql. Si le conteneur Mysql ne démarre pas, nous pouvons trouver la cause de l'erreur en vérifiant le journal du conteneur et la résoudre à temps.

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!

Déclaration:
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