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创作工具
相关推荐
woniu_buhui_fei21 小时前
JVM垃圾回收SeatuneWrite21 小时前
动态漫软件2026推荐,助力高效创作体验@我漫长的孤独流浪21 小时前
医院病房管理系统E-R建模与关系转换AC赳赳老秦21 小时前
文案策划提效:OpenClaw批量生成活动文案、宣传海报配文,适配不同渠道调性_codemonster21 小时前
系统分析师系列目录|_⊙21 小时前
Linux 深入理解文件(Ext2文件系统:下)甄心爱学习1 天前
【项目实训】法律文书智能摘要系统5沉下去,苦磨练!1 天前
python的全局解释器锁(GIL)到垃圾回收机制烟雨江南aabb1 天前
Python第四弹:python进阶-匿名函数和内置函数treacle田1 天前
达梦数据库-备份与还原-逻辑备份与还原