mysql5.7生成SSL证书

1、创建 CA 私钥和 CA 证书

生成一个 CA 私钥(多出来的文件:ca-key.pem)

shell 复制代码
openssl genrsa 2048 > ca-key.pem

通过 CA 私钥生成数字证书执行这个命令时, 会需要填写一些问题,如:CN,多出来的文件:ca-cert.pem

shell 复制代码
openssl req -sha1 -new -x509 -nodes -days 3650 -key ca-key.pem > ca-cert.pem

2、创建服务器端的 RSA 私钥和数字证书

创建服务器端的私钥和一个证书请求文件,需要回答几个问题,多出来文件:server-key.pem server-req.pem

shell 复制代码
openssl req -sha1 -newkey rsa:2048 -days 3650 -nodes -keyout server-key.pem > server-req.pem

将生成的私钥转换为 RSA 私钥文件格式

shell 复制代码
openssl rsa -in server-key.pem -out server-key.pem

使用原先生成的 CA 证书来生成一个服务器端的数字证书(多出来文件:server-cert.pem)

shell 复制代码
openssl x509 -sha1 -req -in server-req.pem -days 3650 -CA ca-cert.pem -CAkey ca-key.pem -set_serial 01 -out server-cert.pem

3、创建客户端的 RSA 私钥和数字证书

为客户端生成一个私钥和证书请求文件(多出来文件:client-key.pem client-req.pem )

shell 复制代码
openssl req -sha1 -newkey rsa:2048 -days 3650 -nodes -keyout client-key.pem > client-req.pem

将生成的私钥转换为 RSA 私钥文件格式

shell 复制代码
openssl rsa -in client-key.pem -out client-key.pem

为客户端创建一个数字证书(多出来文件:client-cert.pem )

shell 复制代码
openssl x509 -sha1 -req -in client-req.pem -days 3650 -CA ca-cert.pem -CAkey ca-key.pem -set_serial 01 -out client-cert.pem

4、生成的具体证书说明

text 复制代码
SSL 配置及生成文件说明:在前面的步骤中, 我们已经生成了8个文件, 分别是:

ca-cert.pem: CA 证书, 用于生成服务器端/客户端的数字证书.

ca-key.pem: CA 私钥, 用于生成服务器端/客户端的数字证书.

server-key.pem: 服务器端的 RSA 私钥

server-req.pem: 服务器端的证书请求文件, 用于生成服务器端的数字证书.

server-cert.pem: 服务器端的数字证书.

client-key.pem: 客户端的 RSA 私钥

client-req.pem: 客户端的证书请求文件, 用于生成客户端的数字证书.

client-cert.pem: 客户端的数字证书.

5、服务器端配置

text 复制代码
ca-cert.pem

server-cert.pem

server-key.pem

6、校验证书

shell 复制代码
openssl verify -CAfile ca-cert.pem server-cert.pem client-cert.pem

7.注意

text 复制代码
创建证书的时候输入的密码: xxx

创建证书的时候输入的邮箱: 可以为空

生成证书的时候

    根证书的Common Name字段的值置空
    
    服务端证书的Common Name字段的值设置为mysql数据库的ip
    
    客户端证书的Common Name字段的值设置为连接mysql使用的用户名

输出结果如下,即为通过:

shell 复制代码
server-cert.pem: OK

client-cert.pem: OK

如输出结果报错如下:

shell 复制代码
error 18 at 0 depth lookup:self signed certificate

修改Common Name就可以了

text 复制代码
服务端证书的Common Name字段的值设置为mysql数据库的ip
    
客户端证书的Common Name字段的值设置为连接mysql使用的用户名
相关推荐
吠品7 小时前
企业信任基石OV SSL证书
网络协议·https·ssl
吠品13 小时前
命令行揭示SSL证书真相
https·github·ssl
·云扬·15 小时前
MySQL 8.0 Redo Log 归档与禁用实战指南
android·数据库·mysql
筵陌16 小时前
MySQL索引及其底层原理(上)
mysql
怣5017 小时前
MySQL子查询零基础入门教程:从小白到上手(零基础入门版)
数据库·mysql
宝塔面板17 小时前
AllinSSL 一站式搞定 SSL 自动续期:永久免费,开源可自托管
网络·网络协议·ssl
csdn今天倒闭了吗17 小时前
飞牛lucky配置ipv6 ddns+ssl+反向代理
网络·网络协议·ssl
艾斯我来找你啦17 小时前
2026更新!OpenSSL 3.x版本的详细下载教程,纯小白友好!(内附介绍应用)
ssl
JavinLu17 小时前
ios 配置了代理且使用 chls.pro/ssl 下载不了证书,无法弹出下载证书的提示问题
网络协议·ios·ssl
菜鸟特工00718 小时前
javax.net.ssl.SSLPeerUnverifiedException 异常如何处理
网络协议·.net·ssl