使用 Docker 部署 React + Nginx 应用教程

目录

    • [1. 创建react项目结构](#1. 创建react项目结构)
    • [2. 创建 .dockerignore](#2. 创建 .dockerignore)
    • [3. 创建 Dockerfile](#3. 创建 Dockerfile)
    • [4. 创建 nginx.conf](#4. 创建 nginx.conf)
    • [5. 构建和运行](#5. 构建和运行)
    • [6. 常用命令](#6. 常用命令)

1. 创建react项目结构

2. 创建 .dockerignore

plaintext:.dockerignore 复制代码
# 依赖目录
node_modules
npm-debug.log

# 构建输出
dist
build

# 开发环境文件
.git
.gitignore
.env
.env.local
.env.development
.env.test
.env.production

3. 创建 Dockerfile

dockerfile:Dockerfile 复制代码
# 构建阶段
FROM node:18-alpine as build
WORKDIR /app
COPY package*.json ./
RUN npm install
COPY . .
RUN npm run build

# 生产阶段
FROM nginx:alpine
COPY --from=build /app/dist /usr/share/nginx/html
COPY nginx.conf /etc/nginx/conf.d/default.conf
EXPOSE 80
CMD ["nginx", "-g", "daemon off;"]

4. 创建 nginx.conf

nginx:nginx.conf 复制代码
server {
    listen 80;
    server_name localhost;
    
    location / {
        root /usr/share/nginx/html;
        index index.html index.htm;
        try_files $uri $uri/ /index.html;
    }
}

完整的项目结构

5. 构建和运行

在项目根目录下执行以下命令:

bash 复制代码
# 构建Docker镜像
docker build -t react-nginx .

docker run -d -p 80:80 react-nginx

6. 常用命令

bash 复制代码
# 查看运行中的容器
docker ps

# 停止容器
docker stop <container_id>

# 查看容器日志
docker logs <container_id>

# 进入容器内部
docker exec -it <container_id> sh
相关推荐
倾颜14 分钟前
React 19 源码主线拆解 04:Fiber 到底是什么,React 为什么需要 Fiber?
前端·react.js·源码阅读
yoyo_zzm27 分钟前
Laravel8.x新特性全解析
数据库·nginx
老王以为2 小时前
为什么 React 和 Vue 不一样?
前端·vue.js·react.js
木雷坞5 小时前
视觉算法环境 Docker 镜像拉取失败排查
运维·人工智能·docker·容器
瀚高PG实验室5 小时前
安全版V4.5版本docker容器license过期问题处理步骤
安全·docker·容器·瀚高数据库
迪菲赫尔曼5 小时前
从 0 到 1 打造工业级推理控制台:UltraConsole(Ultralytics + FastAPI + React)开源啦!
前端·yolo·react.js·计算机视觉·开源·fastapi
Highcharts.js6 小时前
React 开发实战:如何使用 useEffect 为 Highcharts 注入实时数据
前端·javascript·react.js·开发实战·实时数据·highcharts·轮询数据
java_logo6 小时前
SiYuan 思源笔记 Docker 部署终极指南:Windows+Linux 双平台
windows·笔记·docker·思源笔记·思源笔记部署·docker部署思源笔记·思源笔记文档
计算机安禾6 小时前
【Linux从入门到精通】第32篇:Nginx入门——高性能Web服务器搭建
linux·服务器·nginx