我的activeMq配置如下:
<plugins>
<!-- Configure authentication; Username, passwords and groups -->
<simpleAuthenticationPlugin>
<users>
<authenticationUser username="admin" password="admin" groups="users,admins"/>
<authenticationUser username="xx" password="xx" groups="users"/>
</users>
</simpleAuthenticationPlugin>
<!-- Lets configure a destination based authorization mechanism -->
<authorizationPlugin>
<map>
<authorizationMap>
<authorizationEntries>
<authorizationEntry queue=">" read="admins" write="admins" admin="admins" />
<authorizationEntry queue=">" read="users" write="users" admin="admins" />
<authorizationEntry topic=">" read="admins" write="admins" admin="admins" />
<authorizationEntry topic=">" read="users" write="users" admin="admins" />
<authorizationEntry topic="ActiveMQ.Advisory.>" read="users,admins" write="users,admins" admin="users,admins"/>
</authorizationEntries>
</authorizationMap>
</map>
</authorizationPlugin>
</plugins>
解决的应用场景:
在开发时连调测试时,如果在客户端(生产者,消费者)在创建或消费,不存在的队列时,
BK就会自动创建,这些主题 或队列。
所以禁止客户端创建这些队列,只能读写。只有admin通过控制台创建队列。
所以配置如上
参考资料:
从上面的配置文件可以看出,ActiveMQ使用者针对不同的queue或者topic设置了可以进行操作的组。此处主要涉及三种操作权限:read, write, admin,下面对其详细介绍。
read:可以从queue或者topic里面接收消息
write:可以向queue或者topic发送消息
admin:可以创建queue或者topic(可能还有别的功能)
注意:如果做mater,slaver可能会报错
INFO | Network connection between vm://bk12#272 and tcp://dell-PC/192.168.23.184:61617@60885 shutdown due to a local error: java.lang.SecurityExcepti
on: User name [null] or password is invalid.
INFO | Connector vm://bk12 Stopped
解决方案:
<networkConnectors>
<networkConnector uri="multicast://default" userName="admin" password="admin"/>
</networkConnectors>
ActiveMq 生产端,客户端 ,连接Broker自动创建队列,解决方案
猜你喜欢
转载自cesymm.iteye.com/blog/1915462
今日推荐
周排行