docker容器启动命令:
docker run -dit --name dev_es -p 9200:9200 -p 9300:9300 \
-v /data/elasticsearch/data/:/usr/share/elasticsearch/data \
-v /data/elasticsearch/logs/:/usr/share/elasticsearch/logs \
-e "discovery.type=single-node" elasticsearch:7.16.2
部署elasticsearch时需要把数据和日志挂载在宿主机上,防止docker容器意外宕机,可以保证数据的安全和方便根据日志进行错误排查。
把docker容器中的/usr/share/elasticsearch/data挂载到宿主机的/data/elasticsearch/data下,日志同理。
看似很简单的命令,却报错java.nio.file.AccessDeniedException:/usr/share/elasticsearch/data/nodes,看到这个错误的时候以为是容器中的/usr/share/elasticsearch/data/nodes目录权限不够,
真正的原因是宿主机上的/data/elasticsearch/data目录权限不足导致的!!!
但是错误日志报的却是docker容器下的
/usr/share/elasticsearch/data/nodes目录,宿主机权限不足导致无法写入,影响到docker容器也无法正常写入。
具体解决方案很简单,就是给/usr/share/elasticsearch/data这个目录对应的宿主机目录授权,日志文件目录同理。
chmod 777 /data/elasticsearch/data