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
相关推荐
我是好小孩4 小时前
【Android】布局优化:include、merge、ViewStub以及Inflate()源码浅析
android
GISer_Jing4 小时前
2025年Flutter与React Native对比
android·flutter·react native
MasterLi80235 小时前
我的读书清单
android·linux·学习
怪兽20145 小时前
fastjson在kotlin不使用kotlin-reflect库怎么使用?
android·开发语言·kotlin
彭同学学习日志5 小时前
Kotlin Fragment 按钮跳转报错解决:Unresolved reference ‘floatingActionButton‘
android·开发语言·kotlin
Gracker7 小时前
Android Perfetto 系列 9 - CPU 信息解读
android
Gracker7 小时前
Android Perfetto 系列 8:深入理解 Vsync 机制与性能分析
android
Gracker7 小时前
Android Perfetto 系列 07 - MainThread 和 RenderThread 解读
android
Gracker7 小时前
Android Perfetto 系列 5:Android App 基于 Choreographer 的渲染流程
android
Gracker7 小时前
Android Perfetto 系列 6:为什么是 120Hz?高刷新率的优势与挑战
android