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

相关推荐
方便面不加香菜6 分钟前
Linux--基础IO(一)
linux·运维·服务器
鼎讯信通2 小时前
风电光缆运维提质增效:G-4000A 光缆故障追踪仪破解风场巡检难题
运维·网络·数据库
三十..3 小时前
MySQL 从入门到高可用架构实战精要
运维·数据库·mysql
fangdengfu1233 小时前
ES分析系统各个服务日志占用量
java·前端·elasticsearch
跨境数据猎手4 小时前
大数据在电商行业的应用
大数据·运维·爬虫
linyanRPA4 小时前
影刀RPA店群自动化实战:多店铺活动自动报名与促销管理架构设计
运维·自动化·办公自动化·rpa·python脚本·爬虫自动化·店群自动化
mounter6254 小时前
现代 Linux 内存管理的演进与变革:从传统 LRU 到多代架构 MGLRU
linux·服务器·kernel
会Tk矩阵群控的小木4 小时前
安卓群控系统对于游戏工作室实战教程
android·运维·游戏·adb·开源软件·个人开发
赵渝强老师5 小时前
【赵渝强老师】Kubernetes(K8s)中的金丝雀升级
linux·docker·云原生·容器·kubernetes
佛山个人技术开发5 小时前
GitCode SSH连接配置教程
运维·ssh·gitcode