从零到上线:Node.js 项目的完整部署流程(包含 Docker 和 CICD)

news/2025/1/23 1:32:45/
从零到上线:Node.js 项目的完整部署流程(包含 Docker 和 CI/CD)

在这里插入图片描述

目录
  1. 项目初始化:构建一个简单的 Node.js 应用
  2. 设置 Docker 环境:容器化你的应用
  3. 配置 CI/CD:自动化构建与部署
  4. 上线前的最后检查:确保项目可以无缝部署
  5. 常见问题与排查技巧

1. 项目初始化:构建一个简单的 Node.js 应用

首先,我们从构建一个简单的 Node.js 项目开始,确保你的开发环境已经安装了 Node.js 和 npm。

1.1 初始化项目

打开终端,创建一个新目录并初始化 Node.js 项目:

mkdir my-node-app
cd my-node-app
npm init -y

这会在当前目录下创建一个 package.json 文件。

1.2 安装必要依赖

安装 Express,作为我们的 Web 框架。

npm install express
1.3 创建基础应用

在项目根目录下创建一个 index.js 文件,简单实现一个 API 端口:

// index.js
const express = require('express');
const app = express();
const port = process.env.PORT || 3000;app.get('/', (req, res) => {res.send('Hello, World!');
});app.listen(port, () => {console.log(`Server is running on http://localhost:${port}`);
});
1.4 本地启动

通过以下命令启动本地开发服务器:

node index.js

访问 http://localhost:3000,你应该能看到 “Hello, World!”。


2. 设置 Docker 环境:容器化你的应用

Docker 是一种非常流行的容器化工具,它允许你将应用及其所有依赖打包到一个可移植的容器中,确保无论在什么环境下都能一致地运行。

2.1 创建 Dockerfile

在项目根目录下创建一个 Dockerfile,用来构建 Docker 镜像。

# 使用官方 Node.js 镜像作为基础镜像
FROM node:14# 设置工作目录
WORKDIR /usr/src/app# 复制 package.json 并安装依赖
COPY package*.json ./
RUN npm install# 复制项目文件
COPY . .# 设置环境变量
ENV PORT 3000# 暴露端口
EXPOSE 3000# 启动应用
CMD ["node", "index.js"]
2.2 构建 Docker 镜像

构建镜像并给它命名为 my-node-app

docker build -t my-node-app .
2.3 运行 Docker 容器

运行镜像并映射到本地的 3000 端口:

docker run -p 3000:3000 my-node-app

这时,你的应用就已经在 Docker 容器中运行了,通过访问 http://localhost:3000,你依然可以看到 “Hello, World!”。


3. 配置 CI/CD:自动化构建与部署

CI/CD(持续集成/持续部署)是现代软件开发流程中的核心组成部分,可以帮助你自动化构建、测试和部署过程。我们使用 GitHub Actions 来实现这一流程。

3.1 创建 GitHub 仓库

首先,将代码推送到 GitHub 上,创建一个新的仓库并将代码推送上去。

git init
git add .
git commit -m "Initial commit"
git remote add origin <your-repo-url>
git push -u origin master
3.2 配置 GitHub Actions

在项目根目录下创建 .github/workflows 目录,并在该目录下创建一个 ci-cd.yml 文件:

name: CI/CD Pipelineon:push:branches:- masterpull_request:branches:- masterjobs:build:runs-on: ubuntu-lateststeps:- name: Checkout codeuses: actions/checkout@v2- name: Set up Dockeruses: docker/setup-buildx-action@v2- name: Build Docker imagerun: |docker build -t my-node-app .- name: Run Docker containerrun: |docker run -d -p 3000:3000 my-node-app- name: Test applicationrun: |curl http://localhost:3000
3.3 自动化流程说明
  • actions/checkout@v2:用于检查代码库。
  • docker/setup-buildx-action@v2:配置 Docker 构建工具。
  • docker build:构建 Docker 镜像。
  • docker run:启动 Docker 容器并映射端口。
  • curl http://localhost:3000:通过 curl 测试应用是否正常运行。
3.4 提交并推送

将 GitHub Actions 配置文件提交并推送:

git add .github/workflows/ci-cd.yml
git commit -m "Add CI/CD pipeline"
git push origin master

每次推送到 master 分支时,GitHub Actions 会自动触发该工作流,构建并部署应用。


4. 上线前的最后检查:确保项目可以无缝部署

