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

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

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

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

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

相关推荐
苹果醋31 小时前
快速玩转 Mixtral 8x7B MOE大模型!阿里云机器学习 PAI 推出最佳实践
spring boot·nginx·毕业设计·layui·课程设计
程序员大金1 小时前
基于SpringBoot+Vue+MySQL的装修公司管理系统
vue.js·spring boot·mysql
姜学迁2 小时前
Rust-枚举
开发语言·后端·rust
爱学习的小健2 小时前
MQTT--Java整合EMQX
后端
北极小狐2 小时前
Java vs JavaScript:类型系统的艺术 - 从 Object 到 any,从静态到动态
后端
【D'accumulation】2 小时前
令牌主动失效机制范例(利用redis)注释分析
java·spring boot·redis·后端
2401_854391082 小时前
高效开发:SpringBoot网上租赁系统实现细节
java·spring boot·后端
Cikiss2 小时前
微服务实战——SpringCache 整合 Redis
java·redis·后端·微服务
wxin_VXbishe2 小时前
springboot合肥师范学院实习实训管理系统-计算机毕业设计源码31290
java·spring boot·python·spring·servlet·django·php
Cikiss2 小时前
微服务实战——平台属性
java·数据库·后端·微服务