宝塔面板如何配置Node.js环境运行项目_使用Node版本管理器安装并启动PM2
知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个文章开发实战,手把手教大家学习《宝塔面板如何配置Node.js环境运行项目_使用Node版本管理器安装并启动PM2》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!
宝塔面板直接装Node.js会因路径、权限、环境变量不一致导致npm找不到、全局模块错位等问题;应改用nvm手动安装指定版本,并确保pm2在nvm激活环境下全局安装及启动,配合正确反向代理配置。

宝塔面板里直接装Node.js会踩哪些坑
宝塔面板自带的“软件商店”里点几下就能装 Node.js,但实际跑项目时大概率会出问题:路径不一致、权限不对、npm 命令找不到、全局模块装到错误位置——根本原因是宝塔默认用的是它自己编译的 Node 二进制,和系统 PATH、用户环境变量不联动,尤其当你需要配合 pm2 或使用 nvm 切换版本时,几乎必然失败。
所以别走快捷通道。真实可用的方式是:在宝塔的终端里,用用户身份(不是 root)手动装 nvm,再通过它装指定版本的 Node.js,最后用该环境启动 pm2。
用 nvm 安装 Node.js 并设为默认版本
登录宝塔终端(推荐用“SSH 终端”或“宝塔内置终端”,确保当前是你的网站部署用户,比如 www 或你创建的普通用户,**不要用 root**):
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.7/install.sh | bash
安装完后,关闭并重开终端,或手动加载:source ~/.bashrc(如果用 zsh,则是 source ~/.zshrc)。验证是否生效:nvm --version 应该输出版本号。
nvm install 18.19.0(选 LTS 版本更稳,避免用最新奇数版)nvm alias default 18.19.0(设为默认,新终端自动激活)nvm use 18.19.0(立即切换,确认node -v和npm -v正确)
注意:nvm 安装的 Node 和 npm 全局路径在 ~/.nvm/versions/node/v18.19.0/bin,这个路径不会自动加进系统 PATH,但 nvm use 后当前 shell 是可用的——这点直接影响后续 pm2 能否找到 node。
PM2 必须用 nvm 激活后的环境全局安装
很多人装了 pm2 却启动失败,报错 command not found: pm2 或 Cannot find module 'node:fs',本质是用了错误的 Node 环境执行 pm2。正确做法是:在 nvm use 激活好 Node 后,再全局安装:
npm install -g pm2
然后确认路径:which pm2 应该返回类似 /home/www/.nvm/versions/node/v18.19.0/bin/pm2。如果不是,说明 npm 没走对环境,可能之前装过系统级 pm2,得先 npm uninstall -g pm2 清掉。
启动项目时,也必须确保在同一个 shell 环境中运行:pm2 start ecosystem.config.js 或 pm2 start app.js。如果用宝塔“计划任务”或“网站监控”调用 PM2,它们默认不读 .bashrc,得显式加载环境:
- 写成完整命令:
source /home/www/.bashrc && pm2 start /www/wwwroot/myapp/app.js - 或者用
pm2 start的--interpreter指定解释器:pm2 start app.js --interpreter /home/www/.nvm/versions/node/v18.19.0/bin/node
宝塔网站配置与反向代理怎么配才不丢请求
Node.js 项目不能像 PHP 那样直接绑定到网站根目录。你得让项目监听一个本地端口(如 3000),再用宝塔的反向代理把域名流量转过去。关键点在于:
- 项目代码里
app.listen(3000, '127.0.0.1')—— 必须绑定127.0.0.1,不能是0.0.0.0(否则外网可直连,绕过宝塔防火墙和 SSL) - 宝塔网站 → “反向代理” → 添加,目标 URL 填
http://127.0.0.1:3000,务必勾选“启用反向代理”和“SSL 重定向”(如果你开了 HTTPS) - 如果项目里用了
req.headers.host或生成绝对 URL,要配好proxy_set_header Host $host;,宝塔默认已加,不用改;但若用pm2的express中间件做静态服务,注意静态路径别和宝塔网站根目录冲突
代理后常见 502 错误,优先检查:pm2 status 是否 online、netstat -tuln | grep :3000 是否真在监听、宝塔防火墙是否放行本地回环(一般不用动,但有些硬核安全策略会拦)。
真正麻烦的不是装,而是环境链路断在哪一环:nvm → node → npm → pm2 → 反向代理 → 请求头透传。漏掉任意一环,表现都是“项目不动”或“白屏”。尤其要注意宝塔后台操作(比如重启网站)不会自动 reload pm2 进程,得自己 pm2 reload 或加部署脚本。
今天关于《宝塔面板如何配置Node.js环境运行项目_使用Node版本管理器安装并启动PM2》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!
Excel怎么把所有工作表的名称提取出来_Excel提取所有工作表名称方法
- 上一篇
- Excel怎么把所有工作表的名称提取出来_Excel提取所有工作表名称方法
- 下一篇
- Golang如何使用组合模式构建树形结构_Golang Composite模式应用实践
-
- 文章 · php教程 | 5分钟前 |
- PHP8.3怎样调用NewInInitializers_PHP8.3初始化调用指南【配置】
- 286浏览 收藏
-
- 文章 · php教程 | 29分钟前 |
- 宝塔面板如何配置Composer镜像?在宝塔面板环境下加速PHP包下载
- 338浏览 收藏
-
- 文章 · php教程 | 43分钟前 | phpenv
- phpEnv解决PHP编译错误 phpEnv缺失开发库解决
- 220浏览 收藏
-
- 文章 · php教程 | 1小时前 |
- 为什么宝塔面板删除文件后磁盘空间不释放_清空回收站并检查进程占用
- 206浏览 收藏
-
- 文章 · php教程 | 1小时前 |
- 如何用wamp安装php环境_wampserver配置教程【图解】
- 328浏览 收藏
-
- 文章 · php教程 | 1小时前 |
- PHP读取加密文件怎么解密_PHP文件解密算法集成教程【解答】
- 323浏览 收藏
-
- 文章 · php教程 | 1小时前 | Webman
- Webman控制器依赖注入实现_PHP Webman容器IOC进阶用法【架构】
- 105浏览 收藏
-
- 文章 · php教程 | 1小时前 |
- PHP 应用监控:Sentry、New Relic与Prometheus集成
- 328浏览 收藏
-
- 文章 · php教程 | 1小时前 |
- 阿里云服务器如何放行宝塔端口?解决宝塔面板安装后打不开的问题
- 306浏览 收藏
-
- 文章 · php教程 | 2小时前 |
- Laravel 中对接 RabbitMQ 实现订单超时联动优惠券自动退回功能
- 156浏览 收藏
-
- 文章 · php教程 | 2小时前 |
- php nightrain 怎么用_PHP Nightrain工具(Linux部署)使用方法
- 380浏览 收藏
-
- 文章 · php教程 | 2小时前 |
- 如何在 MySQL 中创建每日凌晨自动重置字段的事件调度器
- 442浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 4982次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 5349次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 5228次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 7159次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 5609次使用
-
- PHP技术的高薪回报与发展前景
- 2023-10-08 501浏览
-
- 基于 PHP 的商场优惠券系统开发中的常见问题解决方案
- 2023-10-05 501浏览
-
- 如何使用PHP开发简单的在线支付功能
- 2023-09-27 501浏览
-
- PHP消息队列开发指南:实现分布式缓存刷新器
- 2023-09-30 501浏览
-
- 如何在PHP微服务中实现分布式任务分配和调度
- 2023-10-04 501浏览

