0

0

mysql如何配置数据库连接加密协议_mysql tls版本限制

P粉602998670

P粉602998670

发布时间:2026-03-18 12:42:55

|

214人浏览过

|

来源于php中文网

原创

MySQL强制启用TLS需客户端显式声明ssl-mode=REQUIRED等参数,服务端设require_secure_transport=ON并配置tls_version,验证须查STATUS或SHOW STATUS中SSL字段。

mysql如何配置数据库连接加密协议_mysql tls版本限制

MySQL 连接加密协议怎么强制启用 TLS

不配 TLS,mysql 客户端连上去默认走明文——哪怕服务端支持 TLS,客户端不声明,照样不加密。必须显式要求,不能靠“服务端开了就自动用”。

  • mysql --ssl-mode=REQUIRED -u user -p 是最简验证方式;不加这个参数,即使服务端配置了证书,连接也走非加密通道
  • 应用层(如 Python 的 pymysql、Go 的 mysql 驱动)必须显式设置 ssl_disabled=False 或传入 ssl={'ca': '/path/to/ca.pem'},否则 TLS 不生效
  • 服务端 require_secure_transport=ON 可全局拦截非加密连接,但要注意:旧客户端(如 MySQL 5.7 默认编译选项)可能因缺少 SSL 库直接报错 SSL connection error: protocol version mismatch

MySQL 支持哪些 TLS 版本?怎么限制最低版本

MySQL 8.0.16+ 才真正支持通过配置项控制 TLS 协议版本;早于这个版本只能靠 OpenSSL 底层限制,不可控且易出错。

  • 服务端配置文件中加 tls_version=TLSv1.2,TLSv1.3(注意逗号无空格),MySQL 会拒绝低于 TLSv1.2 的握手请求
  • 若设为 tls_version=TLSv1.3,MySQL 8.0.28+ 才完全稳定;低版本在某些 OpenSSL 组合下会 fallback 失败,导致连接中断
  • 客户端不匹配时典型报错是:SSL connection error: Unsupported protocolSSL handshake failed,不是证书问题,而是协议协商失败
  • 别依赖 openssl version 判断——MySQL 编译时链接的 OpenSSL 版本才决定支持范围,可用 SELECT VERSION(), @@version_compile_ssl; 查看实际绑定情况

为什么开了 TLS 还被提示 “Insecure connection”

不是没启 TLS,而是证书链或验证方式没对上。MySQL 默认只校验证书签名,不校验域名、有效期或 CA 信任链,除非你主动要求。

Buildt.ai
Buildt.ai

AI驱动的软件开发平台,可以自动生成代码片段、代码分析及其他自动化任务

下载
  • 客户端加 --ssl-mode=VERIFY_IDENTITY 才会校验服务端证书中的 Common NameSAN 是否匹配连接地址;否则即使证书过期、自签、域名不符,连接也成功
  • Java 应用常见坑:useSSL=true&requireSSL=true 不等于加密生效,必须加上 verifyServerCertificate=true 并提供 trustCertificateKeyStoreUrl
  • mysql_config_editor 存密码时,它不保存 SSL 设置,login-path 里没有 ssl-mode 字段,得单独传参

配置后如何验证 TLS 真正生效

别信日志里那句 “SSL enabled”,要看实际协商结果和流量特征。

  • 连接后执行 STATUS;,关注输出里的 SSL: 行,显示 Cipher in use is TLS_AES_256_GCM_SHA384 类似内容才算真走 TLSv1.3
  • 服务端查 SHOW STATUS LIKE 'Ssl_cipher%';Ssl_cipher 非空且 Ssl_version 显示具体协议版本(如 TLSv1.3)才可信
  • 抓包验证最硬核:用 tshark -i lo port 3306 -Y ssl.handshake.type==1 看 Client Hello 里的 supported_versions 扩展,确认客户端发的是 TLSv1.3
  • 容易忽略的一点:MySQL Router、ProxySQL 等中间件若未配置 TLS 终止或透传,会把加密连接降级成明文转发,得单独检查它们的 TLS 设置
配置 TLS 不是开关一按就完事,服务端版本、客户端驱动、中间件、证书部署、协议版本限制这五环缺一不可。尤其当多个组件版本混杂时,TLSv1.3 的 fallback 行为极难排查,建议先统一收口到 TLSv1.2 再逐步升级。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的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的相关下载、相关课程等内容,供大家免费下载使用。

690

2023.06.20

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

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

554

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中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

520

2023.07.19

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

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

267

2023.07.25

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

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

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

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

543

2023.08.11

mysql忘记密码
mysql忘记密码

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

668

2023.08.14

Python WebSocket实时通信与异步服务开发实践
Python WebSocket实时通信与异步服务开发实践

本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

3

2026.03.18

热门下载

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

精品课程

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

共48课时 | 2.6万人学习

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

共3课时 | 0.3万人学习

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

共1课时 | 859人学习

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

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