2024 年在 AWS 云 Ubuntu 服务器通过 PM2 部署 Nest.js 项目教程

今年第一次在 Ubuntu 上面部署 Nest.js 项目,因为各个组件每年的版本都会发生变化,这里记录一下环境搭建的过程,帮助大家少踩坑。

首先在 AWS 云上面开通一台 EC2 的服务器,EC2 是弹性计算、按照使用量收费的服务器,性价比很高。具体开通步骤就不赘述了。

开通后使用 pem 文件登陆,pem 通常来说会比密码更加安全。

ssh 复制代码
ssh -i /path/to/xxx.pem user@server_ip

连接到服务器后开始搭建环境。

node.js 环境搭建

第一步是更新一下 apt 包管理器的包列表信息。

shell 复制代码
sudo apt update

第二步是安装 Node.js,注意不要直接用 sudo apt install nodejs 来安装 node.js,因为这样安装的版本是 12.x。这是 Ubuntu 包管理器的策略,它们会以稳定性优先,所以往往都不会包含软件包的最新版本。

想要安装高版本的 node.js 有三种方式:

  1. 使用 node.js 官网的二进制文件。
  2. 使用 NodeSource 二进制分发 PPA。我们可以指定不同版本的 node.js 进行安装。
  3. 使用 nvm。nvm 的优势是可以方便的切换版本。

通常都会根据需求选择后两种安装方式。

这里我采取了第二种安装方式,因为我的 Node.js 版本是固定的,没有切换版本的需求。不过也会顺便讲一下第三种的安装方式。

首先通过 cURL 下载二进制安装脚本,并把它放到临时目录中。

shell 复制代码
curl -sL https://deb.nodesource.com/setup_20.x -o /tmp/nodesource_setup.sh

然后执行脚本。

shell 复制代码
sudo bash /tmp/nodesource_setup.sh

执行完脚本之后,会自动更新软件包信息。

现在我们可以通过 apt 安装 node.js 了。

shell 复制代码
sudo apt install nodejs

安装完成后测试是否安装成功。

shell 复制代码
node -v

输出正确的版本号就代表安装成功了。

pm2 环境搭建与项目部署

接下来把源代码上传到服务器。这里的方式比较原始,后面我搭建了自动化部署,篇幅所限,会再写一篇文章讲一下通过 Github Actions 来实现自动化部署。

上传文件可以用 rsync,rsync 会比 scp 有更多的功能,比如增量上传、带宽限制、过滤文件等。

shell 复制代码
rsync -avz --progress --exclude='node_modules' /path/to/local/folder/projects/ user@server_ip:/path/to/remote/projects

我通过添加 exclude 参数过滤掉了 node_modules 文件夹。

等待项目源码上传完成。

完成后进入服务器的项目目录下,安装依赖。

shell 复制代码
npm i

然后全局安装 nest cli

shell 复制代码
sudo npm install -g @nestjs/cli@latest

构建项目。

shell 复制代码
npm run build

然后全局安装 pm2

shell 复制代码
sudo npm install -g pm2@latest

通过 pm2 启动项目。

shell 复制代码
pm2 start npm --name "project_name" -- run start

启动完成后可以查看 pm2 的项目列表确认项目是否正常启动。

shell 复制代码
pm2 list

还可以通过 losf 命令来查看项目是否正常。

shell 复制代码
lsof -i :port

映射到公网域名

到这里项目部署已经完成了,接下来是通过公网域名访问项目。

首先设置一下 AWS 的安全组,允许 3000 端口被访问。

然后保证 EC2 的服务器有一个弹性 IP。

最后就是域名解析,在域名服务商的 DNS 配置界面上,添加 A 记录到 EC2 的 IP 就可以了。

相关推荐
2301_8127314129 分钟前
CSS3笔记
前端·笔记·css3
ziblog32 分钟前
CSS3白云飘动动画特效
前端·css·css3
越努力越幸运50832 分钟前
CSS3学习之网格布局grid
前端·学习·css3
半斤鸡胗35 分钟前
css3基础
前端·css
ziblog35 分钟前
CSS3创意精美页面过渡动画效果
前端·css·css3
akangznl36 分钟前
第四章 初识css3
前端·css·css3·html5
会豪37 分钟前
深入理解 CSS3 滤镜(filter):从基础到实战进阶
前端·css·css3
头顶一只喵喵37 分钟前
CSS3进阶知识:CSS3盒子模型,box-sizing:content-box和box-sizing:border-box的讲解
前端·css·css3
小飞大王66640 分钟前
css进阶用法
前端·css
普通网友1 小时前
新手必看!HCCDA-HarmonyOS & Cloud Apps 实验保姆级教程
javascript·angular.js