0

0

mysql如何排查SSL证书过期导致的连接失败_mysql证书更新步骤

P粉602998670

P粉602998670

发布时间:2026-03-09 10:49:02

|

461人浏览过

|

来源于php中文网

原创

直接检查服务端证书有效期:openssl x509 -in /var/lib/mysql/ca.pem -text -noout | grep -e "(not before|not after)",若not after早于当前时间即为过期。

mysql如何排查ssl证书过期导致的连接失败_mysql证书更新步骤

MySQL客户端报错 SSL connection error: certificate verify failed 怎么快速定位是不是证书过期

直接查服务端证书有效期,别绕路试配置或重装驱动。MySQL本身不报“证书已过期”,而是把底层 OpenSSL 的校验失败笼统抛成这个错误,所以得自己挖。

进入 MySQL 服务所在服务器,运行:

openssl x509 -in /var/lib/mysql/ca.pem -text -noout | grep -E "(Not Before|Not After)"

如果 Not After 时间早于当前系统时间,就是它了。注意:客户端和服务端可能各自用不同证书(比如客户端用 client-cert.pem),但绝大多数连接失败由服务端 ca.pemserver-cert.pem 过期引发。

  • 检查前先确认 MySQL 配置里 ssl_cassl_certssl_key 指向的路径真实存在且可读
  • 如果用的是自签名证书,ca.pemserver-cert.pem 通常一起生成,过期时间一致
  • 云数据库(如阿里云 RDS、AWS RDS)不提供文件级访问,需查控制台「SSL/TLS 设置」页的证书有效期,或调用对应 API 查 ValidTill

更新 MySQL 服务端 SSL 证书后为什么客户端还是连不上

证书文件换了,但 MySQL 进程没重新加载,或者客户端缓存了旧 CA。

必须执行两步:重载证书配置 + 重启连接上下文

AI-Text-Classifier
AI-Text-Classifier

OpenAI官方出品,可以区分人工智能书写的文本和人类书写的文本

下载
  • 在 MySQL 服务端执行 ALTER INSTANCE RELOAD TLS;(MySQL 5.7.36+ / 8.0.16+),比重启 mysqld 更轻量;老版本只能 service mysql restart
  • 客户端如果是 Java 应用,JVM 启动时已加载 truststore,必须重启应用;Python 的 pymysqlmysql-connector-python 默认不缓存证书,但若代码里显式传了 ssl_ca 路径,要确认该路径指向新证书
  • 命令行工具如 mysql -u root -p --ssl-ca=/path/to/new/ca.pem 必须显式指定新 CA,否则可能沿用编译时内置的默认 CA 路径(如 /etc/ssl/certs/ca-certificates.crt

用 OpenSSL 自签证书时哪些参数容易导致连接失败

不是所有自签名证书 MySQL 都认。关键在 X.509 扩展字段和密钥用法,MySQL 8.0+ 尤其严格。

生成 server-cert.pem 时,必须包含 subjectAltName,且不能只写 IP;若用域名连接,CN 和 SAN 都得匹配实际连接地址。

  • 错误示范:openssl req -new -key server-key.pem -out server-req.pem(缺 SAN,MySQL 8.0.28+ 拒绝加载)
  • 正确做法:用配置文件生成,确保含 subjectAltName = DNS:db.example.com,IP:10.0.1.5;若本地测试用 localhost,SAN 里必须有 DNS:localhost
  • 密钥用法(Key Usage)至少要含 digitalSignature, keyEncipherment;扩展密钥用法(Extended Key Usage)建议加 serverAuth
  • 证书签名算法避免用 sha1WithRSAEncryption,MySQL 8.0.26+ 默认禁用 SHA-1

Java 客户端连接 MySQL SSL 报 PKIX path building failed 怎么处理

这是 JVM 找不到信任链,不是 MySQL 配置问题。错误信息里带 sun.security.provider.certpath.SunCertPathBuilderException 就是它。

根本解决方式:把新 CA 证书导入 JVM 的 cacerts,而不是仅放在项目 resources 下靠代码加载。

  • keytool -import -trustcacerts -keystore $JAVA_HOME/jre/lib/security/cacerts -storepass changeit -alias mysql_ca -file ca.pem
  • 如果应用跑在 Docker 里,必须在镜像构建阶段导入,或挂载修改后的 cacerts 文件,不能只改宿主机
  • Spring Boot 项目若用 spring.datasource.hikari.data-source-properties.sslMode=REQUIRED,仍需确保 JVM 级信任库已更新,否则照样失败
  • 临时验证可用 -Djavax.net.debug=ssl:handshake 开启 SSL 握手日志,看 JVM 最终尝试校验哪个证书路径

证书更新不是改完文件就完事,MySQL 进程、客户端运行时环境、甚至中间代理(如 ProxySQL、HAProxy)都可能持有旧证书缓存。最容易被忽略的是:云厂商控制台显示证书已更新,但后端节点滚动发布未完成,部分实例还在用旧证书——这种需要结合 SHOW STATUS LIKE 'Ssl_version';SELECT * FROM performance_schema.status_by_thread WHERE VARIABLE_NAME = 'Ssl_cipher'; 实时核对。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

686

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

493

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

287

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

519

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

266

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

542

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

666

2023.08.14

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

59

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 845人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号