docker 启动elasticsearch镜像,挂载目录后报错的解决

本站所有内容来自互联网收集,仅供学习和交流,请勿用于商业用途。如有侵权、不妥之处,请第一时间联系我们删除!Q群:迪思分享
免费资源网 – https://freexyz.cn/

从docker hub下载了一个es的镜像,版本为6.4.2,详细信息如下:

docker 启动elasticsearch镜像,挂载目录后报错的解决插图

比较重要的就是这两条,第一个是工作目录,挂载目录也需要和这里对应;第二个是启动命令,这里是指定了一个预先写好的启动脚本。所以我启动了一个空容器去查看了下容器内的情况:

docker 启动elasticsearch镜像,挂载目录后报错的解决插图1

容器内部目录结构如上图,data是用来存放数据,logs用来存放日志。

接着查看下启动脚本

/usr/local/bin/docker-entrypoint.sh

docker 启动elasticsearch镜像,挂载目录后报错的解决插图2

前半部分我也是看的一知半解,不过真正和挂载目录相关的是最后这部分,这里处理了挂载目录后的操作,大致意思是:

如果是root用户(docker启动容器,默认是以root用户身份),并且 TAKE_FILE_OWNERSHIP 变量存在,则将/usr/share/elasticsearch/{data,logs},这两个目录都改变为1000用户所属(这里也可以看到最终存储数据的路径为data,所以挂载时应该挂载到data下)。

id为1000的用户:

docker 启动elasticsearch镜像,挂载目录后报错的解决插图3

正是elasticsearch用户,所以如果不挂载任何目录直接启动容器即可,如果挂载,那么就添加一个变量,任意赋值,es可以正常启动。

docker run -itd -v /root/es-data/:/usr/share/elasticsearch/data -e TAKE_FILE_OWNERSHIP=111 -p 9200:9200 –name es elasticsearch:6.4.2

补充知识:记一次docker安装elasticsearch及遇到的坑

先给一行命令

docker run -d -p 9200:9200 -p 9300:9300 -e “ES_JAVA_OPTS=-Xms512m -Xmx512m” –name=


© 版权声明
THE END
★喜欢这篇文章吗?喜欢的话,麻烦动动手指支持一下!★
点赞6 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容