Rocketmq开启账号和密码(ACL)

我正在参加「金石计划」

写在前面

权限控制(ACL)主要为RocketMQ提供Topic资源级别的用户访问控制。

用户在使用RocketMQ权限控制时,可以在Client客户端通过 RPCHook注入AccessKey和SecretKey签名;同时,将对应的权限控制属性(包括Topic访问权限、IP白名单和AccessKey和SecretKey签名等)设置在distribution/conf/plain_acl.yml的配置文件中。

Broker端对AccessKey所拥有的权限进行校验,校验不过,抛出异常;

ACL客户端可以参考:org.apache.rocketmq.example.simple 包下面的AclClient代码。

rocketmq的权限控制,可以参考rocketmq官方文档

1.开启acl控制

  • 修改conf/broker.conf
sh 复制代码
#开启acl控制(最后面添加)
aclEnable=true

对应docker镜像的路径:/opt/jxbp/rocketmq/conf/broker.conf

  • 修改conf/plain_acl.yml

这里设置管理员账号和密码

sh 复制代码
- accessKey: LlsydnRocketMQ
  secretKey: Llsydn123!@#
  whiteRemoteAddress: 192.168.1.*
  # if it is admin, it could access all resources
  admin: true

这里默认的账号密码是:rocketmq2/12345678,现在修改为:JxbpRocketMQ/Jxbp123!@#

对应docker镜像的路径:/opt/llsydn/rocketmq/conf/plain_acl.yml

docker方式部署rocketmq的,该文件对应的镜像,已经修改默认账号和密码,拉取最新的镜像即可。如果不想更新镜像,可以自己挂载该文件到宿主机,然后对应修改相应的账号和密码即可。

sh 复制代码
#对应公司harbor的镜像如下:
192.168.1.121/llsydn/rocketmq:5.1.1
192.168.1.121/llsydn/rocketmq:5.1.1-arm

最后重启rocketmq即可。

2.微服务启动配置

在broker中配置aclEnable=true之后,相关微服务会报错,报错消息如下:

sh 复制代码
    CODE: 1 DESC: org.apache.rocketmq.acl.common.AclException: No accessKey is configured, org.apache.rocketmq.acl.plain.PlainPermissionLoader.validate(PlainPermissionLoader.java:194)

如果使用了nacos配置中心的,可以在nacos加上下面配置:

properties 复制代码
spring.cloud.stream.rocketmq.binder.access-key=LlsydnRocketMQ
spring.cloud.stream.rocketmq.binder.secret-key=Llsydn123!@#

以上配置,可以在nacos-config-dev.properties配置文件中添加即可。

然后重启所有微服务即可!

另:(不是集群部署rocketmq,可忽略)

RocketMQ开启ACL之后,客户端通过accessKey和secretKey进行认证,但是集群的节点之间是不能配置accessKey和secretKey,只能通过配置全局ip白名单的方式来访问,也就是配置plain_acl.yml中的globalWhiteRemoteAddresses,可以看看这篇文章:blog.csdn.net/sinat_14840...

3.RocketMQ-Dashboard(可忽略)

如没有部署Dashboard可视化客户端服务的,这个步骤可以忽略。

修改application.properties,将注释放开,设置对应的RocketMQ账号密码

properties 复制代码
rocketmq.config.accessKey=LlsydnRocketMQ
rocketmq.config.secretKey=Llsydn123!@#

重启dashboard,即可正常访问。

注:

当前,已经为RocketMQ设置了密码,但是,还存在问题,Dashboard操作面板没有设置密码,操作面板没有设置密码,在实际应用中,也是很危险的。下面为Dashboard操作面板设置密码:

  • Dashboard操作面板开启账号密码

修改application.properties

properties 复制代码
rocketmq.config.loginRequired=true

重新访问,发现需要账号密码

默认的账号密码,在user.properties

这里默认的账号密码是:admin/admin,现在修改为:admin/Llsydn123!@#

注:

RocketMQ-Dashboard相关的配置都不用自己修改,公司相关的docker镜像包,已经进行了修改,拉取最新的镜像即可。

sh 复制代码
#对应公司harbor的镜像如下:
192.168.2.122/llsydn/rocketmq:db100
192.168.2.121/llsydn/rocketmq:db100-arm

好了,以上就是我个人的实操了。可能有些不对,大家伙,轻点喷!!!

个人理解,可能也不够全面,班门弄斧了。

好了,今天就先到这里了!!!^_^

如果觉得有收获的,帮忙点赞、评论、收藏一下,再走呗!!!

相关推荐
e***74955 小时前
SpringBoot项目集成ONLYOFFICE
java·spring boot·后端
Java天梯之路6 小时前
Spring Boot 实战:基于 JWT 优化 Spring Security 无状态登录
spring boot·后端
o***74176 小时前
SpringBoot Maven快速上手
spring boot·后端·maven
Qiuner6 小时前
Spring Boot 配置文件高级实战指南 热更新/动态配置/安全加密/分布式同步/环境变量注入
spring boot·分布式·安全
g***96906 小时前
springboot设置多环境配置文件
java·spring boot·后端
Dreamer-'6 小时前
Spring Boot + RabbitMQ 实现导出任务异步处理
spring boot·rabbitmq·java-rabbitmq
q***54757 小时前
springboot之集成Elasticsearch
spring boot·后端·elasticsearch
q***2517 小时前
Spring Boot 中使用 @Transactional 注解配置事务管理
数据库·spring boot·sql
q***31897 小时前
Spring Boot 实战篇(四):实现用户登录与注册功能
java·spring boot·后端
IT_陈寒7 小时前
React性能翻倍!90%开发者忽略的5个Hooks最佳实践
前端·人工智能·后端