feat: add multi-stage Dockerfile for full build with martial-tool

- Add Dockerfile.fullbuild: multi-stage build that compiles martial-tool
- Rename Dockerfile to Dockerfile.quick for quick builds (pre-built jar)
- Update docker-compose.yml to use parent directory context
- Update README with new deployment instructions
This commit is contained in:
2025-12-29 14:34:54 +08:00
parent 47d0b70a9c
commit 86e4580e5d
4 changed files with 81 additions and 18 deletions

50
Dockerfile.fullbuild Normal file
View File

@@ -0,0 +1,50 @@
# ============================================
# 武术赛事管理系统 - 完整构建 Dockerfile
# 包含 martial-tool 编译 + martial-master 编译
# ============================================
# 构建阶段:使用 Maven + JDK 镜像
FROM maven:3.9-eclipse-temurin-17 AS builder
WORKDIR /build
# 复制 martial-toolBladeX 框架)
COPY martial-tool /build/martial-tool
# 编译 martial-tool 并安装到本地仓库
RUN cd /build/martial-tool && \
mvn clean install -DskipTests -q
# 复制 martial-master后端项目
COPY martial-master /build/martial-master
# 编译 martial-master
RUN cd /build/martial-master && \
mvn clean package -DskipTests -q
# ============================================
# 运行阶段:使用轻量级 JRE 镜像
# ============================================
FROM eclipse-temurin:17-jre-jammy
LABEL maintainer="JohnSion"
LABEL description="武术比赛管理系统后端服务"
WORKDIR /app
# 从构建阶段复制 JAR 文件
COPY --from=builder /build/martial-master/target/blade-api.jar /app/blade-api.jar
# 暴露端口
EXPOSE 8123
# 健康检查
HEALTHCHECK --interval=30s --timeout=3s --start-period=60s --retries=3 \
CMD curl -f http://localhost:8123/actuator/health || exit 1
# JVM 参数配置
ENV JAVA_OPTS="-Xms512m -Xmx1024m -XX:+UseG1GC"
ENV SPRING_PROFILE="dev"
# 启动命令
CMD ["sh", "-c", "java ${JAVA_OPTS} -jar /app/blade-api.jar --spring.profiles.active=${SPRING_PROFILE}"]

View File

@@ -28,20 +28,29 @@
### 环境要求 ### 环境要求
- JDK 17+
- Maven 3.8+
- Docker & Docker Compose - Docker & Docker Compose
### Docker Compose 部署(推荐) ### 一键部署(推荐)
确保目录结构如下:
```
martial/
├── martial-tool/ # BladeX 框架(必需)
├── martial-master/ # 后端项目
├── martial-web/ # 管理后台前端
├── martial-mini/ # 用户端小程序
└── martial-admin-mini/ # 裁判端小程序
```
```bash ```bash
# 克隆项目 cd martial/martial-master
git clone https://git.waypeak.work/martial/martial-master.git
cd martial-master
# 启动所有服务 # 首次部署完整构建约5-6分钟
docker compose up -d docker compose up -d
# 查看构建日志
docker compose logs -f martial-api
# 查看服务状态 # 查看服务状态
docker compose ps docker compose ps
``` ```
@@ -50,14 +59,19 @@ docker compose ps
- API 服务: http://localhost:8123 - API 服务: http://localhost:8123
- API 文档: http://localhost:8123/doc.html - API 文档: http://localhost:8123/doc.html
### 本地开发 ### 快速构建(开发迭代)
如果已经手动编译过 JAR可以使用快速构建
```bash ```bash
# 编译项目 # 编译 martial-tool首次
mvn clean package -DskipTests cd ../martial-tool && mvn clean install -DskipTests
# 运行(需要先启动 MySQL 和 Redis # 编译 martial-master
mvn spring-boot:run -Dspring-boot.run.profiles=dev cd ../martial-master && mvn clean package -DskipTests
# 使用快速构建 Dockerfile
docker compose build martial-api --build-arg DOCKERFILE=Dockerfile.quick
``` ```
## 项目结构 ## 项目结构
@@ -79,7 +93,8 @@ martial-master/
├── database/ # 数据库初始化脚本 ├── database/ # 数据库初始化脚本
├── docs/ # 项目文档 ├── docs/ # 项目文档
├── docker-compose.yml # Docker 编排配置 ├── docker-compose.yml # Docker 编排配置
── Dockerfile # 镜像构建文件 ── Dockerfile.fullbuild # 完整构建(含 martial-tool
└── Dockerfile.quick # 快速构建(需预编译 JAR
``` ```
## Docker Compose 服务 ## Docker Compose 服务

View File

@@ -1,5 +1,3 @@
version: '3.8'
services: services:
# MySQL 数据库 # MySQL 数据库
mysql: mysql:
@@ -84,11 +82,11 @@ services:
networks: networks:
- martial-network - martial-network
# 后端应用 # 后端应用(完整构建模式)
martial-api: martial-api:
build: build:
context: . context: ..
dockerfile: Dockerfile dockerfile: martial-master/Dockerfile.fullbuild
container_name: martial-api container_name: martial-api
restart: always restart: always
environment: environment: