MySQL 8.0升级后老客户端连接报错ERROR 1251,因默认认证插件改为caching_sha2_password;需对每个现有用户执行ALTER USER ... IDENTIFIED WITH mysql_native_password修改认证方式,而非仅配置default_authentication_plugin。MySQL 8.0 升级后连接报错 ERROR 1251: Client does not support authentication protocol这是最典型的症状:老客户端(比如 MySQL 5.7 客户端、某些 PHP 扩展、旧版 Navicat 或 DBeaver)连不上新 MySQL 8.0+ 实例,日志里明确提示不支持认证协议。根本原因是 MySQL 8.0 默认改用 caching_sha2_password 插件,而旧客户端只认 mysql_native_password。别急着改全局 default_authentication_plugin ------ 它只影响新建用户的默认插件,对已有用户无效真正要动的是具体用户的认证方式,不是服务端开关如果用 root 连不进,得先用 --skip-grant-tables 启动临时绕过验证,再改用户插件给指定用户切换回 mysql_native_password 认证必须登录 MySQL(哪怕用临时免密方式),对每个需要兼容的用户执行 ALTER USER。这不是配置文件开关,是数据字典层面的修改。确认当前用户用的什么插件:SELECT user, host, plugin FROM mysql.user WHERE user = 'your_user';切换认证方式:ALTER USER 'your_user'@'%' IDENTIFIED WITH mysql_native_password BY 'your_password';强制重载权限:FLUSH PRIVILEGES;注意 @'%' 要和创建用户时的 host 完全一致,'localhost' 和 '127.0.0.1' 是两个不同用户my.cnf 里设 default_authentication_plugin 没用?设了 default_authentication_plugin = mysql_native_password 确实能让新 CREATE USER 不带 IDENTIFIED WITH 时默认用它,但不影响已存在用户,也不解决老客户端连不上 root 的问题。很多人配了却没效果,就是卡在这儿。 WisPaper 复旦大学研发的AI学术搜索工具,5分钟内筛选1000篇论文
相关推荐
zopple2 小时前
四大编程语言对比:PHP、Python、Java与易语言lhbian2 小时前
PHP、C++和C语言对比:哪个更适合你?NotFound4862 小时前
Flask项目目录怎么分_MVC架构在Flask应用中的常见目录树小陈phd2 小时前
电商智能客服智能体——基于LangChain的电商智能客服 Agent 架构设计与实现(二)2401_897190552 小时前
JavaScript对象浅拷贝:Object-assign的合并规则Shorasul2 小时前
如何用 fill 配合 map 初始化一个填充了不同对象的数组weixin_586061462 小时前
golang如何使用go-redis客户端_golang go-redis客户端使用教程逍遥德2 小时前
Java 锁(线程间)和数据库锁(事务间)对比详解m0_377618232 小时前
C# 异步范围Asynchronous Disposal方法 C# await using如何使用