问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

kafka ACL常用权限操作

发布网友 发布时间:2022-11-27 10:13

我来回答

1个回答

热心网友 时间:2023-10-16 08:22

kafka ACL常用权限操作

使用bin/kafka-topics.sh创建
注意工具bin/kafka-topics.sh访问的是zookeeper而不是kafka,即他是一个zookeeper client而不是一个kafka client,所以它的认证都是通过zookeeper完成的。

Case 1:如果zookeeper没有配置ACL激活:

Case 2:如果zookeeper已经配置ACL激活:

命令还是前面的那个命令,但是必须提供java.security.auth.login.config指向jaas.conf文件。例如:

命令的配置可以直接修改jvm的启动脚本,或者设置在环境变量里:

这里配置的用户必须是zookeeper服务端已经配置运行可以访问的客户端用户。例如,下面的zookeeper服务端配置:

运行客户端为admin的用户作为zookeeper客户端连接访问。

查询topic操作的ACL认证,同前面创建topic操作的认证一样,不细说,参考前面。

删除topic操作的ACL认证,同前面创建topic操作的认证一样,不细说,参考前面。

procer用的脚本是/opt/kafka/bin/kafka-console-procer.sh,注意这个procer脚本是和kafka打交道的(相对bin/kafka-topics.sh是和zookeeper打交道的),所以:

命令行格式:

文件/path/to/client-sasl.properties

还需要配置client用户信息,并传给JVM参数:

此时如果没有授权,则会得到如下错误信息:

赋予procer的权限:

这个选项--procer实际上在Topic域上创建了(Write/Describe/Create)3个子权限:

当然用户也可以单独创建者三个子权限。

consumer用的脚本是/opt/kafka/bin/kafka-console-consumer.sh,注意和生产者procer一样,consumer也是和kafka打交道的(相对于bin/kafka-topics.sh是和zookeeper打交道的),所以:

命令行格式:

选项--from-begining可以调整成其他值;配置文件/path/to/client-sasl.properties和procer的一样,不细说,参考生产者。

此时如果没有授权,则会得到如下错误信息:

赋予consumer的权限:

和procer相比,consumer还有一个额外的参数--group,如果没有*,则置成'*'即可;这个--consumer的选择实际上在Topic域上创建了(Read/Describe)2个子权限,然后在Group域创建了(Read)1个子权限:

这个地方我们注意一下,consumer没有Create的权限,所以如果kafka配置成auto.create.topics.enable=true,而此时topic不存在,那么consumer试图创建topic的时候会失败,那就需要一条单独的Create授权规则来给consumer增加Create权限。

权限管理工具以命令行的方式管理权限,可以增加/删除/列举所有的权限规则。

基本用法:

授权用户kafaclient具有Read topic kafaclient--topic的权限。

删除用户kafaclient具有Describe topic kafaclient--topic的权限。

查看当前在topic kafkaclient--topic上面的权限列表。

另外注意,和kafka-topics.sh一样,kafka-acls.sh也是直接访问zookeeper的,而不是访问kafka,所以它的认证方式和kafka-topics.sh是一样的:

详细的用法配置请参考kafka-topics.sh部分,不细说。

在kafka2.0之后引入了--resource-pattern-type这个参数,可以针对特定的资源(topic)命名规则,例如前缀,来为某一类的topic添加规则。而之前的办法只能读完整的topic设置规则,字符''表示所有的,这不是规则表达式匹配任意字符的意思,而就是文本字符''。

例如:

授权用户kafkaclient具有访问所有以'kafkaclient--'开头的topic的权限;这样带来的好处是,以后我们使得kafkaclient创建的topic全部以'kafkaclient--'开头,那么就不需要再为这些topic创建rule,一条rule就能够动态的管理新加的topic。

其实我对这个还是不满意,如果能够定义灵活规则就好了;因为上面的*,我还是需要为每一个用户添加一条规则,而我想为所有的用户只用一条规则,这条规则就是:任何用户具有访问以这个用户名开头的所有的topic;这样不管以后新加topic还是新加用户,都不用再新加rule了。遗憾的是目前kafka还是不支持这个功能。类似:

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
个人账户养老金预测公式:现有5万元,缴费20年,能领多少钱? 临沂比较有名的男装品牌 呼伦贝尔市悦动网络科技有限公司怎么样? 呼伦贝尔中汇实业有限公司怎么样? 呼伦贝尔油玉不绝电子商务有限公司怎么样? 如何避免wps卡顿? 属鼠的男人找对象是属什么,属鼠的人和什么属相合 96年鼠的姻缘在哪年 属相相合年份运势提升 2024属鼠找对象属什么最佳 黑客攻击网站能报案吗 关于kafka消费者的命令 描写老师的文章 描写老师的文章范文 我想问一下关于花儿与爱情的句子 去北京市东城区,社保中心领取退休档案审批意见什么意思 组织部对干部人事档案的认定意见可以提出异议吗 干部基本信息审核认定可以由档案管理人员提出认定意见吗 张忠华的获奖及荣誉称号 致蒋憧先生的信--关于轻谈 山东大学研究生院的招生情况 阿里否认总裁蒋凡降职传闻,那蒋总裁会主动离开吗?小编认为不会 你好,别人聊天时经常说核电这个词,弱弱的问一句核电是什么意思? 国科大优秀博士论文指导教师奖励多少钱 姓蒋 能取什么微博名 RTMFP server 连接失败怎么搞 rtmfpp2pdisable=1可以改成别的数字吗 rtmfpturnproxy怎么设置 flex怎么截取通过rtmfp传过来的流的显示区域(如videodisplay组件) 如何禁止服务器使用 rtmfp 南京天堂村附近哪有教堂?什么教的都可以,知道的全说出来 请问面包硬了怎么变软? kafka 常见命令以及增加topic的分区数 三、Kafaka的基本操作 kafka消费者状态检查—消费的offset是否滞后/堆积 Kafka身份认证与权限控制配置 微信里的信用卡账单来了!短信为什么没有来 宁夏坐高铁到宜昌怎么走? 青莲火车站和高铁站是同一个站吗? 蛋卷可以放几天 蛋卷怎么保存 蛋卷心填充材料做法 qq飞车至曜暗影怎么获得 求QQ飞车A车子弹,针尖,流火。维纳斯,雷诺,暗影,冰魄最简单的购买方法。 QQ飞车A车怎么得? qq飞车a车神影怎么弄的好多人都有 广东优派家私集团怎么样? 山东财经大学燕山学院教务管理系统入口http://jwc.ys.sdufe.edu.cn/ 山东财经大学教务系统登陆不上 山东财经大学迎新系统 腌笃鲜做法 腌笃鲜怎么做 重写(覆盖,Override)和重载(Overload)的区别 overload和override都叫重载,都在什么情况下用阿?