MySQL遇到“ Access denied for user ”问题的解决办法

1. 检查 MySQL 认证方法

  • 在 MySQL 5.7 及以上版本中,root 用户默认可能使用 auth_socket 插件而不是密码进行认证。
  • 要查看认证方法,可以通过以下命令登录 MySQL:
bash 复制代码
sudo mysql -uroot -p 

然后运行以下查询来查看 root 用户的认证方式:

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

如果你看到 auth_socket 插件与 root 用户关联,说明 root 用户使用的是 socket 认证方式。

可以修改认证方式和密码解决,注意,修改了认证方式后密码也要修改

sql 复制代码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'new_password';

2. 重置密码(如果使用密码认证)

  • 如果认证方式是基于密码的,可以通过以下步骤重置 root 用户的密码:
  1. 停止 MySQL 服务:

    bash 复制代码
    sudo systemctl stop mysql
  2. 使用跳过授权表模式启动 MySQL(不进行权限检查):

    bash 复制代码
    sudo mysqld_safe --skip-grant-tables &
  3. 登录到 MySQL:

    bash 复制代码
    mysql -u root
  4. 更新 root 用户的密码:

    bash 复制代码
    USE mysql;
    UPDATE user SET authentication_string=PASSWORD('new_password') WHERE user='root';
    FLUSH PRIVILEGES;
  5. 重新启动 MySQL 服务:

    bash 复制代码
    sudo systemctl start mysql
  6. 尝试使用新密码登录:

    bash 复制代码
    mysql -u root -p

3. 检查用户权限

  • 如果 root 用户的权限被限制,可以使用以下命令检查用户权限并进行适当调整:
bash 复制代码
SHOW GRANTS FOR 'root'@'localhost';

如果需要,可以调整权限,例如:

bash 复制代码
GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION;
FLUSH PRIVILEGES;

按照上述步骤检查和修复后,应该能够解决 Access denied 错误。

相关推荐
2301_765703147 分钟前
Python迭代器(Iterator)揭秘:for循环背后的故事
jvm·数据库·python
倔强的石头10615 分钟前
关键信息基础设施的数据库选型:高可用、全链路安全与平滑替代的技术实践
数据库·安全·金仓数据库
人道领域38 分钟前
javaWeb从入门到进阶(SpringBoot事务管理及AOP)
java·数据库·mysql
煎蛋学姐43 分钟前
SSM音乐播放软件的开发与实现7g5j0(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·javaweb 开发·前后端开发
2301_821369611 小时前
使用Python进行图像识别:CNN卷积神经网络实战
jvm·数据库·python
星空露珠1 小时前
速算24点所有题库公式
开发语言·数据库·算法·游戏·lua
m0_561359671 小时前
使用Kivy开发跨平台的移动应用
jvm·数据库·python
sheji52611 小时前
JSP基于信息安全的读书网站79f9s--程序+源码+数据库+调试部署+开发环境
java·开发语言·数据库·算法
海域云-罗鹏1 小时前
国内公司与英国总部数据中心/ERP系统互连,SD-WAN专线实操指南
大数据·数据库·人工智能
千寻技术帮2 小时前
10404_基于Web的校园网络安全防御系统
网络·mysql·安全·web安全·springboot