WSL 里跑 Node.js 服务:nohup 对它无效,我翻了 5 次车才摸清

标签: WSL · Node.js · Linux · 后端 · 踩坑记录


01 问题

在 WSL Ubuntu 里装了 Hermes Agent,配了 Dashboard(9119)和 hermes-web-ui(8648)。两个服务都起来了,浏览器能打开,登录也正常。

但发送消息没反应。

没有报错,没有超时,就是安静地不动。


02 排查

查了一下端口情况:

端口 服务 状态
9119 Hermes Dashboard 监听中
8642 Hermes Gateway(后端 API) 没起来
8648 hermes-web-ui(前端) 监听中

问题找到了:8642 端口没开,Web UI 根本连不上后端 API。


03 第一次尝试:nohup + disown

先启动 Hermes Gateway:

bash 复制代码
nohup hermes gateway run > hermes_gateway.log 2>&1 &
disown

8642 端口起来了。关闭终端再检查------端口没了

原因:用 subprocess.run() 调 WSL 命令,每次都是一个新的 bash 进程。进程结束后,它衍生的所有子进程也会一起被清理。


04 第二次尝试:hermes-web-ui 也用 nohup

bash 复制代码
nohup /usr/bin/node /usr/lib/node_modules/hermes-web-ui/dist/server/index.js > webui.log 2>&1 &
disown

进程秒退。日志到 gateway manager initialized 就停了,没有报错。

Python 进程用 nohup 还能撑一会儿,Node.js 进程直接退出了。disown 对 Node.js 不起作用。


05 第三次尝试:setsid

bash 复制代码
setsid /usr/bin/node /usr/lib/node_modules/hermes-web-ui/dist/server/index.js > webui.log 2>&1 < /dev/null &

还是秒退。nohup + setsid 组合也试了,一样。


06 第四次尝试:timeout

timeout 跑前台看看:

bash 复制代码
timeout 5 /usr/bin/node /usr/lib/node_modules/hermes-web-ui/dist/server/index.js

日志完整输出:

csharp 复制代码
[bootstrap] listening on 0.0.0.0:8648
Server: http://localhost:8648

服务能起来,但 timeout 结束就停了,无法常驻。


07 解法:screen -dmS

换用 screen

bash 复制代码
screen -dmS hermes-webui /usr/bin/node /usr/lib/node_modules/hermes-web-ui/dist/server/index.js

8648 端口稳稳亮起,进程在 screen 会话里挂着,关闭终端也不掉。

Gateway 同样用 screen:

bash 复制代码
screen -dmS hermes-gateway bash -c "source ~/.hermes/hermes-agent/.venv/bin/activate && exec hermes gateway run > hermes_gateway.log 2>&1"

08 为什么 nohup 对 Node.js 无效

nohup 负责忽略 SIGHUP 信号,这部分没问题。真正的问题在于父进程生命周期

  • Python 进程被 nohup 后,父 bash 退出时会被 init 接管,继续运行
  • Node.js 对 SIGHUP 的处理有时会触发额外清理逻辑,或者 V8 垃圾回收在没有 TTY 时行为异常,导致进程主动退出

screen 创建了一个真正的守护终端,Node.js 运行在一个完整会话里,不依赖任何父进程。


结论

WSL/Linux 里让 Node.js 服务持久运行的正确方式:

bash 复制代码
# ✅ screen
screen -dmS <session-name> node your-app.js

# ❌ nohup / disown / setsid 对 Node.js 均不可靠

把持久化交给 screen。

相关推荐
Ada's7 小时前
方法论01:如何写好一篇期刊论文
人工智能
szxinmai主板定制专家7 小时前
基于 ARM+FPGA精密多轴实时运动控制卡设计方案,适用于半导体设备等高精度领域(一)
arm开发·人工智能·嵌入式硬件·fpga开发·架构·语音识别
2601_958352907 小时前
车载蓝牙通话的声学突围:A-29P 在智能座舱语音处理中的核心技术优势解析
人工智能·回音消除·音频处理模块·智能车载硬件
mykj15517 小时前
AI旅拍小程序定制开发,解锁文旅变现新赛道
人工智能·小程序
voidmort7 小时前
9. 微调(Fine-tuning)的数学原理
人工智能·算法·机器学习
zzhongcy7 小时前
AI时代软件开发的深度感悟
人工智能
zhangfeng11337 小时前
国家超算中心 htc 如果只有gpu资源 没有cpu资源 操作文件的时候会不会很卡呢
人工智能·pytorch·python·机器学习
零壹AI实验室7 小时前
英伟达Vera Rubin芯片:Blackwell直接过时?Agentic AI时代的硬件革命
人工智能
coder Ethan7 小时前
Spring AI 入门:(3)快速搭建一个简单的问答助手
java·人工智能·spring
高兴高兴张高兴7 小时前
张高兴的 Hailo-10 开发指南:(一)实现离线语音识别
人工智能·语音识别