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篇论文
相关推荐
星云穿梭3 小时前
用Python写一个带图形界面的学生管理系统——完整教程金銀銅鐵3 小时前
用 Pygame 实现 15 puzzle倔强的石头_8 小时前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战黄忠9 小时前
大模型之LangGraph技术体系冬奇Lab21 小时前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLitehboot21 小时前
AI工程师第二课 - 数据处理用户8356290780511 天前
使用 Python 自动化 PowerPoint 形状布局与格式设置用户8356290780511 天前
用 Python 自动化 PowerPoint 演讲者备注添加ClouGence1 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步黄忠1 天前
01-系统架构设计-LangGraph状态机与多源异构RAG