Maison >base de données >tutoriel mysql >Pourquoi un « accès refusé » se produit-il pour l'utilisateur racine MySQL même lorsque MYSQL_ROOT_PASSWORD est défini dans Docker ?

Pourquoi un « accès refusé » se produit-il pour l'utilisateur racine MySQL même lorsque MYSQL_ROOT_PASSWORD est défini dans Docker ?

DDD
DDDoriginal
2024-12-20 08:20:11404parcourir

Why Does

MySQL_ROOT_PASSWORD est défini, mais l'accès est refusé pour l'utilisateur 'root'@'localhost' (en utilisant le mot de passe : OUI)

Dans les environnements MySQL dockerisés , la définition de la variable d'environnement MYSQL_ROOT_PASSWORD n'est pas suffisante pour garantir l'accès à la base de données. En effet, l'image n'initialisera pas une nouvelle base de données si le volume db_data contient déjà une installation existante.

Dépannage :

  1. Vérifiez si une la base de données est déjà initialisée dans le volume db_data : Si vous avez démarré le conteneur avec un volume préexistant, les variables d'environnement n'auront aucun effet et la base de données ne sera pas initialisée.
  2. Supprimez le volume db_data pour forcer l'initialisation :

    • Exécutez docker-compose down -v pour supprimer l'existant volume.
    • Exécutez docker-compose up -d pour démarrer le conteneur avec un nouveau volume et initialiser le base de données.
  3. Convertir en support de liaison si vous le souhaitez :

    • Après avoir initialisé la base de données, vous pouvez convertissez le volume en un montage lié en modifiant la section des volumes dans docker-compose.yml à :

      volumes:
         - /host/path/to/db_data:/var/lib/mysql
    • Supprimer le contenu de l'emplacement de montage de liaison avant de démarrer le conteneur : rm -rf /host/path/to/db_data/*
  4. Vérifiez d'autres problèmes potentiels :

    • Assurez-vous que le La variable MYSQL_ROOT_PASSWORD est définie correctement.
    • Vérifiez les paramètres du pare-feu pour vous assurer que le port 3306 est ouvert.
    • Vérifiez que le service MySQL est exécuté dans le conteneur.

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