ユーザー 'root'@'localhost' のアクセスが拒否されました (パスワード使用: YES) - 権限がありませんか? 質問する

ユーザー 'root'@'localhost' のアクセスが拒否されました (パスワード使用: YES) - 権限がありませんか? 質問する

このエラーが継続的に発生します。

私は mySQL Workbench を使用していますが、ルートのスキーマ権限が null であることがわかりました。権限はまったくありません。

私のサーバーが使用されているプラ​​ットフォーム全体で問題が発生しており、これは突然の問題です。

[email protected]には多くのアクセス権があるようですが、私はそのユーザーとしてログインしていますが、とにかく localhost に割り当てられるだけです。localhost には権限がありません。

FLUSH HOSTS、、などのいくつかのことを試しましたFLUSH PRIVILEGESが、それらやインターネットからは成功が見つかりませんでした。

どうすればルート アクセスを回復できますか? 周りを見渡すと、みんなが「アクセス権がある」ことを期待しているのに、私にはアクセス権がないので、コマンド ラインなどにアクセスできず、GRANT自分自身も何もできないので、イライラします。

実行すると、SHOW GRANTS FOR root次のような結果が返されます:

エラー コード: 1141。ホスト '%' 上のユーザー 'root' に定義された権限はありません

ベストアンサー1

MySql 5.7 以降で同じ問題が発生する場合:

Access denied for user 'root'@'localhost'

これは、MySql 5.7 ではデフォルトでソケットによる接続が許可されているためです。つまり、 で接続するだけですsudo mysql。sql を実行すると:

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

すると、次のようになります:

+------------------+-------------------------------------------+-----------------------+-----------+
| 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)

ルートとパスワードによる接続を許可するには、次のコマンドでテーブルの値を更新します。

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

次に、select コマンドを再度実行すると、変更されたことがわかります。

+------------------+-------------------------------------------+-----------------------+-----------+
| 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)

以上です。sudo mysql_secure_installationコマンドを実行して完了したら、このプロセスを実行できます。

mariadbの場合は、

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

パスワードを設定します。詳細はhttps://mariadb.com/kb/en/set-password/をご覧ください。

おすすめ記事