繁体   English   中英

将kibana与elasticsearch链接

[英]linking kibana with elasticsearch

我的盒子上正在运行以下Docker容器...

CONTAINER ID        IMAGE               COMMAND                  CREATED              STATUS              PORTS                              NAMES
5da7523e527b        kibana              "/docker-entrypoint.s"   About a minute ago   Up About a minute   0.0.0.0:5601->5601/tcp             elated_lovelace
20aea0e545ca        elasticsearch       "/docker-entrypoint.s"   3 hours ago          Up 3 hours          0.0.0.0:9200->9200/tcp, 9300/tcp   sad_meitner

我的目标是让kibana链接到我的elasticsearch容器,但是当我点击kibana时,它告诉我我没有任何文档存储。 我知道这是不对的,因为我肯定在Elasticsearch中有文件。 我猜我的链接命令是错误的。

这是我用来启动kibana容器的docker命令。

docker run -p 5601:5601 --link sad_meitner:elasticsearch -d kibana 

有人可以告诉我我做错了什么吗?

谢谢

首先,链接是旧功能,首先创建用户定义的网络:

docker network create mynetwork --driver=bridge

现在,将mynetwork用于您希望能够相互通信的容器。

docker run -p 5601:5601 --name kibana -d --network mynetwork kibana 
docker run -p 9200:9200 -p 9300:9300 --name elasticsearch -d --network mynetwork elasticsearch

Docker将为您的用户定义的网络运行dns server ,因此您可以按名称ping其他容器。

docker exec -it kibana /bin/bash
ping elasticsearch

您可以使用telnetcurl来验证kibana容器中的kibana-> elasticsearch连接。

ps我最近将ELK堆栈的official (library) docker镜像与用户定义的网络一起使用,它的工作原理很吸引人。

您可以在构建kibana之前将ENV ELASTICSEARCH_URL=elasticsearch:9200添加到您的Dockerfile中,然后使用docker-compose通过kibana运行弹性搜索,如下所示:

version: '2'
services:
  elasticsearch:
   image: docker.elastic.co/elasticsearch/elasticsearch:5.3.0
   container_name: elasticsearch
   ports:
    - "9200:9200"
    - "9300:9300"
  environment:
    ES_JAVA_OPTS: "-Xmx256m -Xms256m"
 kibana:
  image: docker.elastic.co/kibana/kibana:5.3.0
  container_name: kibana
  ports:
    - "5601:5601"
  depends_on:
   - elasticsearch

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM