Docker 部署前后端分离项目

发布于:2025-06-04 ⋅ 阅读:(27) ⋅ 点赞:(0)

1.Docker 

1.1 什么是 Docker ?

Docker 是一种开源的 容器化平台,用于开发、部署和运行应用程序。它通过 容器(Container) 技术,将应用程序及其依赖项打包在一个轻量级、可移植的环境中,确保应用在不同计算环境中一致运行。

 1.2 Docker 核心概念

容器(Container)

类似于轻量级的虚拟机,但共享主机操作系统内核,启动更快、占用资源更少。每个容器运行一个独立的应用进程,与其他容器隔离。

镜像(Image)

容器的静态模板,包含运行应用所需的代码、库、环境变量和配置文件。

Dockerfile 用于定义如何构建镜像的文本文件
Docker Hub 官方的镜像仓库,提供大量预构建的镜像(如 MySQL、Python、Redis 等)
Docker Engine

Docker Daemon(后台服务)

Docker CLI(命令行工具)

REST API(用于交互)

2. Docker 基本命令

# 1.镜像
# 在线搜索镜像 可以不带版本号
docker search <镜像名称>:<版本号>
docker pull nginx:latest      # 拉取镜像 docker pull <镜像名>:<标签>
docker images                 # 查看本地所有镜像
docker rmi <镜像ID或镜像名>    # 删除本地镜像
docker build -t my-app:1.0 .  # 使用 Dockerfile 构建镜像 docker build -t <镜像名>:<标签> <Dockerfile路径>

# 2.容器
# 基于镜像启动一个新容器 docker run [选项] <镜像名>  -d:后台运行 -p:端口映射(主机端口:容器端口) --name:容器名
docker run -d -p 8080:80 --name my-nginx nginx 
docker exec -it <容器ID或容器名> /bin/bash  # 进入(运行的)容器
docker ps     # 查看正在运行的容器
docker ps -a  # 查看所有容器
docker stop <容器ID或容器名>     # 停止(运行的)容器
docker start <容器ID或容器名>    # 启动(停止的)容器
docker restart <容器ID或容器名>  # 重启(停止的)容器
docker rm <容器ID或容器名>       # 删除(停止的)容器
docker rm -f <容器ID或容器名>    # 强制删除(运行的)容器
docker logs <容器ID或容器名>     # 查看容器的日志

# 3.网络
docker network ls              # 查看 Docker 网络
docker network create <网络名>  # 创建一个自定义网络
docker network connect <网络名> <容器ID或容器名>     # 将容器连接到指定网络
docker network disconnect <网络名> <容器ID或容器名>  # 断开容器与指定网络的连接

# 3.数据卷(持久化数据存储)
docker volume create <卷名> # 创建一个数据卷
docker volume ls            # 查看所有数据卷
docker volume rm <卷名>     # 删除一个数据卷
docker run -v <卷名>:<容器内路径> <镜像名> # 启动容器时挂载数据卷(容器内外同步指定的目录和文件)

# 4.其他命令
docker version # 查看 Docker 客户端和服务端版本
docker info    # 查看 Docker 的系统信息
docker system prune     # 清理未使用的镜像、容器、网络和数据卷
docker system prune -a  # 强制清理所有未使用的资源

