当前位置: 首页 > article >正文

docker安装的es报错了?failed to obtain node locks怎么破~

目录

一、问题分析

1.1 按惯例上报错

二、问题定位

2.1检查并修改数据目录权限

2.2检查权限

2.3清理 node.lock 文件

2.4然后重启 

三、实操检查

3.1检查权限

3.2执行指令

3.3检查

3.4再次启动

3.5检查一下端口

四、补充


 

一、问题分析

1.1 按惯例上报错

 failed to obtain lock on /usr/share/elasticsearch/data这句是关键! 

Caused by: java.io.IOException: failed to obtain lock on /usr/share/elasticsearch/data
Caused by: java.nio.file.NoSuchFileException: /usr/share/elasticsearch/data/node.lock
org.elasticsearch.server@8.6.2/org.elasticsearch.env.NodeEnvironment$NodeLock.<init>Suppressed: java.nio.file.AccessDeniedException: /usr/share/elasticsearch/data/node.lockjava.base/sun.nio.fs.UnixException.translateToIOException(UnixException.java:90)java.base/sun.nio.fs.UnixException.rethrowAsIOException(UnixException.java:106)
milvus-elasticsearch | ERROR: Elasticsearch did not exit normally - check the logs at /usr/share/elasticsearch/logs/docker-cluster.log

Elasticsearch(ES)容器启动失败,错误日志显示 failed to obtain node locks,可能的原因包括:

  1. 数据目录不可写:ES 需要对 /usr/share/elasticsearch/data 目录有写权限,但容器可能没有足够权限。
  2. 已有 ES 进程占用锁文件:如果之前的 ES 实例没有正确关闭,可能导致 node.lock 文件存在,阻止新的实例启动。
  3. Docker 挂载目录问题:如果你将 data 目录挂载到了宿主机,宿主机上的目录权限可能导致容器无法访问。

二、问题定位

2.1检查并修改数据目录权限

如果你挂载了本地目录作为 ES 数据目录,尝试执行:

sudo chmod -R 777 /your/local/path/to/data

或者,如果你不确定挂载了哪个目录,可以先进入容器:

docker exec -it milvus-elasticsearch bash ls -ld /usr/share/elasticsearch/data

2.2检查权限

这里检查的权限是要根据你docker-compose.yml里的配置去检查,比如我的配置是有挂载到/home/docker/milvus/volumes/elasticsearch/这个目录。

ls -ld /home/docker/milvus/volumes/elasticsearch

如果权限不足,可以尝试:

chmod -R 777 /usr/share/elasticsearch/data

2.3清理 node.lock 文件

可能是 node.lock 文件阻止 Elasticsearch 启动,删除它:

sudo rm -f /home/docker/milvus/volumes/elasticsearch/node.lock

2.4然后重启 

docker restart milvus-elasticsearch

三、实操检查

3.1检查权限

 

注意:显示的所有者是root,那我们就要修改为  1000:1000因为它是Elasticsearch 默认的 UID 和 GID。

3.2执行指令

sudo chown -R 1000:1000 /home/docker/milvus/volumes/elasticsearch
sudo chmod -R 777 /home/docker/milvus/volumes/elasticsearch

3.3检查

ls -ld /home/docker/milvus/volumes/elasticsearch

 

3.4再次启动

docker-compose down
docker-compose up -d

docker-compose up #这可以跟踪日志
docker-compose up -d #后台运行

3.5检查一下端口

四、补充

  • ls -ld /home/docker/milvus/volumes/elasticsearch 输出
  • docker logs milvus-elasticsearch 最新错误日志
  • docker inspect milvus-elasticsearch 的输出信息

 


http://www.kler.cn/a/584322.html

相关文章:

  • linux - ubuntu 使用时一些小问题整理 --- 持续更新
  • 级联树SELECTTREE格式调整
  • AI智能代码疫苗技术,赋能数字化应用内生安全自免疫
  • 通义万相 2.1 × 蓝耘智算:AIGC 界的「黄金搭档」如何重塑创作未来?
  • 解析富集分析中的过表达分析(ORA):原理、应用与优化
  • Axure PR 9 中继器 05 快捷查询
  • 从3b1b到课堂:教育3D化的理想与现实鸿沟
  • 深度学习 bert与Transformer的区别联系
  • 接入手机后,DeepSeek难“转正”
  • Pytorch中矩阵乘法使用及案例
  • Manus(一种AI代理或自动化工具)与DeepSeek(一种强大的语言模型或AI能力)结合使用任务自动化和智能决策
  • 视频理解之Actionclip(论文宏观解读)
  • 小米路由器SSH下安装DDNS-GO
  • 【学习笔记】语言模型的发展历程
  • vue2安装scss
  • Java 断言(Assert)机制
  • 西门子S7-1200 PLC远程调试技术方案(巨控GRM532模块)
  • 【蓝桥杯速成】| 1.暴力解题
  • 音视频入门基础:RTP专题(17)——音频的SDP媒体描述
  • NVIDIA k8s-device-plugin源码分析与安装部署