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。

相关推荐
雷欧力2 小时前
Claude Code 两个被低估的新命令:/goal 让它自己干到底,Agent View 让你同时盯十个任务
人工智能
小陈工2 小时前
Python异步编程进阶:asyncio高级模式与性能调优
开发语言·前端·数据库·人工智能·python·flask·numpy
Agent手记2 小时前
供应商资质智能审核自动化、落地方法与合规校验方案:AGI时代下的企业级风控重塑
运维·人工智能·ai·自动化·agi
数智工坊2 小时前
VMware 17 Pro 中 Ubuntu 虚拟机共享 Windows 文件夹(完美踩坑版)
linux·人工智能·windows·ubuntu
这张生成的图像能检测吗2 小时前
(论文速读)DSFormer:用于高光谱图像分类的双选择融合变压器网络
人工智能·深度学习·计算机视觉·transformer
黎阳之光2 小时前
黎阳之光:视频孪生硬核赋能,共启数字孪生水利监测新征程
大数据·人工智能·算法·安全·数字孪生
观测云2 小时前
观测云4月产品升级报告 | 统一目录、Obsy AI 全新上线,基础设施、场景、监控告警、管理多项能力升级
数据库·人工智能·可观测性·产品迭代·观测云
凌杰2 小时前
AI 学习笔记:关于 Hermes Agent 的补充
人工智能
wuxianda10302 小时前
uniapp项目上架苹果商店4.3a被拒,3天极速解决方案2026.5.8
前端·人工智能·flutter·uni-app·ios上架·苹果上架·苹果4.3a