我的盒子上运行了以下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时,它告诉我我没有任何文档存储。我知道这是不对的,因为我肯定有弹性搜索中的文档。我猜测我的链接命令是错误的。
这是我用来启动kibana容器的docker命令。
docker run -p 5601:5601 --link sad_meitner:elasticsearch -d kibana
有人可以告诉我我做错了什么吗?
感谢
答案 0 :(得分:7)
首先,链接是一项传统功能,首先创建用户定义的网络:
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
您可以使用telnet
或curl
来验证来自kibana容器的kibana-> elasticsearch连接。
p.s我最近使用official (library)
码头图像用于ELK堆栈和用户定义的网络,它就像一个魅力。
答案 1 :(得分:1)
你可以在构建kibana之前将ENV ELASTICSEARCH_URL=elasticsearch:9200
添加到Dockerfile,然后使用docker-compose与kibana一起运行elasticsearch:
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