在上线之前,确保进行以下操作:

  • 本地测试:确保 Docker 容器能够正确运行,并且 API 可访问。
  • 测试 CI/CD 流程:手动推送代码到 GitHub,查看自动化流程是否正常执行。
  • 检查日志:确保所有的日志都记录了详细的错误信息和运行状态,方便日后调试。

5. 常见问题与排查技巧
5.1 Docker 容器启动失败
  • 错误信息Error: Cannot find module 'express'
  • 解决方案:确保在 Dockerfile 中安装了依赖,并且正确复制了项目文件。
5.2 GitHub Actions 构建失败
  • 错误信息docker: buildx is not installed
  • 解决方案:检查 GitHub Actions 配置文件中的 Docker 设置是否正确,确保使用了正确的构建工具。
5.3 端口冲突
  • 错误信息Error: bind: address already in use
  • 解决方案:检查主机上的端口是否被其他应用占用,可以尝试更改容器暴露的端口。

总结

从零到上线,Node.js 项目的部署过程涉及多个步骤,包括项目初始化、Docker 容器化和 CI/CD 配置。使用 Docker,可以确保你的应用在任何环境下都能一致地运行;而配置 CI/CD,可以让你在代码更改时自动化地完成构建、测试和部署。掌握这些部署技巧,能够显著提高开发效率和系统稳定性。

希望这篇指南能够帮助你理解从零到上线的整个流程,成功部署你自己的 Node.js 项目!


http://www.ppmy.cn/news/1565352.html

相关文章

从零开始打造一个Java基于 Spring Boot 的旅游信息化平台

博主介绍&#xff1a;✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精彩专栏推荐订阅&#x1f447;…

Golang 生态学习

1. Go 语言基础 在深入 Go 语言的生态之前&#xff0c;首先需要掌握 Go 语言本身的核心特性。 • Go 语言官方文档&#xff1a;https://golang.org/doc/ Go 官方文档是学习语言基础和标准库的首选资源。 • 学习内容&#xff1a; • 基础语法&#xff1a;数据类型、控制流…

基于本地消息表实现分布式事务

假设我们有一个电商系统,包含订单服务和库存服务。当用户下单时,需要在订单服务中创建订单,同时在库存服务中扣减库存。这是一个典型的分布式事务场景,我们需要保证这两个操作要么都成功,要么都失败,以保证数据的最终一致性。 项目结构: 订单服务(Order Service)库存服务(Inv…

Kafka 和 MQ 的区别

1.概述 1.1.MQ简介 消息中间件&#xff0c;其实准确的叫法应该叫消息队列&#xff08;message queue&#xff09;&#xff0c;简称MQ。其本质上是个队列&#xff0c;有FIFO的性质&#xff0c;即first in first out&#xff0c;先入先出。 目前市场上主流的MQ有三款&#xff…

python管理工具:conda部署+使用

python管理工具&#xff1a;conda部署使用 一、安装部署 1、 下载 - 官网下载&#xff1a; https://repo.anaconda.com/archive/index.html - wget方式&#xff1a; wget -c https://repo.anaconda.com/archive/Anaconda3-2023.03-1-Linux-x86_64.sh2、 安装 在conda文件的…

如何将本地电脑上的文件夹设置为和服务器的共享文件夹

将本地电脑上的文件夹设为与服务器共享的文件夹&#xff0c;通常是在本地开启文件共享&#xff0c;并配置相应的权限&#xff0c;使服务器可以访问该文件夹。以下以 Windows 系统为例说明具体操作步骤&#xff1a; 一、在本地电脑上设置共享文件夹 选择文件夹 找到需要共享的文…

基于libuv实现的C++定时器管理器——TimerManager

在多线程编程中&#xff0c;定时器是一个非常重要的功能&#xff0c;它能够让我们在特定的时间点执行特定的任务。本文将介绍一个基于libuv库实现的C定时器管理器——TimerManager&#xff0c;它通过创建多个工作线程&#xff0c;每个线程运行一个uv loop来高效地管理定时器任务…

【大模型】ChatGPT 高效处理图片技巧使用详解

目录 一、前言 二、ChatGPT 4 图片处理介绍 2.1 ChatGPT 4 图片处理概述 2.1.1 图像识别与分类 2.1.2 图像搜索 2.1.3 图像生成 2.1.4 多模态理解 2.1.5 细粒度图像识别 2.1.6 生成式图像任务处理 2.1.7 图像与文本互动 2.2 ChatGPT 4 图片处理应用场景 三、文生图操…