Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/spring-boot/5.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java Elasticsearch客户端可以';t连接docker容器中的elasticsearch_Java_Spring Boot_Docker_<img Src="//i.stack.imgur.com/RUiNP.png" Height="16" Width="18" Alt="" Class="sponsor Tag Img">elasticsearch_Docker Compose - Fatal编程技术网 elasticsearch,docker-compose,Java,Spring Boot,Docker,elasticsearch,Docker Compose" /> elasticsearch,docker-compose,Java,Spring Boot,Docker,elasticsearch,Docker Compose" />

Java Elasticsearch客户端可以';t连接docker容器中的elasticsearch

Java Elasticsearch客户端可以';t连接docker容器中的elasticsearch,java,spring-boot,docker,elasticsearch,docker-compose,Java,Spring Boot,Docker,elasticsearch,Docker Compose,我试图在容器中使用Elasticsearch,它来自一个Java应用程序,也在容器中。如果没有docker容器,我的应用程序将正确连接到本地elasticsearch。我的docker撰写文件: version: "3.7" volumes: postgis: services: database: container_name: database build: postgis/ ports: - 5432:5432 volum

我试图在容器中使用Elasticsearch,它来自一个Java应用程序,也在容器中。如果没有docker容器,我的应用程序将正确连接到本地elasticsearch。我的docker撰写文件:

version: "3.7"

volumes:
  postgis:

services:
  database:
    container_name: database
    build:
      postgis/
    ports:
      - 5432:5432
    volumes:
      - ./postgis:/var/lib/postgresql:rw
    restart: on-failure
    networks:
      - net

  application:
    depends_on:
      - database
      - es
    container_name: application
    build:
      application/
    ports:
      - $LORRYAPP_DEBUG_PORT:8080
    volumes:
      - ./application:/app:rw
    environment:
      LORRYAPP_OPTS: $LORRYAPP_OPTS
    restart: on-failure
    networks:
      - net

  es:
    image: docker.elastic.co/elasticsearch/elasticsearch:7.6.1
    ports:
      - "9200:9200"
      - "9300:9300"
    environment:
      - discovery.type=single-node
    networks:
      - net

networks:
  net:
    driver: bridge
初始化ctor中的客户端:

public ElasticSearchDao(ObjectMapper mapper) {
    this.esClient = new RestHighLevelClient(RestClient.builder(HttpHost.create("http://localhost:9200")));
    this.mapper = mapper;
} 
堆栈跟踪:

java.net.ConnectException: Connection refused
        at org.elasticsearch.client.RestClient.extractAndWrapCause(RestClient.java:788) ~[elasticsearch-rest-client-7.4.0.jar!/:7.4.0]
        at org.elasticsearch.client.RestClient.performRequest(RestClient.java:218) ~[elasticsearch-rest-client-7.4.0.jar!/:7.4.0]
        at org.elasticsearch.client.RestClient.performRequest(RestClient.java:205) ~[elasticsearch-rest-client-7.4.0.jar!/:7.4.0]
        at org.elasticsearch.client.RestHighLevelClient.internalPerformRequest(RestHighLevelClient.java:1454) ~[elasticsearch-rest-high-level-client-7.4.0.jar!/:7.4.0]
        at org.elasticsearch.client.RestHighLevelClient.performRequest(RestHighLevelClient.java:1424) ~[elasticsearch-rest-high-level-client-7.4.0.jar!/:7.4.0]
        at org.elasticsearch.client.RestHighLevelClient.performRequestAndParseEntity(RestHighLevelClient.java:1394) ~[elasticsearch-rest-high-level-client-7.4.0.jar!/:7.4.0]
        at org.elasticsearch.client.RestHighLevelClient.index(RestHighLevelClient.java:836) ~[elasticsearch-rest-high-level-client-7.4.0.jar!/:7.4.0]
ES可通过浏览器获取,答复:

{
  "name" : "254bdb7bcc2a",
  "cluster_name" : "docker-cluster",
  "cluster_uuid" : "vm537RNGSiG3dW8ag2MDTw",
  "version" : {
    "number" : "7.6.1",
    "build_flavor" : "default",
    "build_type" : "docker",
    "build_hash" : "aa751e09be0a5072e8570670309b1f12348f023b",
    "build_date" : "2020-02-29T00:15:25.529771Z",
    "build_snapshot" : false,
    "lucene_version" : "8.4.0",
    "minimum_wire_compatibility_version" : "6.8.0",
    "minimum_index_compatibility_version" : "6.0.0-beta1"
  },
  "tagline" : "You Know, for Search"
}

我想这可能和我很久以前问过的问题有关


它针对的是C#,这确实是容器的问题。在我的案例中,客户端将连接到docker,获取仅用于容器间通信的内部IP,然后尝试使用此IP保持连接打开-这显然不起作用。

如果您谈论的是跨容器,则它不是本地主机。Docker networking很好地解析了容器名称,因此在您的案例中,URL应设置为
http://es:9200
用于集装箱间通信。