为RabbitMQ配置SSL

1. 安装 OpenSSL

从 OpenSSL 的官方网站(https://www.openssl.org/)下载 OpenSSL 工具的 Windows 版本,并安装。

2. 创建 SSL 证书和私钥

执行以下命令以生成私钥文件(.key)和证书签名请求文件(.csr):

bash 复制代码
openssl req -newkey rsa:2048 -nodes -keyout your_private_key.key -out your_csr_file.csr

在执行此命令时,你需要回答一些关于证书的问题。最重要的是 Common Name (CN),它通常是你的 RabbitMQ 服务器的主机名。

Country Name (2 letter code) [AU]: CN

State or Province Name (full name) [Some-State]: JS

Locality Name (eg, city) []: NJ

Organization Name (eg, company) [Internet Widgits Pty Ltd]: MyOrg

Organizational Unit Name (eg, section) []: MyDep

Common Name (e.g. server FQDN or YOUR name) []: CUS

Email Address []: ******@hotmail.com

使用以下命令生成自签名证书:

bash 复制代码
openssl x509 -req -in your_csr_file.csr -signkey your_private_key.key -out your_cert_file.pem
3. 配置 RabbitMQ 使用 SSL

在 RabbitMQ 配置文件(rabbitmq.config或者advanced.config)中,添加 SSL 相关配置。示例配置如下:

该文件通常在这里:C:\Users\user_name\AppData\Roaming\RabbitMQ

erlang 复制代码
[
  {rabbit, [
    {ssl_listeners, [5671]},
    {ssl_options, [
      {cacertfile,"path/to/your_csr_file.csr"},
      {certfile,"path/to/your_cert_file.pem"},
      {keyfile,"path/to/your_private_key.key"},
      {verify,verify_peer},
      {fail_if_no_peer_cert,true}
    ]}
  ]}
].

确保替换上述示例中的路径为你生成的证书和私钥文件的实际路径。

[备注]: 我不太确定 cacertfile 后面应该填什么,似乎填csr或者key都没有什么影响。有清楚的同学欢迎在评论区告诉我。谢谢。

4. 重启 RabbitMQ

在 RabbitMQ 配置更改后,重启 RabbitMQ 服务以使更改生效。

相关推荐
.生产的驴1 小时前
SpringBoot 消息队列RabbitMQ 消费者确认机制 失败重试机制
java·spring boot·分布式·后端·rabbitmq·java-rabbitmq
月夜星辉雪7 小时前
【RabbitMQ 项目】服务端:路由交换模块
分布式·rabbitmq
super_journey7 小时前
RabbitMq中交换机(Exchange)、队列(Queue)和路由键(Routing Key)
分布式·中间件·rabbitmq
pemper_7 小时前
怎么操作使http变成https访问?
网络·网络协议·http·https·ssl
王彬泽10 小时前
【RabbitMQ】重试机制、TTL
rabbitmq·ttl·重试机制
海里真的有鱼12 小时前
Spring Boot 项目中整合 RabbitMQ,使用死信队列(Dead Letter Exchange, DLX)实现延迟队列功能
开发语言·后端·rabbitmq
小宋102116 小时前
玩转RabbitMQ声明队列交换机、消息转换器
服务器·分布式·rabbitmq
心勤则明1 天前
Netty配置SSL证书加密
服务器·https·ssl
广东数字化转型1 天前
SSL/TSL 总结
网络·网络协议·ssl
xcx0031 天前
快充协议方案,Type-C接口受电端Sink取电快充协议芯片
zookeeper·rabbitmq·flume·memcached·storm