当前位置: 首页 > article >正文

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:

sudo mysql

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

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

SELECT user, host, plugin FROM mysql.user WHERE user = 'root';

输出示例:

+------+-----------+-------------+
| user | host      | plugin      |
+------+-----------+-------------+
| root | localhost | auth_socket |
+------+-----------+-------------+

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


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

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

ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'your_password';

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


🔧 步骤 4:刷新权限

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

FLUSH PRIVILEGES;

🔧 步骤 5:确认修改结果

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

SELECT user, host, plugin FROM mysql.user WHERE user = 'root';

输出示例:

+------+-----------+-----------------------+
| user | host      | plugin                |
+------+-----------+-----------------------+
| root | localhost | mysql_native_password |
+------+-----------+-----------------------+

🔧 步骤 6:重启 MySQL 服务

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

sudo service mysql restart

🔧 步骤 7:测试远程访问

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

mysql -h <WSL_IP_ADDRESS> -P 3306 -u root -p

解决方案总结

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

🎯 常见问题排查

问题解决方法
连接超时检查防火墙是否阻止 3306 端口
Access denied for user 错误确认身份验证插件已更改为 mysql_native_password

http://www.kler.cn/a/467142.html

相关文章:

  • wordpress右侧浮动咨询台插件
  • (leetcode算法题)384. 打乱数组 398. 随机数索引
  • 【2025年最新】OpenWrt 更换国内源的指南(图形界面版)
  • 123.【C语言】数据结构之快速排序挖坑法和前后指针法
  • QT----------QT Data Visualzation
  • 为什么HTTP请求后面有时带一个sign参数(HTTP请求签名校验)
  • vue3 ui组件子组件封装v-model绑定props modelValue
  • 使用SSH建立内网穿透,能够访问内网的web服务器
  • 使用Docker部署最新版JupyterHub
  • 如何利用群晖NAS实现远程访问你的网页版Linux虚拟桌面环境
  • [gcc]代码演示-O使用场景
  • SQL中聚类后字段数据串联字符串方法研究
  • kernel32.dll动态链接库报错要怎解决?详细解析kernel32.dll文件缺失解决方案
  • 什么是 C++ 的序列化?
  • 【一文解析】新能源汽车VCU电控开发——能量回收模块
  • STM32-笔记23-超声波传感器HC-SR04
  • kubernets基础入门
  • 基于STM32的热带鱼缸控制系统的设计
  • 大模型数据采集和预处理:把所有数据格式,word、excel、ppt、jpg、pdf、表格等转为数据
  • 高清监控视频的管理与展示:从摄像头到平台的联接过程
  • 呼叫中心中间件实现IVR进入排队,判断排队超时播放提示音
  • Git快速入门(一)·Git软件的安装以及GitHubDesktop客户端的安装
  • 装饰器模式详解
  • clickhouse Cannot execute replicated DDL query, maximum retries exceeded报错解决
  • Android 14.0 系统限制上网系列之iptables用IOemNetd实现app上网黑名单的实现
  • 行为模式4.观察者模式------消息推送