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

相关推荐
神奇的程序员12 分钟前
从已损坏的备份中拯救数据
运维·后端·前端工程化
虾..1 小时前
Linux 软硬链接和动静态库
linux·运维·服务器
Evan芙2 小时前
Linux常见的日志服务管理的常见日志服务
linux·运维·服务器
玄斎2 小时前
MySQL 单表操作通关指南:建库 / 建表 / 插入 / 增删改查
运维·服务器·数据库·学习·程序人生·mysql·oracle
trayvontang3 小时前
Nginx之location配置
运维·nginx
十六年开源服务商3 小时前
WordPress定制开发最佳公司的用户画像
运维
hkhkhkhkh1233 小时前
Linux设备节点基础知识
linux·服务器·驱动开发
世岩清上4 小时前
AI驱动的智能运维:从自动化到自主化的技术演进与架构革新
运维·人工智能·自动化
HZero.chen4 小时前
Linux字符串处理
linux·string
张童瑶5 小时前
Linux SSH隧道代理转发及多层转发
linux·运维·ssh