【发布时间】:2016-06-23 04:31:24
【问题描述】:
我正在尝试使用 Docker 运行 ELK 堆栈。我发现docker-elk 已经使用docker-compose 为我设置了配置。
我想将 elasticsearch 数据存储在主机而不是容器上。根据 docker-elk 的 README,我在 elasticsearch 的 docker-compose.yml 部分添加了 volumes 行:
elasticsearch:
image: elasticsearch:latest
command: elasticsearch -Des.network.host=0.0.0.0
ports:
- "9200"
- "9300"
volumes:
- ../../env/elasticsearch:/usr/share/elasticsearch/data
但是,当我运行 docker-compose up 时,我得到:
$ docker-compose up
Starting dev_elasticsearch_1
Starting dev_logstash_1
Starting dev_kibana_1
Attaching to dev_elasticsearch_1, dev_logstash_1, dev_kibana_1
kibana_1 | Stalling for Elasticsearch
elasticsearch_1 | [2016-03-09 00:23:35,193][WARN ][bootstrap ] unable to install syscall filter: seccomp unavailable: your kernel is buggy and you should upgrade
elasticsearch_1 | Exception in thread "main" java.lang.IllegalStateException: Unable to access 'path.data' (/usr/share/elasticsearch/data/elasticsearch)
elasticsearch_1 | Likely root cause: java.nio.file.AccessDeniedException: /usr/share/elasticsearch/data/elasticsearch
elasticsearch_1 | at sun.nio.fs.UnixException.translateToIOException(UnixException.java:84)
elasticsearch_1 | at sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:102)
elasticsearch_1 | at sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:107)
... etc ...
查看../../env,确实创建了elasticsearch目录,但它是空的。如果我创建../../env/elasticsearch/elasticsearch,那么我会收到/usr/share/elasticsearch/data/elasticsearch/nodes 的访问错误。如果我创建/nodes,那么我会收到/nodes/0 的错误,等等...
简而言之,容器似乎没有目录的写权限。
如何让它拥有写权限?我试过chmod a+wx ../../env/elasticsearch,然后它设法创建下一个目录,但是那个目录有drwxr-xr-x的权限,它又卡住了。
我不喜欢必须以 root 身份运行它的想法。
【问题讨论】:
-
docker-compose run --rm elasticsearch stat -c "%U %G" /usr/share/elasticsearch/data的输出是什么? -
@kojiro:我得到
UNKNOWN staff
标签: macos docker file-permissions docker-compose docker-toolbox