Linux环境下Node.js后台运行方式(实用版)

Linux环境下Node.js后台运行方式(实用版)

在Linux服务器部署Node.js项目时,直接通过npm start启动应用后,终端关闭会导致进程终止,无法实现长期稳定运行。本文整理两种常用且实用的后台运行方式,其中pm2推荐用于生产环境,screen/tmux适合临时调试或简单部署,步骤清晰可直接复制操作,附异常解决和截图预留。

一、推荐方式:pm2(生产环境首选)

pm2是Node.js生态中成熟的进程管理工具,支持进程守护、自动重启、日志管理、开机自启等功能,能有效保障项目稳定运行,解决终端关闭导致进程中断的问题。

1.1 常见异常及解决(必看)

在执行pm2相关命令时,常遇到「pm2未找到命令」「npm未找到命令」的问题,如下所示,已给出对应解决方法:

异常1:pm2命令未找到

root@jumpserver server# pm2 status

-bash: pm2: 未命令

异常2:npm命令未找到(本质是Node.js未正确激活)

root@jumpserver server# npm install -g pm2

-bash: npm: 未找到命令

解决方法:激活已安装的Node.js版本(以nvm管理的node16为例)

root@jumpserver server# nvm install 16 # 若未安装则安装,已安装则提示已存在

v16.20.2 is already installed.

Now using node v16.20.2 (npm v8.19.4) # 激活成功,此时npm可正常使用

1.2 pm2完整操作步骤

步骤1:安装pm2(全局安装,一次安装终身使用)

npm install -g pm2

步骤2:启动Node.js应用(核心命令)

pm2 start npm --name "your-app" -- start

说明:

1. "your-app" 替换为你的项目名称(自定义,方便后续管理)

2. 末尾的 start 对应你package.json中scripts里的启动命令(若你的启动命令是dev,需改为 -- dev)

步骤3:查看应用运行状态

pm2 status

此处插入pm2 status命令执行后的截图,可清晰看到项目名称、进程ID、运行状态(online/offline)、CPU/内存占用等信息。

步骤4:删除指定应用进程(补充常用命令,适配需求)

pm2 delete dev-server # 删除名称为dev-server的应用进程

此处插入pm2 delete dev-server命令执行后的截图,展示进程删除成功的提示信息。

步骤5:启动指定名称的应用(适配需求命令)

pm2 start npm --name "dev-server" -- run dev

说明:run dev 对应package.json中scripts里的dev启动命令,需根据自身项目配置调整

此处插入pm2 start npm --name "dev-server" -- run dev命令执行后的截图,展示应用启动成功的提示。

步骤6:查看指定应用详情(补充常用命令,适配需求)

pm2 show dev-server # 查看名称为dev-server的应用详细信息(端口、日志路径等)

此处插入pm2 show dev-server命令执行后的截图,展示应用的详细配置及运行信息。

步骤7:查看应用运行日志(排查问题必备)

步骤4:查看应用运行日志(排查问题必备)

pm2 logs

可选:查看指定项目的日志

pm2 logs your-app

步骤8:设置pm2开机自启(生产环境关键步骤)

默认情况下,服务器重启后pm2管理的进程会丢失,需执行以下命令设置开机自启:

pm2 startup # 生成开机自启脚本

pm2 save # 保存当前pm2管理的进程列表

二、备选方式:screen/tmux(临时调试/简单部署)

screen和tmux是Linux下的终端会话管理工具,通过创建独立会话,让Node.js应用在会话中运行,即使关闭终端,会话依然保持,适合临时调试项目或简单部署(不推荐生产环境,无自动重启功能)。

2.1 screen操作步骤(更简单,推荐新手)

步骤1:安装screen(根据Linux系统版本选择命令)

CentOS/RHEL系统(如阿里云、腾讯云服务器常用)

yum install screen -y

Ubuntu/Debian系统

apt-get install screen -y

步骤2:创建新的screen会话(自定义会话名称,方便识别)

screen -S myapp # myapp替换为你的会话名称(如node-project)

步骤3:在会话中启动Node.js应用

cd 你的项目目录 # 先进入项目根目录

npm start # 启动应用(与平时启动方式一致)

步骤4:分离会话(关闭终端不中断进程)

在启动应用的终端中,按快捷键:Ctrl + A → 松开后按 D,即可分离会话,此时应用仍在后台运行,可安全关闭终端。

步骤5:重新连接会话(查看或操作应用)

screen -r myapp # myapp替换为你创建的会话名称

若提示多个会话,可先执行 screen -ls 查看会话ID,再用 screen -r 会话ID 连接

2.2 补充说明

tmux操作逻辑与screen类似,功能更强大,但命令稍复杂,新手可先掌握screen,后续按需学习tmux。两种工具均无自动重启功能,若应用崩溃,需手动重新启动,因此仅适合临时使用。

三、总结

  • 生产环境:优先使用pm2,支持进程守护、自动重启、开机自启,稳定性高,日志管理便捷;

  • 临时调试/简单部署:使用screen,操作简单,快速实现后台运行,无需复杂配置;

所有命令均经过实际测试,可直接复制执行,若遇到其他异常,可在评论区留言交流。

相关推荐
kebidaixu1 小时前
BCU 平台 RS485 驱动适配:从 THVD1406 到 ISO3082
linux
杨浦老苏1 小时前
家庭实验室监控仪表盘HomeLab-Monitor
运维·docker·监控·群晖
回忆2012初秋2 小时前
【Nginx】原理、配置与运维实战(2)
运维·nginx·策略模式
Urbano3 小时前
工装外套全制作流程、工序痛点及自动化设备升级方案
运维·自动化
映翰通朱工3 小时前
工业4G网关无公网IP远程运维实战(内网终端异地访问方案)
运维·服务器·网络·安全·智能路由器
洪晓露3 小时前
将 rke2 集群证书延长至 10 年
运维·服务器·数据库
谢平康4 小时前
解决用 rm 报bash: /usr/bin/rm: Argument list too long错
linux·运维·运维开发
IP老炮不瞎唠4 小时前
Python 价格监控如何实现?思路与实用方法分享
运维·服务器·网络
GIS数据转换器4 小时前
城市排水生命线安全运行监测平台深度解析
java·运维·人工智能·python·安全·数据挖掘·无人机
Tokai_Teio_15 小时前
第四届黄河流域 misc
运维·服务器