nohup 是 linux 中用于让程序在终端关闭后持续运行的工具,通过忽略 sighup 信号并默认将输出重定向至 nohup.out 实现后台执行,适用于短期后台任务但不支持开机自启或自动重启。

nohup 是 Linux 中让程序在终端关闭后仍持续运行的常用工具,核心作用是忽略 SIGHUP(挂起信号),同时自动将标准输出和标准错误重定向到 nohup.out 文件,避免因终端退出导致进程被终止或输出丢失。
适合用 nohup 的典型场景
当需要长期运行、无需实时交互、且不依赖图形界面或 systemd 管理时,nohup 是轻量可靠的选择:
- 启动一个 Web 服务测试脚本(如 Python Flask 或 Node.js 小应用),只跑几个小时验证逻辑
- 执行耗时较长的数据处理任务(比如日志分析、文件批量转换),但不想一直开着 SSH 连接
- 在共享服务器上临时运行个人工具(如下载器、爬虫),没有权限配置系统服务或使用 screen/tmux
- 调试阶段快速验证后台行为,比写 service 文件更直接
nohup 基本用法与关键细节
最简命令是 nohup command &,但实际使用中要注意三点:
- 必须加
&放入后台,否则会阻塞当前终端;nohup 本身不自动后台化 - 默认输出追加到当前目录下的
nohup.out,若无写入权限会失败(可提前检查或指定路径) - 建议显式重定向:例如
nohup python3 server.py > server.log 2>&1 &,便于定位问题 - 进程仍受用户会话限制(如 ulimit、环境变量),不会继承登录 shell 的所有设置
nohup 的局限与替代思路
它不是万能方案,遇到以下情况应考虑其他方式:
- 需要开机自启或进程崩溃自动重启 → 用
systemd写 service 单元 - 要反复连接查看运行状态或交互操作 → 用
screen或tmux - 运行的是容器化应用 → 直接用
docker run -d - 需精细控制资源(CPU/内存限额)、日志轮转或健康检查 → 上
supervisord或云平台任务管理
如何确认 nohup 启动的程序还在运行
不能只看有没有输出文件,要查真实进程:
- 用
ps aux | grep "your_command"查进程是否存在(注意过滤掉 grep 自身) - 结合
pgrep -f "python3 server.py"更精准匹配命令行参数 - 检查
nohup.out或自定义日志末尾是否有最新时间戳或成功提示 - 如果程序监听端口,可用
ss -tuln | grep :port验证端口是否被占用









