01 传输架构图
Namesrv:5.1.0
Broker:5.1.0
Dashboard:1.0.1-SNAPSHOT

02 准备Namesrv、Broker、Client的ca证书、密钥。
以下全部操作在的目录在:/etc/rocketmq, 并且Namesrv、Broker、Dashboard在同一个机器上
实际操作时, dashboard或者客户端可以是其他的机器
1. 生成ca签名证书
- 填写与重复填写ca证书密码。实际填写的时候是输入的字符是看不见的。openssl req -newkey rsa:2048 -keyout ca_rsa_private.pem -x509 -days 365 -out ca.pem
- 填写其他信息, 不填的话使用 “.”
生成ca签名证书2. 生成公私密钥。提供给客户端-服务端加密传输使用
- openssl req -newkey rsa:2048 -keyout server_rsa.key -out server.csr Generating a 2048 bit RSA private key
生成加密密钥对3. 生成Namesrv、Broker加密密钥对,并且签发Namesrv、Broker证书
代码语言:shell复制openssl x509 -req -days 365 -in server.csr -CA ca.pem -CAkey ca_rsa_private.pem -CAcreateserial -out server.pem
生成Namesrv、Broker密钥,签发证书4. 打包并加密Namesrv、Broker私钥
代码语言:text复制 openssl pkcs8 -topk8 -v1 PBE-SHA1-RC4-128 -in server_rsa.key -out server.keytls.test.mode.enable=false
tls.server.need.client.auth=none
tls.server.keyPath=/etc/rocketmq/server.key
tls.server.keyPassword=123456
tls.server.certPath=/etc/rocketmq/server.pem
tls.client.authServer=false
tls.client.trustCertPath=/etc/rocketmq/ca.pem
代码语言:txt复制- tls-namesrv.properties
```propertiestls.test.mode.enable=false
tls.server.need.client.auth=none
tls.server.keyPath=/etc/rocketmq/server.key
tls.server.keyPassword=123456
tls.server.certPath=/etc/rocketmq/server.pem
代码语言:txt复制- tls-client.properties
```propertiestls.client.trustCertPath=/etc/rocketmq/ca.pem
代码语言:txt复制至此,我们得到了全部的tls配置文件:

## 3. 修改启动脚本
### 3.1 修改namesrv启动脚本
```bashvim bin/runserver.sh
代码语言:txt复制
### 3.2 修改broker启动配置
1. 修改broker启动脚本, 设置jvm支持tls
```bashvim bin/runbroker.sh
代码语言:txt复制
1. 添加broker.conf
```propertiesbrokerClusterName = DefaultCluster
brokerName = broker-a
brokerId = 0
deleteWhen = 04
fileReservedTime = 48
brokerRole = ASYNC_MASTER
flushDiskType = ASYNC_FLUSH
namesrvAddr = 127.0.0.1:9876
代码语言:txt复制### 3.3 修改dashboard配置
- 修改namesrv地址

- 打开tls开关
```bashvim rocketmq-dashboard-1.0.1-SNAPSHOT.jar
代码语言:txt复制
`说明:如果是客户端生产消费,设置如下`


## 4. 启动Namesrv,Broker,Dashboard
1. 启动namesrv
```bashnohup sh bin/mqnamesrv &
代码语言:txt复制1. 启动broker
```bashnohup sh bin/mqbroker -c conf/broker.conf &
代码语言:txt复制1. 启动dashboard
```bashjava -Dtls.client.authServer=true -Dtls.enable=true -Dtls.test.mode.enable=false -Dtls.config.file=/etc/rocketmq/tls-client.properties -jar rocketmq-dashboard-1.0.1-SNAPSHOT.jar
代码语言:txt复制5. 验证
- tcpdump抓包验证
TLS抓包结果- rocketmq dashboad日志验证: ~/logs/rocketmqlogs/rocketmq_client.log

6. 问题:抓包结果中, 为什么还有TCP协议呢?
- 抓包结果中, 为什么还有TCP协议呢?

- 客户端可以通过设置:-Dtls.enable=true开启, 但是实际还是需要设置代码"producer.setUseTLS(useTls);" 或者 “consumer.setUseTLS(useTls);”, 为什么?
大家可以留言说说看!
7. 看看生成的最终文件到底是什么?
- ca.pem
ca根证书

- ca_rsa_private.pem
ca根证书的加密私钥

- server.pem 使用跟证书签发的Namesrv、Broker的证书

- server_rsa.key Namesrv、Broker的加密私钥

- server.csr Namesrv、Broker的加密证书的公钥和用于辨别证书迁移机构的名称信息,

- server.key 打包并加密后的Namesrv、Broker的私钥(server_rsa.key)

- ca.srl ca签发证书的序列号

- tls-namesrv.properties 内容见上文, 是namesrv中netty识别的tls加密传输的配置
- tls-broker.properties 内容见上文, 是broker中netty识别的tls加密传输的配置
- tls-client.properties 内容见上文, 是client中netty识别的tls加密传输的配置
PS:RocketMQ的tls配置4.X版本和5.X版本差不多, 基本都可以用。


