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  |
+---------------+---------------------------+**
相关推荐
殷紫川几秒前
SQL 性能优化全解:从执行计划到底层逻辑,根治 99% 的慢 SQL 与规范落地
数据库·mysql
Memory_荒年4 分钟前
TiDB:当 MySQL 遇上分布式,生了个“超级混血儿”
java·数据库·后端
asom227 分钟前
DDD(领域驱动设计) 核心概念详解
java·开发语言·数据库·spring boot
ego.iblacat9 分钟前
MySQL 数据库操作
数据库·mysql·adb
赵渝强老师9 分钟前
【赵渝强老师】高斯数据库(openGauss)的逻辑存储结构
数据库·postgresql·opengauss·gaussdb·国产数据库·高斯数据库
Aawy12041 分钟前
Python生成器(Generator)与Yield关键字:惰性求值之美
jvm·数据库·python
梦想的旅途242 分钟前
API 驱动:实现企业微信外部群自动化管理与效率升级
数据库·windows
飞鱼计划1 小时前
MySQL如何释放sql
数据库·sql·mysql
x***r1511 小时前
MySQL 8.0安装教程 Windows版:解压+自定义组件+传统认证+密码设置+命令行快捷方式创建指南
数据库·windows·mysql
czlczl200209252 小时前
Redis数据编码
数据库·redis·缓存