elasticsearch 使用 systemd 启动时卡在 starting 状态 解决过程记录

上个星期使用 二进制包 elasticsearch-9.2.1-linux-x86_64.tar.gz 安装 elasticsearch 之后,遇到了一个问题,当执行 systemctl start elasticsearch.service 命令之后 就卡住了,状态如下:

另开一个窗口执行 systemctl status elasticsearch 可以看出, elasticsearch 实际上已经启动成功,但是 systemd 给出状态却停留在 Starting...:

打开浏览器也可以看到 elasticsearch 服务的状态是正常的:

从上面的截图上可以看到,elasticsearch.service 的 Main PID 是 15688 ,即 /usr/local/elasticsearch/jdk/bin/java -Xms4m -Xmx64m...这个进程通常是 Elasticsearch 的启动器 (Launcher) 或 Java wrapper。它的主要任务是设置环境变量、配置 JVM 参数,然后 exec 或 fork 出真正运行 Elasticsearch 服务的 Java 进程。

进程 15789 /usr/local/elasticsearch/jdk/bin/java -Des.networkaddress.cache.ttl=60...是运行 Elasticsearch 核心功能 的 主 Java 进程。它是实际负责监听 9200 和 9300 端口、处理索引和查询请求的进程。当前 elasticsearch.service 里面 Service Type 配置的是 notify,服务在完成初始化并准备好接受请求时,必须通过 sd_notify() 函数向 systemd 发送一个 READY=1 信号。systemd 会等待这个就绪信号,收到信号后才将服务标记为 active (running)。导致 systemctl start elasticsearch.service 命令一直阻塞 的原因就是 systemd 没有收到 就绪信号。

解决方式:将 elasticsearch.service 里面 Service Type 配置成 forking 并将 NotifyAccess=all 与 Environment=ES_SD_NOTIFY=true 注释掉

修改之后,systemctl daemon-reload 然后启动就正常了:

这里还有一个重点,修改后的 Main PID 变成了 /usr/local/elasticsearch/jdk/bin/java -Des.networkaddress.cache.ttl=60... 进程的 PID

相关推荐
i建模19 分钟前
统一pnpm的版本
运维
sdm07042722 分钟前
Linux-基础IO
linux·运维·操作系统·理解文件
OpsEye28 分钟前
CPU 只有 30%,系统却慢到不可用?
运维
爱吃生蚝的于勒31 分钟前
【Linux】网络之http协议
linux·运维·服务器·网络·数据结构·c++·http
创世宇图31 分钟前
Alibaba Cloud Linux 安装生产环境-Tomcat
linux·tomcat
margu_16832 分钟前
【Elasticsearch】es7.2 跨集群迁移大量数据方法二
elasticsearch
蜜獾云33 分钟前
Elastic Stack基础概念
运维·jenkins
fakerth35 分钟前
【Linux】调度器底层原理深入探索
linux·c++·操作系统
历程里程碑43 分钟前
44. TCP -23Linux聊天室实现命令符功能
java·linux·开发语言·数据结构·c++·排序算法·tcp
wanhengidc1 小时前
企业如何有效利用高防服务器
运维·服务器·网络·安全·web安全·智能手机