MySQL 8.0默认认证插件改为caching_sha2_password,导致旧客户端连接失败;应优先通过ALTER USER 'user'@'host' IDENTIFIED WITH mysql_native_password BY 'pwd'降级插件,并FLUSH PRIVILEGES。MySQL 8.0 默认认证插件变了MySQL 8.0 开始,mysql_native_password 不再是默认认证方式,新用户默认用 caching_sha2_password。老客户端(比如 MySQL 5.7 客户端、旧版 PHP mysqli 扩展、某些 Python pymysql 版本)不认识这个插件,连不上就报 Client does not support authentication protocol。这不是"客户端太旧要升级",而是服务端和客户端之间认证协议不匹配。解决方向有两个:改服务端适配客户端,或改客户端支持新协议------优先选前者,尤其当无法控制客户端环境时。检查当前用户用的认证插件:SELECT user, host, plugin FROM mysql.user WHERE user = 'your_user';如果返回 caching_sha2_password,且你用的是旧客户端,大概率就是它导致的临时方案不是升级客户端,而是让该用户降级回 mysql_native_passwordALTER USER 切换认证插件(安全但需权限)用有 CREATE USER 或 UPDATE 权限的账号执行,直接改用户认证方式,客户端完全无感。这是最稳的解法,比改全局配置更精准,也避免影响其他新用户。注意不能只改 PASSWORD,必须显式指定 IDENTIFIED WITH:ALTER USER 'your_user'@'%' IDENTIFIED WITH mysql_native_password BY 'your_password';执行后记得 FLUSH PRIVILEGES;(虽然多数情况下自动生效,但保险起见)如果用户是从 localhost 连,host 要写成 'your_user'@'localhost',别漏掉单引号PHP 7.4+、Python PyMySQL 0.9.3+、MySQL Shell 8.0+ 原生支持 caching_sha2_password,这类情况建议保留新插件,升级客户端更合理my.cnf 里禁用新认证插件(仅测试环境)在 MySQL 配置文件 my.cnf 的 [mysqld] 段加一行,强制所有新用户都用老插件: 橙篇 百度文库发布的一款综合性AI创作工具
相关推荐
qyzm2 小时前
Educational Codeforces Round 189 (Rated for Div. 2)z4424753262 小时前
SQL中GROUP BY与WHERE子句顺序_如何正确在聚合前过滤数据RNEA ESIO2 小时前
SQL中的REGEXP正则表达式使用指南AI玫瑰助手2 小时前
Python基础:列表的定义、增删改查核心操作mOok ONSC2 小时前
对基因列表中批量的基因进行GO和KEGG注释吕源林2 小时前
golang如何实现项目错误码规范_golang项目错误码规范实现指南深藏功yu名2 小时前
大模型推理加速实战技术qq_372906932 小时前
Layui表格怎么实现在表头的右侧添加一个自定义配置图标菜菜小狗的学习笔记2 小时前
八股(七)数据库