阿里云(ubuntu)服务器部署nodejs项目

本文介绍如何通过阿里云Ubuntu服务器部署Node.js项目,包括服务器配置、数据盘挂载、Node.js及MongoDB安装、FTP服务搭建、项目上传等步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

服务器的配置

远程连接服务器
  • 下载安装xShell,百度搜索xshell有很多,安装完成之后 点击文件-》新建 协议选择:ssh,主机写自己的公网ip;端口号:22之后 点身份验证:分别输入linux云服务器ESC实例的用户名和密码。 之后点连接就连接成功。就可以进行接下来的操作了。
xshell.png
linux格式化和挂载数据盘,
  • 阿里云服务器第一次使用需要先格式化数据盘和挂载数据盘

  • 首先输入fdisk -l命令后,发现/dev/vdb,说明实例含有数据盘,需要挂载

    x1.png
  • 运行fdisk /dev/vdb,对数据盘进行分区,依次输入n,p,1,然后按两次回车,最后输入wq,进行分区

  • 分区完成之后运行fdisk -l命令,查看新的分区。可以看到新的分区vdb1已经创建好了。

    x2.png
  • 运行mkfs.ext3 /dev/vdb,对新分区进行格式化。

  • 格式化完成之后运行echo /dev/xvdb1 /mnt ext3 defaults 0 0 >> /etc/fstab (这是一条命令)写入分区信息。

  • 完成之后运行 cat /etc/fstab 可以进行查看

  • 运行mount /dev/vdb1 /mnt 挂载新分区,然后执行df -h 查看分区,如果出现数据盘信息,说明挂载成功,就可以开始使用新分区了 至此阿里云服务器配置完成,阿里云服务器里面是空的,要想部署nodejs项目,还需要安装nodejs和mongoDB软件 参考网址

阿里云ubuntu服务器nodejs环境的搭建
  • 输入命令apt-get update 更新源
  • 更新完成之后输入命令apt-get install -y curl,进行安装curl用来下载资源
  • 下载完成之后输入命令 curl -sL https://deb.nodesource.com/setup_4.x | sudo -E bash - ,下载node安装脚本
  • 下载完成之后输入apt-get install nodejs 进行安装nodejs
  • 安装完成之后输入node -v 和npm -v查看node和npm是否安装成功
  • 输入命令apt-get install mongodb 进行安装mongodb
  • 安装完成之后输入service mongodb start可以进行启动mongodb
  • 输入命令ps aux | grep mongo ,结果显示含有mongodb说明安装成功 至此nodejs环境已经搭建成功,要想把nodejs项目放到服务器上去,我们首先需要vsftdb来搭建ftp服务。
vsftpd上安装和配置vsftpd
  • 直接输入命令apt-get install vsftpd 进行vsftpd的安装
  • 安装之后输入servive vsftpd restart 判断是否安装成功
  • 输入mkdir /home/project 来创建目录
  • 输入命令 useradd -d /home/project -s /bin/bash project 创建用户,创建成功之后输入命令passwd project 来设置密码,需要输入两次密码
  • 然后修改vsftpd的配置文件输入命令 vim /etc/vsftpd.conf
  • 修改如图:

    vsftpd.png
vsftpd2.png
  • 然后配置完成,可以使用xftp进行上传文件
xftp进行上传文件
  • xftp安装完成之后,点击文件-》新建
  • 协议一定要选择SFTP,然后主机输自己的公网IP,端口号22,登录的用户名和密码分别是自己ESC实例的用户名和密码,输完之后点击确定就可以连接到自己的主机了,就可以往服务器上放自己的nodejs项目了

    ftp2.png
ftp.png
  • 在往服务器上放项目的时候需要注意的是linux系统下的mode_modules和windows下的不一样,所以项目的时候需要先把项目里面的mode_modules给删掉,然后再在该项目下运行npm install进行安装
  • 之后输入node ./bin/www就可以启动项目了

forever让nodejs应用后台执行

  • nodejs一般是当成一条用户命令执行的,当用户断开客户连接,运用也就停了,很烦人。使用forever可以使nodejs应用当成服务,在后台执行
  • 输入命令 npm install forever -g 进行安装
  • 输入 forever start app.js 启动nodejs项目, 输入forever stop app.js 可以关闭。 至此,阿里云(ubuntu)服务器部署nodejs项目