3. 下载 Docker Desktop(Windows | Docker Docs

4. Docker Desktop 拉取镜像、创建并启动容器 

4.1 拉取镜像仓库的镜像

4.2 根据镜像创建并启动容器

 5. Dockerfile 定义如何构建镜像 

# 使用官方 OpenJDK 镜像作为基础镜像
FROM openjdk:25-jdk

# 设置工作目录
WORKDIR /app

# 将当前目录的 springboot3-vue3-0.0.1-SNAPSHOT.jar 复制到容器 /app/app.jar
COPY springboot3-vue3-0.0.1-SNAPSHOT.jar app.jar

# 暴露 Spring Boot 默认端口(根据 application.yml 调整)
EXPOSE 8080

# 启动 Spring Boot 应用
ENTRYPOINT ["java", "-jar", "app.jar"]

6. docker-compose(推荐)

docker-compose 是一个用于定义和运行多容器 Docker 应用程序的工具。通过 docker-compose.yml 文件,您可以配置应用程序的服务、网络和卷等信息,然后使用一条命令来启动所有服务。(Docker Desktop 内置了 docker-compose)

6.1 docker-compose 命令(在 docker-compose.yml 目录执行以下命令

# 构建并以前台模式启动所有服务或某个服务(根据 docker-compose.yml 文件)
docker-compose up 
docker-compose up mysql
# 构建并以后台模式启动所有服务或某个服务
docker-compose up -d
docker-compose up -d mysql

# 查看当前正在运行的服务的状态
docker-compose ps

# 停止所有服务但不移除容器
docker-compose stop

# 停止并移除所有服务以及它们的网络
docker-compose down

# 构建或重新构建服务(不启动服务)
docker-compose build  # 用于当 Dockerfile 发生变化时重新构建镜像

# 实时查看所有服务的日志输出
docker-compose logs -f 

# 重启所有服务
docker-compose restart

# 重启特定服务,例如 'web'
docker-compose restart web=

# 扩展某个服务的实例数量,比如将 'web' 服务扩展到 3 个实例
docker-compose up --scale web=3 -d

# 在某个服务的容器内执行命令,例如在 'web' 服务中执行 'bash'
docker-compose exec web bash

# 验证 docker-compose.yml 文件的配置是否正确
docker-compose config

6.2 docker-compose 定义和运行多容器

 6.2.1 拉取 minio、redis、nginx、mysql 镜像

6.2.2 服务目录结构

├── docker/
│   ├── backend/
│   │   ├── Dockerfile
│   │   └── springboot3-vue3-0.0.1-SNAPSHOT.jar(后端打的包)
│   ├── frontend/
│   │   ├── dist/                              (前端打的包)
│   │   └── nginx.conf                         (nginx 配置文件)
│   ├── minio/
│   │   └── data/                              (minio 持久化数据的文件夹)
│   ├── mysql/
│   │   ├── data/                              (mysql 持久化数据的文件夹)
│   │   └── springboot3_vue3_satoken.sql       (sql 文件按)
│   ├── redis/
│   │   └── redis.conf                         (redis 配置文件)
│   ├── docker-compose.yml                     (docker-compose 配置文件)
6.2.2.1 docker 目录 
6.2.2.2 backend 目录 
6.2.2.3 frontend 目录  
6.2.2.4 minio目录   
6.2.2.5 mysql 目录
6.2.2.6 redis目录   

6.2.2.7 (很重要!!!)docker-compose.yml
name: my-project
services:
    backend:
        # 构建镜像(在当前目录的 backend 目录下,根据 Dockerfile 构建镜像)
        build: 
            context: ./backend
            dockerfile: Dockerfile
        image: springboot-image:latest
        container_name: springboot-container
        ports:
            - "8080:8080"
        depends_on:
            - redis
            - mysql
            - minio
        environment:
            # MySQL 数据库配置(容器内的 mysql 服务和端口)
            - SPRING_DATASOURCE_URL=jdbc:mysql://mysql:3306/springboot3_vue3_satoken
            - SPRING_DATASOURCE_USERNAME=***
            - SPRING_DATASOURCE_PASSWORD=***

            # Redis 配置
            - SPRING_REDIS_HOST=redis
            - SPRING_REDIS_PORT=6379
            - SPRING_REDIS_PASSWORD=    # 如果没有密码则留空
            - SPRING_REDIS_DATABASE=1   # 默认使用0号数据库

            # MinIO 配置(Spring Boot 应用访问 MinIO 的配置)
            - SPRING_MINIO_ENDPOINT=http://minio:9000
            - SPRING_MINIO_ACCESS_KEY=minioadmin
            - SPRING_MINIO_SECRET_KEY=minioadmin
        restart: unless-stopped

    redis:
        image: redis:latest
        container_name: redis-container
        ports:
            - "6379:6379"
        volumes:
            - ./redis/redis.conf:/usr/local/etc/redis/redis.conf
        # 启动 Redis 使用这个配置文件
        command: ["redis-server", "/usr/local/etc/redis/redis.conf"]
        restart: unless-stopped

    mysql:
        image: mysql:latest
        container_name: mysql-container
        ports:
            - "13306:3306"
        environment:
            MYSQL_ROOT_PASSWORD: ***
            MYSQL_DATABASE: springboot3_vue3_satoken
        volumes:
            # 将容器内的 MySQL 数据目录 (/var/lib/mysql) 持久化到 ./mysql/data
            - ./mysql/data:/var/lib/mysql

            # MySQL 容器首次启动时,会自动执行 /docker-entrypoint-initdb.d/ 目录下的 .sql
            - ./mysql/springboot3_vue3_satoken.sql:/docker-entrypoint-initdb.d/springboot3_vue3_satoken.sql
        restart: unless-stopped

    nginx:
        image: nginx:latest
        container_name: nginx-container
        ports:
            - "5173:80" 
        volumes:
            - ./frontend/nginx.conf:/etc/nginx/nginx.conf
            - ./frontend/dist:/usr/share/nginx/html 
        depends_on:
            - backend
        restart: unless-stopped
    
    minio:
        image: minio/minio:latest
        container_name: minio-container
        ports:
            - "9000:9000"  # API 端口
            - "9001:9001"  # 控制台端口
        volumes:
            - ./minio/data:/data  # 持久化存储
        environment:
            MINIO_ROOT_USER: minioadmin
            MINIO_ROOT_PASSWORD: minioadmin
        # 指定数据目录、API 端口、控制台端口
        command: ["server", "/data", "--address", ":9000", "--console-address", ":9001"]
        restart: unless-stopped

6.3 启动所有服务

6.3.1 cmd 启动所有服务和查看所有服务 

6.3.2 Docker Desktop 启动和查看所有服务 

6.4 进入容器内部

 6.5 访问 http://localhost:5173(Docker 部署前后端分离项目成功!!!)


网站公告

今日签到

点亮在社区的每一天
去签到