宝塔升级MySQL8.0错误解决办法
时间:2026-04-17 12:06:41 370浏览 收藏
宝塔升级MySQL 8.0后频繁出现“Plugin caching_sha2_password could not be loaded”连接报错,本质是新版默认认证插件与旧版PHP、Navicat及宝塔自身管理界面不兼容所致——问题不在密码错误,而在于客户端根本不认识新插件;只需通过ALTER USER显式切换root用户(及必要时远程用户)的认证方式为mysql_native_password并执行FLUSH PRIVILEGES即可秒级恢复连接,无需重启服务或重装数据库;同时提醒备份时务必使用--set-gtid-purged=OFF参数规避GTID导入异常,避开宝塔界面一键备份的潜在陷阱,兼顾效率、安全与稳定性。

MySQL 8.0 升级后连接报错 Plugin caching_sha2_password could not be loaded
这是宝塔升级 MySQL 8.0 后最典型的兼容性问题:旧客户端(如 PHP 的 mysqlnd、某些 Navicat 版本、甚至宝塔自身数据库管理页)不支持 MySQL 8.0 默认的 caching_sha2_password 认证插件,直接拒绝连接。
根本原因不是密码错了,而是服务端要求用新插件鉴权,而客户端压根不认识它。别急着重装或删库,先验证是否是这个原因:
- 登录宝塔终端,执行
mysql -u root -p,如果能进,说明本地命令行客户端已兼容;若报错该插件加载失败,则大概率是远程/PHP 连接出问题 - 检查当前用户认证方式:
SELECT user,host,plugin FROM mysql.user WHERE user='root';—— 若plugin列显示caching_sha2_password,就对上了
临时绕过:把 root 用户切回 mysql_native_password 插件
这不是降级安全,而是快速恢复业务的务实做法。MySQL 8.0 仍完全支持 mysql_native_password,只是不再设为默认。
操作前确保你已用 root 登录成功(可通过宝塔终端或跳板机):
- 执行
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '你的当前密码'; - 如果要同时允许远程 root 连接(不推荐生产环境),再加一行:
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '你的当前密码'; - 刷新权限:
FLUSH PRIVILEGES; - 验证修改结果:
SELECT user,host,plugin FROM mysql.user WHERE user='root';—— 确认plugin已变为mysql_native_password
改完立刻生效,无需重启 MySQL。PHP、Django、旧版客户端基本都能连上了。
备份数据时要注意 mysqldump 的 --set-gtid-purged 参数
升级后若启用了 GTID(宝塔 8.0+ 默认开启),直接用老命令导出可能报错 GTID state cannot be changed 或导致还原失败。
安全导出建议用:
mysqldump --all-databases --single-transaction --routines --triggers --set-gtid-purged=OFF -u root -p > full_backup.sql
--set-gtid-purged=OFF是关键,避免导出文件里写死 GTID 位置,否则在非 GTID 环境或不同主从拓扑下无法导入--single-transaction保证一致性,适合 InnoDB 表;若含 MyISAM,需改用--lock-all-tables- 别用宝塔界面一键备份——它默认不加
--set-gtid-purged=OFF,导出的 SQL 在还原时容易卡住
为什么不能只改密码而不改插件?
很多人试过 ALTER USER 'root'@'localhost' IDENTIFIED BY '新密码';,发现还是连不上。因为这条命令在 MySQL 8.0+ 中**不会改变 plugin 字段**,只会重置密码,认证方式仍为 caching_sha2_password。
必须显式指定 WITH mysql_native_password,否则徒劳。这也是最容易被忽略的一行 —— 看似改了密码,其实认证协议没变,客户端照样报插件加载失败。
真要长期用 caching_sha2_password,得同步升级所有客户端:PHP 至 7.4+ 并启用 mysqlnd,Navicat 至 12.1+,且连接字符串里加上 ?serverVersion=8.0 显式声明版本。但对多数宝塔用户,切回 mysql_native_password 更省事也足够安全。
好了,本文到此结束,带大家了解了《宝塔升级MySQL8.0错误解决办法》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多文章知识!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
464 收藏
-
355 收藏
-
103 收藏
-
326 收藏
-
179 收藏
-
374 收藏
-
467 收藏
-
206 收藏
-
238 收藏
-
131 收藏
-
220 收藏
-
265 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习