作者:wuyumumu 链接:https://www.jianshu.com/p/8fb738cd8672 來源:简书 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
<think>好的,用户想知道如何在阿里云ECS服务器部署Node.js应用程序。我需要根据提供的引用内容来整理步骤。首先,用户提供的引用有三个,都是关于在阿里云ECS部署Node.js项目的教程,所以需要综合这些信息。 首先,步骤应该是购买和配置ECS服务器。引用1和2提到了学生认证和购买ECS,可能需要指导用户如何申请学生优惠,重置密码等。接下来是连接服务器,引用2提到了使用终端连接,可能包括SSH连接的方法,以及安装宝塔面板,这部分需要详细说明。 然后是服务器环境的配置,比如安装Node.js。引用2提到在服务器上下载Node.js,可能需要说明使用包管理器安装的方法,比如用apt-get或者从源代码安装。同时,引用3提到了使用express框架,可能需要安装npm包,比如express。 接着是部署项目文件。引用3提到通过Git导入项目文件,或者使用FTP工具上传。这里需要分步骤说明如何将本地的Node.js代码上传到服务器,比如使用scp命令或者宝塔面板的文件管理功能。 然后是安装依赖和开放端口。引用2中提到了开放Node.js代码中的端口,包括宝塔面板和服务器安全组的设置。用户可能需要知道如何在阿里云控制台配置安全组规则,放行相应的端口,比如3000或者80端口。 接下来是运行应用程序,并保持后台运行。引用2提到了使用nohup命令,这样即使关闭终端,应用也能持续运行。需要说明nohup的使用方法,比如nohup node index.js &。 最后是配置Nginx反向代理和SSL证书。引用1提到申请免费SSL证书,并配置多网站。这里可能需要指导用户如何通过Nginx配置反向代理到Node.js应用的端口,以及如何配置HTTPS,提升安全性。 还要考虑常见问题,比如引用2中的图片加载问题、端口无法访问、服务器连接问题等,可能需要给出一些排查步骤,比如检查防火墙设置,确认端口是否正确开放,查看日志文件等。 需要确保步骤清晰,逻辑顺序正确,用户能够一步步跟随操作。同时,要引用对应的引用来源,比如在购买ECS时引用[^1][^2],在安装Node.js时引用[^2][^3],在配置Nginx时引用等。另外,用户可能关心如何管理多个网站,所以需要简要提及Nginx的多站点配置方法,如引用1所述。 最后生成相关问题,可能涉及性能优化、HTTPS配置、多应用部署等,根据引用内容中的知识点来提问,比如如何优化Node.js性能,如何配置SSL证书,如何处理多个Node.js应用部署等。</think>### 如何在阿里云ECS服务器部署Node.js应用程序? 以下是分步骤的详细教程,结合阿里云ECS环境配置与Node.js项目部署的核心要点: --- #### **一、服务器购买与基础配置** 1. **购买ECS实例** - 登录[阿里云官网](https://www.aliyun.com/),完成实名认证与学生认证(学生可享免费试用或优惠)。 - 选择操作系统(推荐Ubuntu/Centos),配置安全组规则(预先开放SSH端口22、HTTP端口80、HTTPS端口443及Node.js应用端口如3000)。 2. **连接服务器** - 使用终端通过SSH连接: ```bash ssh root@<服务器公网IP> ``` - 首次登录后重置密码,并更新系统: ```bash apt update && apt upgrade # Ubuntu yum update # Centos ``` --- #### **二、安装Node.js环境** 1. **通过包管理器安装** - **Ubuntu**: ```bash curl -fsSL https://deb.nodesource.com/setup_lts.x | sudo -E bash - sudo apt install -y nodejs ``` - **Centos**: ```bash curl -fsSL https://rpm.nodesource.com/setup_lts.x | bash - yum install -y nodejs ``` - 验证安装:`node -v` 和 `npm -v`[^3]。 2. **全局工具配置(可选)** ```bash npm install -g pm2 # 进程管理工具 ``` --- #### **三、部署Node.js项目文件** 1. **上传代码到服务器** - 方法一:通过Git克隆项目: ```bash git clone <仓库地址> cd <项目目录> npm install # 安装依赖 ``` - 方法二:使用SCP/FTP工具上传本地文件: ```bash scp -r ./local_project root@<服务器IP>:/opt/node_app ``` 2. **配置应用端口** - 确保代码中监听的端口(如3000)与服务器安全组、宝塔面板(若使用)中开放的端口一致。 --- #### **四、运行与持久化服务** 1. **直接运行** ```bash node index.js # 测试运行(关闭终端会终止服务) ``` 2. **后台运行** - 使用`nohup`保持进程: ```bash nohup node index.js > app.log 2>&1 & ``` - 或使用PM2管理: ```bash pm2 start index.js --name "my-app" pm2 save && pm2 startup # 持久化进程 ``` --- #### **五、Nginx反向代理与HTTPS配置** 1. **安装Nginx** ```bash apt install nginx # Ubuntu yum install nginx # Centos systemctl start nginx ``` 2. **配置反向代理** - 编辑Nginx站点配置文件(如`/etc/nginx/conf.d/node_app.conf`): ```nginx server { listen 80; server_name your_domain.com; location / { proxy_pass http://localhost:3000; # 指向Node.js应用端口 proxy_set_header Host $host; } } ``` - 重载配置:`nginx -s reload`[^1]。 3. **申请SSL证书** - 在阿里云控制台申请免费SSL证书,下载Nginx版本证书文件(`.crt`和`.key`)。 - 修改Nginx配置启用HTTPS: ```nginx server { listen 443 ssl; ssl_certificate /path/to/cert.crt; ssl_certificate_key /path/to/cert.key; # 其他配置同上 } ``` --- #### **六、常见问题解决** - **端口无法访问**:检查安全组规则、服务器防火墙(`ufw`/`iptables`)及应用日志。 - **图片/静态资源加载失败**:确保文件路径正确,Nginx配置中静态资源代理无误[^2]。 - **多网站部署**:在Nginx中为每个域名创建独立的配置文件,绑定不同端口或域名[^1]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值