recherche

Maison  >  Questions et réponses  >  le corps du texte

Accès refusé pour l'utilisateur 'root'@'localhost' - Autorisations insuffisantes ?

<p>Je reçois toujours cette erreur. <br /><br />J'utilise MySQL Workbench et d'après ce que j'ai trouvé, les autorisations de l'utilisateur root semblent vides. Aucune autorisation du tout. <br /><br />Je rencontre des problèmes avec root sur plusieurs plates-formes et cela dure depuis longtemps. <br /><br />root@127.0.0.1 semble avoir de nombreuses autorisations, mais lorsque je me connecte en tant que root, il attribue simplement les autorisations à l'ordinateur local - l'ordinateur local n'a aucune autorisation. <br /><br />J'ai essayé FLUSH HOSTS, FLUSH PRIVILEGES et d'autres méthodes, mais aucune n'a réussi. <br /><br />J'ai besoin d'un accès root. Je suis tellement frustré parce que lorsque je suis avec des gens qui semblent s'attendre à ce que j'y ait accès, je n'y ai en fait pas accès, donc je ne peux pas accéder à la ligne de commande ni faire quoi que ce soit, et je ne peux m'accorder aucune autorisation. . <br /><br />Lors de l'exécution de SHOW GRANTS FOR root, j'obtiens le retour suivant : </p><p><code></code></p> <blockquote> <p>Code d'erreur : 1141. Aucune autorisation de ce type n'est définie pour l'utilisateur « root » sur hôte '%'</p> </blockquote><p><br /></p>
P粉826283529P粉826283529473 Il y a quelques jours517

répondre à tous(2)je répondrai

  • P粉864594965

    P粉8645949652023-08-08 13:46:16

    Si vous rencontrez ce problème dans MySQL 5.7.+ :

    Access denied for user 'root'@'localhost'

    Étant donné que MySQL 5.7 autorise les connexions via des sockets par défaut, cela signifie que vous devez uniquement vous connecter à MySQL avec les privilèges d'administrateur.

    SELECT user,authentication_string,plugin,host FROM mysql.user;

    Alors tu vois

    +------------------+-------------------------------------------+-----------------------+-----------+
    | user             | authentication_string                     | plugin                | host      |
    +------------------+-------------------------------------------+-----------------------+-----------+
    | root             |                                           | auth_socket           | localhost |
    | mysql.session    | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | mysql_native_password | localhost |
    | mysql.sys        | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | mysql_native_password | localhost |
    | debian-sys-maint | *497C3D7B50479A812B89CD12EC3EDA6C0CB686F0 | mysql_native_password | localhost |
    +------------------+-------------------------------------------+-----------------------+-----------+
    4 rows in set (0.00 sec)

    Autoriser la connexion avec les droits d'administrateur et la saisie d'un mot de passe, puis mettre à jour les valeurs dans le tableau via la commande :

    ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'Current-Root-Password';
    FLUSH PRIVILEGES;

    Ensuite, exécutez à nouveau la commande select et vous verrez qu'elle a changé :

    +------------------+-------------------------------------------+-----------------------+-----------+
    | user             | authentication_string                     | plugin                | host      |
    +------------------+-------------------------------------------+-----------------------+-----------+
    | root             | *2F2377C1BC54BE827DC8A4EE051CBD57490FB8C6 | mysql_native_password | localhost |
    | mysql.session    | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | mysql_native_password | localhost |
    | mysql.sys        | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | mysql_native_password | localhost |
    | debian-sys-maint | *497C3D7B50479A812B89CD12EC3EDA6C0CB686F0 | mysql_native_password | localhost |
    +------------------+-------------------------------------------+-----------------------+-----------+
    4 rows in set (0.00 sec)

    Alors ça y est. Après avoir terminé la commande sudo mysql_secure_installation, vous pouvez exécuter la procédure suivante.

    Pour mariadb, utilisez :


    SET PASSWORD FOR 'root'@'localhost' = PASSWORD('manager');

    Ensuite, il est temps de définir un mot de passe. Pour plus d'informations, consultez https://mariadb.com/kb/en/set-password/.

    répondre
    0
  • P粉647504283

    P粉6475042832023-08-08 09:12:02

    Instructions pour utiliser la réinitialisation du mot de passe - mais au lieu de réinitialiser le mot de passe, forcez l'insertion d'un enregistrement dans la table mysql.user


    INSERT INTO mysql.user (Host, User, Password) VALUES ('%', 'root', password('YOURPASSWORD'));
    GRANT ALL ON *.* TO 'root'@'%' WITH GRANT OPTION;

    répondre
    0
  • Annulerrépondre