MariaDB数据库开启SSL 教程

MariaDB 开启 SSL 教程

步骤 1:创建证书存放目录
python 复制代码
mkdir -p /usr/local/mysql/ssl
python 复制代码
##### 步骤 2:用 openssl 一键生成所有证书
1. 生成CA根证书
openssl genrsa 2048 > ca-key.pem
openssl req -new -x509 -days 3650 -nodes -key ca-key.pem -out ca.pem

2. 生成服务端证书+私钥 
# ========== 1. 生成CA根证书(修复核心缺陷,必对) ==========
openssl genrsa 2048 > ca-key.pem
openssl req -new -x509 -days 3650 -nodes -key ca-key.pem -out ca.pem

# ========== 2. 生成服务端证书+私钥 ==========
openssl req -newkey rsa:2048 -days 3650 -nodes -keyout server-key.pem -out server-req.pem
openssl rsa -in server-key.pem -out server-key.pem
openssl x509 -req -in server-req.pem -days 3650 -CA ca.pem -CAkey ca-key.pem -set_serial 01 -out server-cert.pem

# ========== 3. 生成客户端证书+私钥(客户端连接时用) ==========
openssl req -newkey rsa:2048 -days 3650 -nodes -keyout client-key.pem -out client-req.pem
openssl rsa -in client-key.pem -out client-key.pem
openssl x509 -req -in client-req.pem -days 3650 -CA ca.pem -CAkey ca-key.pem -set_serial 02 -out client-cert.pem

#执行中会弹出 3 次填写信息的提示,所有信息都可以直接回车跳过(不用填任何内容),直接按Enter就行,不影响证书有效性!
步骤 3:证书权限配置
python 复制代码
chmod 600 *.pem
步骤 4:修改/etc/my.cnf,添加如下配置
python 复制代码
[mysqld]
# 原有SSL配置不变
ssl=ON
ssl_ca=/usr/local/mysql/ssl/ca.pem
ssl_cert=/usr/local/mysql/ssl/server-cert.pem
ssl_key=/usr/local/mysql/ssl/server-key.pem
# 新增:强制所有连接必须使用SSL加密,拒绝明文连接(核心配置)
require_secure_transport=ON
步骤 5:检测是否成功
python 复制代码
1. 重启服务:
systemctl  restart MariaDB

2. 连接登录数据库:
mysql -uroot -p'密码'

3. 执行查询 SQL:
show variables like '%ssl%';

输出结果:
**+---------------+---------------------------+
| Variable_name | Value                     |
+---------------+---------------------------+
| have_openssl  | YES                       |
| have_ssl      | YES                       | 👉 这个值为 YES 表示SSL完全开启成功!
| ssl_ca        | /var/lib/mysql/ca.pem     |
| ssl_cert      | /var/lib/mysql/server-cert.pem |
| ssl_key       | /var/lib/mysql/server-key.pem  |
+---------------+---------------------------+**
相关推荐
焦糖布丁的午夜2 小时前
数据库大王mysql---linux
linux·数据库·mysql
appearappear2 小时前
IntelliJ IDEA 2025.3.1 中 Export → SQL Updates 不带 WHERE 的真实原因与解决方案(OpenAI 协助整理)
java·数据库
玄〤2 小时前
黑马点评中的分布式锁设计与实现(Redis + Redisson)
java·数据库·redis·笔记·分布式·后端
老邓计算机毕设2 小时前
SSM新华书店o2o服务系统89nml(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·客户管理·ssm 框架·新华书店 o2o·书籍管理
岁岁种桃花儿2 小时前
深入理解MySQL SELECT语句执行顺序:从书写到内部流程全解析
数据库·mysql
野犬寒鸦2 小时前
从零起步学习RabbitMQ || 第二章:RabbitMQ 深入理解概念 Producer、Consumer、Exchange、Queue 与企业实战案例
java·服务器·数据库·分布式·后端·rabbitmq
想唱rap2 小时前
MySQL表得内外连接
服务器·数据库·c++·mysql·ubuntu
熏鱼的小迷弟Liu2 小时前
【Redis】Redis为什么快?
数据库·redis·缓存
Gauss松鼠会2 小时前
【opengauss】opengauss使用gs_probackup进行增量备份恢复
数据库·sql·database·opengauss