当前位置: 首页 > 面试题库 >

elasticsearch NodeBuilder与TranportClient

胡云瀚
2023-03-14
问题内容

对于其他Elasticsearch开发人员来说,这可能是一个非常简单(愚蠢的问题),这两者之间有什么区别?

我正在从Java
Web应用html" target="_blank">程序连接到远程Elasticsearch服务器,到目前为止,我一直在使用TransportClient,但是我想知道是否可以使用NodeBuilder,或者应该仅将NodeBuilder用于嵌入式客户端?

如果可以将两者中的任何一个用于连接到远程ES服务器,则在内存和性能方面哪个更好?

如果有人能指出我要连接到远程ES服务器的NodeBuilder的话,那很好,因为我还没有找到任何幸运的例子。

谢谢。


问题答案:

NodeBuilder也可以用于连接到集群。

Node node = nodeBuilder().clusterName("yourcluster").client(true).node();
Client client = node.client();

它将作为另一个节点加入群集,并将了解整个拓扑。使用节点,您可以使用多播来发现其他正在运行的节点。

我的观点是,我更喜欢使用它TransportClientNodeClient因为当TransportClient停止时,其他群集节点不会收到无用的信息。当NodeClient停止时,每个节点都必须知道,即使不必管理它,因为它不保存任何数据。另外,我已经看到在调试模式下,NodeClient
Threads比TransportCLient 可以启动更多。因此,我认为TransportClient的内存占用较少。

顺便说一句,如果您使用的是Spring,则可以使用spring-
elasticsearch
工厂。如果没有,您可以随时查看源代码,以了解如何管理NodeClient与TransportClient。

希望这可以帮助。

EDIT 2016-03-09NodeClient不应使用。如果有需要,人们应该创建一个客户端节点(使用node.data: false和启动elasticsearch节点node.master: false),并使用TransportClient本地连接到该客户端节点。



 类似资料:
  • 在C语言中,假设每个算法被赋予完全相同的一组进程,那么先到先得、最短作业优先和循环之间的周转时间是否相等?还是调度算法不同?

  • 问题内容: 为了为 HTML5 Doctype 定义字符集,我应该使用哪种表示法? 短: 长: 问题答案: 在HTML5中,它们是等效的。使用较短的一个,更容易记住和键入。浏览器支持很好,因为它是为向后兼容而设计的。

  • 连接的多个输入都相当于Yes的时候才会输出Yes。 用法 Your browser does not support the video tag. 案例:小闹钟 功能:今天15:10:00,响起猫叫声小闹钟 工作原理 当所有的输入都是Yes的时候,与节点才输出Yes。

  • 问题内容: 似乎有三种 相同的 方法可以独立于平台获取依赖于平台的“文件分隔符”: 我们如何决定何时使用哪个? 它们之间甚至有什么区别吗? 问题答案: 可以通过调用命令行参数或使用命令行参数覆盖 获取默认文件系统的分隔符。 获取默认文件系统。 获取文件系统的分隔符。请注意,作为一种实例方法,在需要代码在一个JVM中对多个文件系统进行操作的情况下,可以使用该方法将不同的文件系统传递给代码(而不是默认

  • 问题内容: 我今天刚刚与一些同事讨论了python的db-api fetchone vs fetchmany vs fetchall。 我确定每个应用程序的用例都取决于我正在使用的db-api的实现,但是总的来说,fetchone,fetchmany,fetchall的用例是什么? 换句话说,以下等效项是什么?还是其中之一比其他人更受青睐?如果是这样,在哪些情况下? 问题答案: 我认为这确实取决于