window11 wsl mysql8 错误分析:1698 - Access denied for user ‘root‘@‘kong.mshome.net‘

🚨 错误分析:1698 - Access denied for user 'root'@'kong.mshome.net'

这个错误是因为 MySQLroot 用户 使用 auth_socket 插件进行身份验证,而不是使用密码。因此,当你尝试从 远程主机 连接时,MySQL 会拒绝访问。


解决方法:修改 MySQL 的身份验证方式

你需要将 root 用户 的身份验证插件从 auth_socket 改为 mysql_native_password,以便使用密码登录。

🔧 步骤 1:登录 MySQL

WSL 终端中执行以下命令,以 root 用户 登录 MySQL:

bash 复制代码
sudo mysql

🔧 步骤 2:检查当前的身份验证插件

执行以下命令,查看 root 用户 的身份验证插件:

sql 复制代码
SELECT user, host, plugin FROM mysql.user WHERE user = 'root';

输出示例:

复制代码
+------+-----------+-------------+
| user | host      | plugin      |
+------+-----------+-------------+
| root | localhost | auth_socket |
+------+-----------+-------------+

这里你会看到 pluginauth_socket,这就是导致远程连接被拒绝的原因。


🔧 步骤 3:修改身份验证插件

执行以下命令,将 root 用户 的身份验证插件改为 mysql_native_password

sql 复制代码
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'your_password';

your_password 替换为你想设置的 root 用户密码


🔧 步骤 4:刷新权限

执行以下命令,刷新权限表:

sql 复制代码
FLUSH PRIVILEGES;

🔧 步骤 5:确认修改结果

再次执行以下查询,确认身份验证插件已修改为 mysql_native_password

sql 复制代码
SELECT user, host, plugin FROM mysql.user WHERE user = 'root';

输出示例:

复制代码
+------+-----------+-----------------------+
| user | host      | plugin                |
+------+-----------+-----------------------+
| root | localhost | mysql_native_password |
+------+-----------+-----------------------+

🔧 步骤 6:重启 MySQL 服务

执行以下命令,重启 MySQL 服务

bash 复制代码
sudo service mysql restart

🔧 步骤 7:测试远程访问

Windows 主机 中尝试使用 MySQL 客户端 连接到 WSL 中的 MySQL 服务器:

bash 复制代码
mysql -h <WSL_IP_ADDRESS> -P 3306 -u root -p

解决方案总结

错误原因 解决方法
使用 auth_socket 插件 将插件修改为 mysql_native_password
未设置远程访问权限 授予 root 用户远程访问权限

🎯 常见问题排查

问题 解决方法
连接超时 检查防火墙是否阻止 3306 端口
Access denied for user 错误 确认身份验证插件已更改为 mysql_native_password
相关推荐
雨白2 小时前
StateFlow 与 SharedFlow:在协程中管理状态与事件
android·kotlin
WAsbry4 小时前
NFC开发系列专栏 - 第三篇:无界面NFC后台服务方案
android·程序员·架构
消失的旧时光-19434 小时前
WebView 最佳封装模板(BaseWebActivity + WebViewHelper)
android·webview
WAsbry4 小时前
NFC开发系列-第一篇:NFC开发基础与实战入门
android·程序员
WAsbry4 小时前
NFC开发系列 - 第二篇:NFC企业级架构设计与最佳实践
android·程序员·架构
feibafeibafeiba5 小时前
Android 14 关于imageview设置动态padding值导致图标旋转的问题
android
tangweiguo030519876 小时前
ProcessLifecycleOwner 完全指南:优雅监听应用前后台状态
android·kotlin
介一安全7 小时前
【Frida Android】基础篇15(完):Frida-Trace 基础应用——JNI 函数 Hook
android·网络安全·ida·逆向·frida
吞掉星星的鲸鱼7 小时前
android studio创建使用开发打包教程
android·ide·android studio
陈老师还在写代码7 小时前
android studio 签名打包教程
android·ide·android studio