配置RocketMQ ACL用户
RocketMQ实例开启ACL权限控制功能后,生产和消费消息时,须增加ACL用户信息,才能成功生产和消费消息。您还可以通过创建多个用户并为其赋予不同的Topic和消费组权限,以达到用户之间的权限隔离。
前提条件
- 已购买RocketMQ实例。
- 已开启ACL访问控制。
创建用户
- 登录管理控制台。
- 在管理控制台左上角单击,选择区域。
请选择RocketMQ实例所在的区域。
- 在管理控制台左上角单击,选择“应用中间件 > 分布式消息服务RocketMQ版”,进入分布式消息服务RocketMQ专享版页面。
- 在左侧导航栏,单击“用户管理”,进入“用户管理”页面。
- 单击“创建用户”,弹出“创建用户”对话框。
- 参考表1,填写用户名称和配置信息。
表1 用户参数说明 参数
说明
名称
自定义用户名称,用于识别不同的用户。
用户名称命名规则如下:- 长度为7~64个字符。
- 只能由英文字母、数字、中划线、下划线组成,且须以英文字母开头。
- 名称不可重复。
用户名创建成功后,不可修改。
IP白名单
如果请求的来源IP为IP白名单中的地址,不需要校验用户密钥是否正确,且具有所有Topic和消费组的发布+订阅权限。
IP白名单可以配置为具体的IP地址,也可以配置为网段。
- 多个IP时使用英文逗号隔开,如:192.168.1.2,192.168.2.3。
- IP网段值如192.*.*.*。
管理员
开启管理员时,具有所有Topic和消费组的发布+订阅权限。
5.x基础版不支持配置此参数。
默认Topic权限
指定用户的默认Topic权限。
取值范围:
- 禁止:表示用户既不可以往Topic发送消息,也不能消费Topic中的消息。
- 发布:表示用户只可以往Topic发送消息,不能消费Topic中的消息。
- 订阅:表示用户不可以往Topic发送消息,但可以消费Topic中的消息。
- 发布+订阅:表示用户既可以往Topic发送消息,也可以消费Topic中的消息。
如果为指定Topic设置特殊权限,则特殊权限会覆盖默认权限,此Topic的实际权限为特殊权限。例如:默认权限为订阅,指定Topic的特殊权限为发布+订阅,则此Topic实际权限为发布+订阅。
5.x基础版不支持配置此参数。
默认消费组权限
指定用户的默认消费组权限。
取值范围:
- 禁止:表示用户不能使用消费组消费消息。
- 订阅:表示用户可以使用消费组消费消息。
如果在为指定消费组设置特殊权限,则特殊权限会覆盖默认权限,此消费组的实际权限为特殊权限。例如:默认权限为订阅,指定消费组的权限为禁止,则此消费组实际权限为禁止。
5.x基础版不支持配置此参数。
密钥
设置用户的密钥。
密钥设置规则如下:- 长度为8~32个字符。
- 不能以“-”开头,至少包含三种字符:大写字母、小写字母、数字、特殊字符`~!@#$%^&*()-_=+\|[{}];:'",<.>/?。
- 不能与名称或倒序的名称相同。
- 单击“确定”,完成用户的创建。
(可选)为用户设置Topic/消费组权限
创建用户时会设置默认的Topic和消费组权限,如果需要修改默认权限,则可以在此处重新为用户设置。管理员默认具有所有权限,无需手动添加。
- 单击用户名称,进入用户详情页面。
- 在“Topic权限”/“消费组权限”页签中,单击添加权限,弹出“添加权限”对话框。
- 勾选需要添加权限的Topic或者消费组,选择所需的特殊权限,单击“确定”。
指定Topic或者消费组的特殊权限会覆盖默认权限,如图1中,test01的实际权限为发布+订阅。
编辑用户
- 登录管理控制台。
- 在管理控制台左上角单击,选择区域。
请选择RocketMQ实例所在的区域。
- 在管理控制台左上角单击,选择“应用中间件 > 分布式消息服务RocketMQ版”,进入分布式消息服务RocketMQ专享版页面。
- 单击RocketMQ实例的名称,进入实例详情页面。
- 在左侧导航栏,单击“用户管理”,进入“用户管理”页面。
- 在待修改的用户所在行,单击“编辑”,弹出“编辑用户”对话框。
- 根据业务需要修改用户信息。
用户名称不可修改,其他参数配置说明请参见表1。
- 单击“确定”,完成用户的修改。
删除用户
删除用户后会删除授权关系,原来使用该用户认证的请求将无法访问。
- 登录管理控制台。
- 在管理控制台左上角单击,选择区域。
请选择RocketMQ实例所在的区域。
- 在管理控制台左上角单击,选择“应用中间件 > 分布式消息服务RocketMQ版”,进入分布式消息服务RocketMQ专享版页面。
- 单击RocketMQ实例的名称,进入实例详情页面。
- 在左侧导航栏,单击“用户管理”,进入“用户管理”页面。
- 在待删除的用户所在行,单击“删除”,弹出“删除用户”对话框。
- 单击“确定”,完成用户的删除。