CentOS系统部署Node.js应用详细步骤指南
在CentOS上部署Node.js应用:一份清晰的操作指南
将Node.js应用部署到CentOS服务器,听起来可能涉及不少环节,但别担心,整个过程其实可以梳理得相当清晰。核心步骤无非是准备环境、上传代码、启动服务这几大步。下面这份指南,会带你一步步走完从安装到上线的全过程。
免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
1. 安装Node.js
在CentOS上安装Node.js,你有几种选择:使用系统自带的包管理器、从NodeSource仓库安装,或者直接下载二进制包。其中,通过NodeSource安装特定版本是个常用且可靠的方法。
使用NodeSource安装Node.js
NodeSource提供了便捷的安装脚本。以安装Node.js 14.x版本为例,操作如下:
# 添加NodeSource仓库curl -sL https://rpm.nodesource.com/setup_14.x | sudo bash -# 安装Node.jssudo yum install -y nodejs
验证安装
安装完成后,务必确认一下Node.js和它的包管理器npm是否就位。打开终端,输入:
node -vnpm -v
如果正确显示了版本号,恭喜你,第一步已经稳稳完成了。
2. 设置环境变量(可选)
根据应用需要,你可能得设置一些环境变量,比如指定运行环境为生产环境。常见的做法是把它们加到用户配置文件~/.bashrc里,或者放到/etc/profile.d/目录下的脚本中。
举个例子,如果想设置NODE_ENV,可以编辑~/.bashrc文件,加入这行:
export NODE_ENV=production
保存后,别忘了让配置立刻生效:
source ~/.bashrc
3. 上传应用代码
接下来,得把你的代码搬到服务器上。常用的传输工具有scp、rsync,或者直接从Git仓库克隆。这里以scp为例:
使用SCP上传文件
scp -r /path/to/your/nodejs-app user@your-server:/path/to/deploy
执行命令后,你的项目文件就会安全地抵达服务器指定目录。
4. 安装依赖项
代码到位后,进入项目目录,安装项目运行所依赖的包。这步很简单:
cd /path/to/deploy/nodejs-appnpm install
耐心等待npm拉取所有依赖,项目的基础环境就搭建好了。
5. 启动应用
启动Node.js应用,你有几种不同选择,从简单到专业,各有适用场景。
直接使用node命令启动
最直接的方式,适合快速测试:
node app.js
不过,这种方式在终端关闭后应用也会停止,不适合生产环境。
使用pm2启动
对于生产部署,强烈推荐使用进程管理工具pm2。它能守护进程、管理日志、实现零停机重启。首先全局安装它:
sudo npm install -g pm2
然后用它来启动应用,并给应用起个名字:
pm2 start app.js --name my-app
想看看所有应用的状态?运行这个命令一目了然:
pm2 status
使用systemd服务启动
如果你希望应用能像系统服务一样随服务器开机自启,那么配置systemd服务是个好主意。先创建一个服务文件:
sudo nano /etc/systemd/system/my-app.service
在文件中填入类似下面的配置,记得替换其中的路径和用户名:
[Unit]Description=My Node.js AppAfter=network.target[Service]ExecStart=/usr/bin/node /path/to/deploy/nodejs-app/app.jsRestart=alwaysUser=your-userEnvironment=NODE_ENV=production[Install]WantedBy=multi-user.target
保存退出后,启动并启用这个服务:
sudo systemctl start my-appsudo systemctl enable my-app
这样,你的应用就成为一个标准的系统服务了。
6. 配置防火墙
为了让外界能访问你的应用,别忘了在防火墙放行流量。如果服务器使用的是firewalld
sudo firewall-cmd --permanent --zone=public --add-service=httpsudo firewall-cmd --permanent --zone=public --add-service=httpssudo firewall-cmd --reload
7. 访问应用
至此,所有部署工作就完成了。现在,打开浏览器,访问你的服务器地址和对应的端口(例如 http://your-server:3000),应该就能看到应用正常运行了。
总的来说,在CentOS上部署Node.js应用,只要遵循环境准备、代码部署、服务启动和网络配置这几个关键阶段,就能顺利搞定。当然,根据应用的具体情况,可能还需要考虑数据库连接、反向袋里(如Nginx)等其他配置,但以上步骤已经为你搭建了一个坚实可靠的起点。
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
Ubuntu系统下使用Go语言实现机器学习的实践指南
在Ubuntu上使用Go进行机器学习需先安装环境并配置工作空间,通过goget获取golearn等库。编写代码遵循数据加载、模型训练、预测评估的流程后运行程序。Go在性能与并发方面有优势,但生态不如Python丰富,更适合特定工程场景或统一技术栈的团队探索。
Ubuntu系统下Go语言程序打包方法与核心要点
在Ubuntu中打包Go应用需关注环境配置、交叉编译与优化。通过GoModules管理依赖,使用CGO_ENABLED=0生成静态二进制文件以实现跨平台兼容。利用UPX和链接器参数减小体积,采用Docker多阶段构建制作最小镜像。交付时建议包含平台信息并签名,注意解决动态库依赖和版本锁定等常见问题。
Android开发中高效管理多个CheckBox组件的实用技巧
在Android应用开发过程中,高效管理多个功能相似的复选框(CheckBox)是提升开发效率的关键。无论是应用设置界面、多选列表,还是动态生成的选项列表,如果对每个CheckBox都进行单独引用和操作,代码会迅速变得冗长且难以维护。那么,是否存在更优雅的解决方案?答案是肯定的——通过数组或动态集合
面向对象编程中封装字段如何提升代码安全性与维护性
将类的公共字段改为私有,并提供公共的获取和设置方法,是提升代码安全性与可控性的基础重构。此举能防止外部随意读写,避免状态失控,并便于后续加入校验、脱敏等控制逻辑,适用于核心业务或敏感字段。
Master-Worker架构解析如何实现并发任务的负载均衡与结果高效合并
Master-Worker架构的核心在于实现任务划分、动态负载均衡与可靠结果合并的协同:任务必须具备无依赖性与可聚合性,负载需依据节点实时能力进行动态分配,结果合并则需通过唯一ID、版本号及超时重试机制确保不丢失、保顺序、容故障。 构建一个高性能的Master-Worker并发架构,核心在于系统性地
- 日榜
- 周榜
- 月榜
1
2
3
4
5
6
7
8
9
10
1
2
3
4
5
6
7
8
9
10
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

