gpt4 book ai didi

java - Elasticsearch 5 Java 客户端给出 "NoNodeAvailableException"

转载 作者:IT老高 更新时间:2023-10-28 13:57:42 25 4
gpt4 key购买 nike

我正在使用 Elasticsearch 5.2Spring Boot 1.5.1。我通过 Spring 应用程序中的 Java 客户端连接到它。当我在端口 93009200 上连接到它时,我得到 NoNodeAvailableException: None of the configured nodes are available。在我的 Java 客户端中,我将 client.transport.sniff 属性设置为 true。通过端口 9200 上的 cURL 向它发送请求时,它工作正常。我在一个集群中有 4 个节点,我无法连接到其中任何一个。我的配置文件具有 network 部门中的所有默认值,除了具有 eth0 inet addrnetwork.host > 作为值。

我正在使用 Gradle。我的依赖是:

compile('org.springframework.boot:spring-boot-starter-web')
compile('org.elasticsearch:elasticsearch:5.2.0')
compile('org.elasticsearch.client:transport:5.2.0')
compile('org.apache.logging.log4j:log4j-api:2.7')
compile('org.apache.logging.log4j:log4j-core:2.7')

我连接 Elasticsearch 集群的代码:

@Bean
public TransportClient elasticClient() {
org.elasticsearch.common.settings.Settings settings = Settings.builder()
.put("client.transport.sniff", true)
.put("cluster.name", "TestCluster")
.build();
TransportClient client = null;
try {
client = new org.elasticsearch.transport.client.PreBuiltTransportClient(settings)
.addTransportAddress(new org.elasticsearch.common.transport.InetSocketTransportAddress(
InetAddress.getByName("54.175.155.56"), 9200));
} catch (UnknownHostException e) {
e.printStackTrace();
}
return client;
}

ES启动时我的ES日志是:

[2017-02-15T10:37:40,664][INFO ][o.e.t.TransportService   ] [ip-10-0-29-2] publish_address {10.0.29.2:9300}, bound_addresses {10.0.29.2:9300}
[2017-02-15T10:37:40,669][INFO ][o.e.b.BootstrapChecks ] [ip-10-0-29-2] bound or publishing to a non-loopback or non-link-local address, enforcing bootstrap checks
[2017-02-15T10:37:43,856][INFO ][o.e.c.s.ClusterService ] [ip-10-0-29-2] detected_master {kafka-stage}{sTIeF8gGTNam0oNW8dkbbA}{TTX6FIRtRp-gDemYY-22Sg}{10.0.20.71}{10.0.20.71:9300}, added {{kafka-stage-2}{jl3oLGgMQ1yxhdMMy65k_g}{ibV8BApjRByUOpDDncddyQ}{10.0.51.31}{10.0.51.31:9300},{ip-10-0-40-144}{t-_THs3wQbC_k9eivDo5eQ}{v-UYoYgXQ265QkdYhtiPYA}{10.0.40.144}{10.0.40.144:9300},{kafka-stage}{sTIeF8gGTNam0oNW8dkbbA}{TTX6FIRtRp-gDemYY-22Sg}{10.0.20.71}{10.0.20.71:9300},}, reason: zen-disco-receive(from master [master {kafka-stage}{sTIeF8gGTNam0oNW8dkbbA}{TTX6FIRtRp-gDemYY-22Sg}{10.0.20.71}{10.0.20.71:9300} committed version [98]])
[2017-02-15T10:37:44,009][INFO ][o.e.h.HttpServer ] [ip-10-0-29-2] publish_address {10.0.29.2:9200}, bound_addresses {10.0.29.2:9200}
[2017-02-15T10:37:44,009][INFO ][o.e.n.Node ] [ip-10-0-29-2] started

这些问题的答案并不能解决我的问题:

  1. Java ElasticSearch None of the configured nodes are available
  2. Elasticsearch - NoNodeAvailableException
  3. Elasticsearch NoNodeAvailableException issue

最佳答案

在您的 elasticsearch.yml 配置文件中,您需要确保绑定(bind)到正确的主机并具有以下设置:

network.host: 54.175.155.56

同样在您的 Java 代码中,由于您使用的是传输客户端,因此您需要使用端口 9300(用于 TCP 通信)而不是用于 HTTP 通信(例如通过 curl)的 9200

    client = new org.elasticsearch.transport.client.PreBuiltTransportClient(settings)
.addTransportAddress(new org.elasticsearch.common.transport.InetSocketTransportAddress(
InetAddress.getByName("54.175.155.56"), 9300));
^
|
change this

关于java - Elasticsearch 5 Java 客户端给出 "NoNodeAvailableException",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42134573/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com