- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
从官方的 Kafka 文档,以及我旅行期间翻腾的大量博客来看,我似乎可以启动一个 Kafka 代理,其 server.properties
配置文件包含:
authorizer.class.name=kafka.security.auth.SimpleAclAuthorizer
super.users=User:Bob;User:Alice
这定义了两个 super 用户(Bob + Alice),他们可以向我的代理人的主题生成消息,并从中使用消息。
但我如何从客户端利用这些用户?如果我有一个 Java 客户端需要向我的 Kafka 代理发送消息,该客户端如何“验证”自己为 ' Bob'(或'Alice',或任何其他 super 用户)?
super 用户密码在哪里定义/使用?!?
最佳答案
我这周做了一些挖掘,看起来 Kafka 本身不支持“基本身份验证”式(用户名 + 密码)凭据。
看起来您可以设置 Kerberos 或类似的解决方案(JAAS/SASL 等)来创建与 Kafka 一起工作的票证服务,这似乎是这些 ACL 的用途。我认为要点是您首先要针对 Kerberos 进行身份验证,此时您将获得票证/ token 。然后,您将向 Kafka 出示您的用户名/原则以及您的票证,Kafka 将与 Kerberos 合作以确保票证仍然有效。我认为这就是它的工作原理,基于我能够接触到的一些晦涩/模糊的博客。
我还看到证据表明 Kafka 目前或计划对 LDAP 提供某种集成层支持,因此您可以将 Kafka 集群连接到 AD 或类似设备。
奇怪的是,管理 Kafka 身份验证的最佳方式似乎是 Yahoo! Kafka Manager工具,这似乎是一个非常受欢迎、维护良好的项目,最近有很多更新和社区支持。这可能是我将要运行的,至少目前是这样。 HTH.
关于authentication - 从客户端使用 Kafka super 用户 ACL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40025832/
问题比较Java,但是我想在Android中实现: 假设有 3 个或更多类相互扩展: class A { ... int color; ... } class B extend
我知道标题听起来有点奇怪,但这正是我愿意做的。简单解释:A类是B类的子类,B类也是C类的子类>. 现在,所有这些类都包含方法m()。在我的 A 类中,这是我唯一可以访问的类,因为其他类仅在运行时可用,
我有一个 UIViewController 类 A 和 B。 A 使用以下方式加载 B:[A.view addSubView B.view]。 B 有一个带有“后退”按钮的导航栏。我想在单击时返回到
我有以下(第三方)类结构。我们将调用第三方项目 ProjectSeriously,并注意我使用 System.out.println 代替其他复杂的功能(100 行代码) . class A {
在下面的代码中,我从 Game 扩展了 MyGame。我有两个问题: 我们是否需要为所有render()、dispose()、pause()调用super方法 和 resize(w,h)?很多人都没有
例如,假设我想在调用 super.viewDidLoad() 时跳过一级。所以我希望能够做这样的事情: override func viewDidLoad() { super.super.vi
public class Faculty extends Employee { public static void main(String[] args) { new Fac
假设我有: class Superclass { //fields... methodA() {...} methodB() {...} ... } class Subclass exte
这个问题在这里已经有了答案: Why is super.super.method(); not allowed in Java? (22 个答案) 关闭 9 年前。 我怀疑我想做的事情是否可行。我有
我有一个实现 Initializable 的类。 public abstract class ExampleClass implements Initializable { public vo
我想知道,我有这个大数组,是否可以只在内存中使用一次而不是每个线程一次?以 stackoverflow 上的标签为例。他们几乎从不改变,为什么不为他们留下一个内存点呢?甚至可能将该数组永久保存在内存中
假设这三个类具有这个简单的层次结构: class A { func foo() { print("A") } } class B: A { override fu
有没有办法在 TypeScript 中调用 super.super.methodName。我想避免调用super.methodName,但我想调用二祖的methodName方法。 谢谢。 最佳答案 T
这个问题已经有答案了: When do I use super()? (11 个回答) 已关闭 7 年前。 package Geometry; public abstract class Geomet
我必须执行and()在我的实现 Predicate 的业务对象上. 出现问题的代码是 and() 行调用: Predicate predicate = new M
我有一个实现接口(interface)的抽象父类(super class): public abstract class FooMatrix implements Matrix { publi
我有四个 UIView:viewA 是 Root View ,它有 viewB 作为它的 subview 。 viewB 将 viewC 作为其 subview ,而 viewC 将 viewD 作为
有什么区别: class Child(SomeBaseClass): def __init__(self): super(Child, self).__init__() 和:
我有一个通用接口(interface) interface ListList extends List> .由于某些原因,我无法转换 ListList至 List> .有什么方法可以做到吗?为什么它不
我想调用带有两个参数的父类(super class)的构造函数,所以我调用了 super(arguments),但是编译器说: “类 Person 中的构造函数 Person 不能应用于给定类型; 要
我是一名优秀的程序员,十分优秀!