Please enable Javascript to view the contents

使用 TLS 1.3 加密 MongoDB Client 与 Server 端的网络流量

 ·  🕒 2 分钟  ·  🤖 Gavin · 👀... 阅读

加密传输

使用 tls 1.3 对 MongoDB client 与 server 端的网络通信进行加密,主要步骤:

1》创建自签名根证书 ca.crt

2》生成 client 及 server 端证书

3》mongod 进程配置 server 和 ca 证书

4》mongosh 指定 client 和 ca 证书

环境介绍:

1》Rocky Linux release 8.9 (kernel 4.18.0)

2》MongoDB Community version 7.0.11,mongosh version 2.2.10

3》服务器端 IP: 192.168.31.13,客户端 IP:192.168.31.10

4》要使用 tls 1.3 加密网络传输,需确保 OpenSSL 至少为 1.1.1 版本

具体配置流程如下:

证书配置模板

cat server/client.conf

[req]
distinguished_name = req_distinguished_name
req_extensions = req_ext

[req_distinguished_name]
countryName = CN
stateOrProvinceName = SiChuan
localityName = Chengdu
organizationName = JiaWen
organizationalUnitName = Ops
commonName = SERVER           # 名称任意,表示服务端证书。创建 Client 证书时设置为 CLIENT

[req_ext]
subjectAltName = @alt_names

[alt_names]
DNS.1 = example.com
DNS.2 = www.example.com
IP.1 = 192.168.31.13        # Sever 所在主机 IP 地址,创建 Client 证书时需变更为 31.10

创建根证书

首先生成自签名根证书,用于签发 server 及 client 证书

# 生成 ca 证书私钥 ca.key
openssl genrsa -aes256 -out ca.key 2048

# 生成 ca 证书签名请求文件 ca.csr
openssl req -new -sha256 -key ca.key -out ca.csr -subj "/C=CN/ST=SiChuan/L=Chengdu/O=JiaWen/OU=Ops/CN=CA"

# 创建自签名根证书文件 ca.crt
openssl x509 -req -days 365 -in ca.csr -signkey ca.key -out ca.crt

创建服务器证书

# 生成 Server 证书私钥及请求文件
openssl genrsa -out server.key 2048

# 生成服务器证书签名请求文件 server.csr
# 注意:配置项 -extensions 'req_ext' 需与证书配置模板中的 [req_ext] 匹配
openssl req -new -key server.key -out server.csr -subj "/C=CN/ST=SiChuan/L=Chengdu/O=JiaWen/OU=Ops/CN=SERVER" -config server.conf -extensions 'req_ext'

# 使用根证书签发服务器证书
openssl x509 -req -days 365 -in server.csr -CA ca.crt -CAkey ca.key -CAcreateserial -out server.crt -extfile server.conf -extensions 'req_ext'

# 合并服务器端私钥和服务器端证书,生成 server.pem
cat server.key server.crt > server.pem

创建客户端证书

# 生成 Client 证书私钥及请求文件
openssl genrsa -out client.key 2048

# 生成客户端证书签名请求文件 client.csr
openssl req -new -key client.key -out client.csr -subj "/C=CN/ST=SiChuan/L=Chengdu/O=JiaWen/OU=Ops/CN=CLIENT" -config client.conf -extensions 'req_ext'

# 使用根证书签发客户端证书
openssl x509 -req -days 365 -in client.csr -CA ca.crt -CAkey ca.key -CAcreateserial -out client.crt -extfile client.conf -extensions 'req_ext'

# 合并客户端私钥和客户端证书,生成 client.pem
cat client.key client.crt > client.pem

效验 pem 文件、查看证书信息 (可选)

openssl verify -CAfile ca.crt server.pem
#> server.pem: OK

# 查看证书详细信息
openssl x509 -text -noout -in /root/ssl/server.pem

Server 端配置

net:
   tls:
      mode: requireTLS      # 仅使用并接受 TLS 加密连接
      certificateKeyFile: /var/lib/mongo/server.pem      # 包含 TLS/SSL 证书和密钥的文件的路径
      CAFile: /var/lib/mongo/ca.crt
      disabledProtocols: TLS1_0,TLS1_1,TLS1_2       # 确保仅使用 tls 1.3

未加密连接

Client 端使用 mongosh 连接 mongod 执行数据插入

db.c1.insert({name: "jiawen", age: "29"})

wireshark 抓包截图如下:

未加密流量

可发现数据为明文,毫无安全可言…☠️

加密连接

1、使用 mongosh 连接 mongodb server

# ca.crt 签发 server 及 client 端证书的自签名根证书
mongosh --tls --host 192.168.31.13 --tlsCAFile /root/ssl/ca.crt --tlsCertificateKeyFile /root/ssl/client.pem

2、mongodb server 端 tls 连接日志

{.., "msg":"Connection accepted","attr":{"remote":"192.168.31.10:33168","uuid":{"uuid":{"$uuid":"f1e42096-557f-459e-9c5c-cd2d07b21b62"}},"connectionId":69,"connectionCount":1}}
{.., "msg":"Ingress TLS handshake complete","attr":{"durationMillis":11}}
{.., "msg":"Accepted TLS connection from peer","attr":{"peerSubject":"CN=CLIENT,OU=Ops,O=JiaWen,L=Chengdu,ST=SiChuan,C=CN","cipher":"TLS_AES_256_GCM_SHA384"}}

3、wireshark 抓包验证流量加密

加密流量

可发现数据已加密,从而确保数据的网络传输安全


加文
作者: Gavin
运维工程师
版权声明:自由转载-非商用-非衍生-转载请注明出处!


目录