Maison >Opération et maintenance >Docker >Comment Docker résout le problème de l'échec du démarrage de MySQL
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!