Docker+Nginx+pm2部署nuxt3项目

1.本地文件树的一级目录结构如下

├── Dockerfile
├── apis
├── app.vue
├── assets
├── certificate.pem
├── components
├── composables
├── deploy.json
├── docker-compose.yml
├── ecosystem.config.cjs
├── error.vue
├── layouts
├── middleware
├── nginx.conf
├── nuxt.config.ts
├── package.json
├── pages
├── pnpm-lock.yaml
├── private.key
├── public
├── server
├── tsconfig.json
└── utils

2.新建Dockerfile文件

# 使用 Node.js 18 版本的官方镜像作为基础镜像
FROM node:18

# 设置工作目录为 /data
WORKDIR /data

# 复制当前目录下的所有文件到容器的 /data 目录中
COPY . /data

# 创建 logs 目录
RUN mkdir -p data/logs

# 安装pm2
RUN npm install pm2 -g

# 全局安装 pnpm
RUN npm install -g pnpm

# 使用 pnpm 安装项目依赖
RUN pnpm install

# 运行项目构建命令
RUN pnpm run build

3.新建pm2配置文件ecosystem.config.cjs

module.exports = {
  apps: [
    {
      name: "nuxt3-web",
      port: "3000",
      script: "/data/.output/server/index.mjs",
      cwd: "/data/",
      node_args: "--harmony",
      watch: false, // 是否监视文件变化
      instances: 1, // 启动实例数量
      exec_mode: "fork", // 进程执行模式
      autorestart: true, // 是否自动重启
      max_memory_restart: "1G", // 最大内存限制,达到限制时自动重启
      env: {
        NODE_ENV: "production", // 环境变量
      },
      error_file: "/data/logs/pm2-error.log", // 错误日志文件路径
      out_file: "/data/logs/pm2-out.log", // 输出日志文件路径
      merge_logs: true, // 是否合并日志
      log_date_format: "YYYY-MM-DD HH:mm:ss", // 日志时间格式
      min_uptime: "60s", // 最小运行时间
      kill_timeout: 3000, // 关闭超时时间
    },
  ],
};

4.新建docker-compose.yml文件

services:
  nuxt-container:
    build: .
    ports:
      - "3000:3000"
    command: ["pm2-runtime", "start", "ecosystem.config.cjs"]
    networks:
      - app-network

  nginx-container:
    image: nginx:latest
    container_name: nuxt-nginx
    ports:
      - "80:80"
      - "443:443"
    volumes:
      - ./nginx.conf:/etc/nginx/nginx.conf
      - ./certificate.pem:/etc/nginx/ssl/certificate.pem
      - ./private.key:/etc/nginx/ssl/private.key
    depends_on:
      - nuxt-container
    networks:
      - app-network

networks:
  app-network:
    driver: bridge

5.新建nginx.conf文件

# nginx.conf
worker_processes auto; # 使用CPU核心数来设置工作进程的数量

events {
  worker_connections 1024;
}
http {
  include mime.types; # 包含默认的MIME类型文件
  default_type application/octet-stream; # 默认的MIME类型

  server {
    listen 80;
    server_name xxx.com;
    return 301 https://$host$request_uri;
  }


  server {
    listen 443 ssl http2; # 在8000端口上监听HTTPS连接
    server_name xxx.com; # 改成你的域名
    ssl_certificate /etc/nginx/ssl/certificate.pem;
    ssl_certificate_key /etc/nginx/ssl/private.key;
    location / {
      proxy_pass http://xxx.com:3000; # 将请求代理到 PM2 或其他应用的端口
      proxy_set_header Host $host;
      proxy_set_header X-Real-IP $remote_addr;
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
      proxy_set_header X-Forwarded-Proto $scheme;
    }
  }
}

6.上传自己的ssl证书文件

一般是.key和.cem

7.将代码上传到服务器的某个目录下

在这里插入图片描述

7. cd到代码所在目录执行命令部署项目

在这里插入图片描述

  1. 构建容器
docker-compose build
  1. 运行容器
docker-compose up -d
  1. 查看容器运行情况
docker ps

在这里插入图片描述

  • 8
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
Docker+Consul+Nginx+keepalived是一种常用的云原生架构方案,它结合了容器化、服务发现、负载均衡和高可用等多种技术手段,可用于构建高可用、弹性、可扩展的应用系统。 该方案的主要组件包括: 1. Docker:用于容器化应用程序和服务,提供了高效、轻量、可移植的应用打包和部署方式。 2. Consul:用于服务发现和配置管理,支持多数据中心、跨平台、高度可扩展的分布式系统。 3. Nginx:用于负载均衡和反向代理,支持高并发、高可用的流量分发。 4. keepalived:用于实现高可用的服务和节点,提供了基于 VRRP 协议的故障转移和自动切换功能。 在该方案中,Docker 容器作为应用程序和服务的运行环境,使用 Consul 进行服务注册和发现,并通过 Nginx 进行流量分发和负载均衡。同时,使用 keepalived 实现高可用的服务和节点,确保系统的稳定性和可用性。 项目描述可以按照以下步骤进行撰写: 1. 项目背景和目的:简要介绍本项目的背景和目的,说明为什么选择 Docker+Consul+Nginx+keepalived 方案。 2. 技术架构:详细介绍该方案的技术架构和组件,包括 Docker、Consul、Nginx 和 keepalived 的作用和使用方式。 3. 系统功能:描述系统的主要功能和特点,包括服务发现、负载均衡、高可用等方面。 4. 实现方式:介绍系统的具体实现方式和实现步骤,包括 Docker 镜像的构建、应用程序的容器化、Consul 的配置和使用、Nginx 的配置和使用、keepalived 的配置和使用等。 5. 测试和验证:对系统进行测试和验证,验证系统的功能和性能是否符合预期,是否满足高可用和弹性的要求。 6. 总结和展望:对本项目进行总结和展望,分析该方案的优缺点和适用范围,展望未来的发展方向和趋势。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员禅心

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值