- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在使用 kafka-clients用于将 Kafka 与 Scala 应用程序集成的库。并且发现很难理解代理人和生产者/消费者之间如何以及何时建立 TCP 连接。
请验证我对以下几点的理解-
(1) KafkaProducer实例初始化时没有建立TCP连接。
val producer = new KafkaProducer[String, String](properties)
这也适用于 KafkaConsumer。
val consumer = new KafkaConsumer[String, String](properties)
(2) 第一个 TCP 连接(在 Broker 和 Producer 之间)是在向 Broker 生成记录时建立的。
producer.send(record1)
(3) 从同一个生产者到同一个代理的后续 send()
调用将共享同一个 TCP 连接,而不管主题如何。
producer.send(record2)
(4) 在消费者的情况下,第一个 TCP 连接是在轮询主题(而不是订阅)时建立的。
val records = consumer.poll(timeout)
(5) 同一 Consumer 对同一 Broker 的后续轮询调用共享同一连接。
最佳答案
No TCP connection is established on initialisation of KafkaProducer instance.
不完全是。 KafkaProducer 初始化将从多个 TCP 连接中启动 Sender 线程,以建立所有引导服务器。这些套接字将用于从集群中检索元数据。
First TCP connection (between Broker and Producer) is established on producing a record to Broker.
几乎正确。实际上,客户端总是创建到代理的多个 TCP 连接。当您只有一个经纪人时,情况更是如此。对于producer来说,往往会创建两个connection,一个用于更新Metadata,一个用于发送消息。对于消费者(假设您使用的是消费者组),它似乎会创建 3 个连接。一个用于寻找协调员;一个用于组管理(包括加入/同步组和偏移量);一个用于检索偏移量,最后一个用于拉取消息。
更新:消费者创建了 3 个连接,而不是我之前声称的 4 个。感谢@ppatierno 的提醒。
Subsequent send() calls from the same Producer to same Broker will share same TCP connection irrespective of the Topic.
后续发送调用重用生产者创建的第二个连接。
In case of Consumer, first TCP connection is established on polling a Topic (not on Subscription).
是的,所有连接都在 poll
调用中创建。
Subsequent calls to poll by the same Consumer to the same Broker share the same connection.
对轮询的后续调用会重用消费者创建的最后一个连接。
关于scala - kafka-clients scala 库如何管理 TCP 连接?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47936073/
Java 库和 android 库有什么区别,各自有什么优点/缺点? 最佳答案 您可以在 Android 应用程序中包含标准 Java .jar 文件库。它们在 .apk 构建时被翻译成 Dalvik
所以,我现在的代码就像从 Java 层加载库(比如 liba.so),并在内部 liba.so 加载 libb.so。因此,如果我必须将所有库打包到 APK 中并将其安装在没有 root 访问权限的设
我想在我的系统中设置 LEDA 库。 我已经从以下链接下载了 LEDA 库 http://www.algorithmic-solutions.info/free/d5.php Instruct
我想用 autoconf 创建一个共享库。但是,我希望共享库具有“.so”扩展名,而不是以“lib”开头。基本上,我想制作一个加载 dlopen 的插件。 .是否有捷径可寻? 当我尝试使用 autoc
我需要在 Apps 脚本应用程序上修改 PDF。为此,我想使用 JS 库:PDF-LIB 我的代码: eval(UrlFetchApp.fetch("https://unpkg.com/pdf-lib
我正在构建一个使用以下 Boost header 的程序(我使用的是 Microsoft Visual C++ 10), #include #include #include #include
当我通过 cygwin 在 hadoop 上运行此命令时: $bin/hadoop jar hadoop-examples-*.jar grep input output 'dfs[a-z.]+' 我
我已经通过 vcpgk 成功安装了一个 C++ 库,名为:lmdb:x64-windows 我还安装了lmdb通过 Cabal 安装的 Haskell 绑定(bind)包 在尝试测试 lmdb 包时:
我该如何解决这个问题? 我刚刚将 javacv jar 文件复制到我的项目 Lib 文件夹下,但出现了这个错误! 我可以找到这个thread来自谷歌,但不幸的是,由于我国的谷歌限制政策,该页面无法打开
我有一个 Android 库项目 FooLib。 FooLib 引用 Android Context 之类的东西,但不需要任何资源文件(res/ 中的东西)所以我目前将其打包为供我的应用使用的 JAR
我正在开发一个 Android 应用程序(使用 Android Studio),它能够通过手势识别算法了解您正在进行的 Activity 。对于我使用 nickgillian ithub 帐户上可用的
关于从 .NET Framework 项目中引用 .NET Standard 类库的问题有很多类似的问题,其中 netstandard 库中的 NuGet 包依赖项不会流向 netframework
我已经从互联网上下载了 jna-4.2.2.jar,现在想将这个 jar 导入到我的项目中。但是当我试图将这个 jar 导入我的项目时,出现以下错误。 [2016-06-20 09:35:01 - F
我正在尝试通过编译在 Mac 上安装 rsync 3.2.3。但是,我想安装所有功能。为此,它需要一些库,此处 ( https://download.samba.org/pub/rsync/INSTA
进入 Web 开发有点困难。过去 5 年我一直致力于 winforms 工作。所以我正在努力从一种切换到另一种。前段时间,我使用过 JavaScript,但现在还没有大量的 JavaScript 库
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
我正在寻找一个用Python编写的与logstash(ruby + java)类似的工具/库。 我的目标是: 从 syslog 中解析所有系统日志 解析应用程序特定日志(apache、django、m
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我花了几天时间试图寻找用于 JavaPOS 实现的 .jar 库,但我找不到任何可以工作的东西。我找到了很多像这样的文档:http://jpos.1045706.n5.nabble.com/file/
这个问题在这里已经有了答案: Merge multiple .so shared libraries (2 个答案) 关闭 9 年前。 我有我在代码中使用的第三方库的源代码和对象。该库附带有关如何使
我是一名优秀的程序员,十分优秀!