首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >无法通过java-client连接到Dockerized elasticsearch

无法通过java-client连接到Dockerized elasticsearch
EN

Stack Overflow用户
提问于 2015-05-14 15:08:13
回答 2查看 3.6K关注 0票数 13

我用官方的REPO elasticsearch docker镜像设置了一个elasticsearch容器。然后用以下命令运行它

代码语言:javascript
复制
docker run -dP elasticsearch

简单而有效。ps信息是

代码语言:javascript
复制
CONTAINER ID        IMAGE                  COMMAND                CREATED             STATUS              PORTS                                              NAMES
658b49ed9551        elasticsearch:latest   "/docker-entrypoint.   2 seconds ago       Up 1 seconds        0.0.0.0:32769->9200/tcp, 0.0.0.0:32768->9300/tcp   suspicious_albattani  

我可以使用http-client通过端口32769->9200访问服务器

代码语言:javascript
复制
baihetekiMacBook-Pro:0 baihe$ curl 10.211.55.100:32769
{
  "status" : 200,
  "name" : "Scorpia",
  "cluster_name" : "elasticsearch",
  "version" : {
    "number" : "1.4.5",
    "build_hash" : "2aaf797f2a571dcb779a3b61180afe8390ab61f9",
    "build_timestamp" : "2015-04-27T08:06:06Z",
    "build_snapshot" : false,
    "lucene_version" : "4.10.4"
  },
  "tagline" : "You Know, for Search"
}

现在,我需要我的JAVA程序来处理停靠的elasticsearch。java Node客户端只能通过32768->9300 (集群节点通话端口)连接到elasticsearch。因此,我在java中配置传输客户机,如下所示

代码语言:javascript
复制
    Settings settings = ImmutableSettings.settingsBuilder()
            .put("client.transport.sniff", true)
            .put("client.transport.ignore_cluster_name", true).build();
    client = new TransportClient(settings);
    ((TransportClient) client)
    .addTransportAddress(new InetSocketTransportAddress(
            "10.211.55.100", 32768));

然后,我在控制台中得到以下错误:

代码语言:javascript
复制
Caused by: org.elasticsearch.client.transport.NoNodeAvailableException: None of the configured nodes are available: []
    at org.elasticsearch.client.transport.TransportClientNodesService.ensureNodesAreAvailable(TransportClientNodesService.java:305)
    at org.elasticsearch.client.transport.TransportClientNodesService.execute(TransportClientNodesService.java:200)
    at org.elasticsearch.client.transport.support.InternalTransportIndicesAdminClient.execute(InternalTransportIndicesAdminClient.java:86)
    at org.elasticsearch.client.support.AbstractIndicesAdminClient.exists(AbstractIndicesAdminClient.java:170)
    at org.elasticsearch.action.admin.indices.exists.indices.IndicesExistsRequestBuilder.doExecute(IndicesExistsRequestBuilder.java:53)
    at org.elasticsearch.action.ActionRequestBuilder.execute(ActionRequestBuilder.java:91)
    at org.elasticsearch.action.ActionRequestBuilder.execute(ActionRequestBuilder.java:65)
    at cct.bigdata.yellowbook.service.impl.ResourceServiceImpl.<init>(ResourceServiceImpl.java:49)
    at cct.bigdata.yellowbook.config.YellowBookConfig.resourceService(YellowBookConfig.java:21)
    at cct.bigdata.yellowbook.config.YellowBookConfig$$EnhancerBySpringCGLIB$$e7d2ff3e.CGLIB$resourceService$0(<generated>)
    at cct.bigdata.yellowbook.config.YellowBookConfig$$EnhancerBySpringCGLIB$$e7d2ff3e$$FastClassBySpringCGLIB$$72e3e213.invoke(<generated>)
    at org.springframework.cglib.proxy.MethodProxy.invokeSuper(MethodProxy.java:228)
    at org.springframework.context.annotation.ConfigurationClassEnhancer$BeanMethodInterceptor.intercept(ConfigurationClassEnhancer.java:312)
    at cct.bigdata.yellowbook.config.YellowBookConfig$$EnhancerBySpringCGLIB$$e7d2ff3e.resourceService(<generated>)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:606)
    at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:166)
    ... 31 common frames omitted

当我直接在主机中运行elasticsearch时。一切都很好。

我在docker hub上检查了elasticsearch的所有dockerfile。它们似乎都只是简单地执行以下操作:

代码语言:javascript
复制
EXPOSE 9200 9300

我想知道有没有人尝试过做类似的事情。9300是正常的TCP端口还是UDP端口?在运行容器时,我需要做一些特殊的事情吗?谢谢!

EN

回答 2

Stack Overflow用户

发布于 2015-08-08 07:03:41

如果您将"client.transport.sniff"设置为false,它应该可以工作。

如果您仍然想使用嗅探,请按照下面的说明进行操作:https://github.com/olivere/elastic/wiki/Docker

在此详细讨论:https://github.com/olivere/elastic/issues/57#issuecomment-88697714

票数 8
EN

Stack Overflow用户

发布于 2017-09-24 03:22:57

这对我来说很有效(在docker-compose.yml中)。

代码语言:javascript
复制
version: "2"
services:
    elasticsearch5:
        image: docker.elastic.co/elasticsearch/elasticsearch:5.5.3
        container_name: elasticsearch5
        environment:
            - cluster.name=elasticsearch5-cluster
            - http.host=0.0.0.0
            - network.publish_host=127.0.0.1
            - transport.tcp.port=9700
            - discovery.type=single-node
            - xpack.security.enabled=false
        ports:
            - "9600:9200"
            - "9700:9700"

指定network.publish_host和transport.tcp.port似乎可以做到这一点。而且sniff=true仍然可以工作。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30231372

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档