当前位置: 首页 > news >正文

从容器化到自动化:Spring Boot 项目 Docker 部署与 GitLab CI/CD 集成 Harbor 全流程

在现代微服务架构中,容器化自动化流水线是必备技能。本文将带你完成两个关键步骤:

  1. Spring Boot 项目容器化 —— 使用多阶段 Dockerfile 构建轻量、安全的运行镜像。
  2. CI/CD 自动化 —— 借助 GitLab CI/CD,将镜像自动构建并推送到 Harbor 私有仓库。

参考阅读:Java Spring Boot 项目 Docker 容器化部署教程


一、Spring Boot 项目容器化

1. Dockerfile 多阶段构建

# 构建阶段
FROM maven:3.9.6-eclipse-temurin-17 AS builder
WORKDIR /build
COPY . .
RUN --mount=type=cache,target=/root/.m2 mvn -B clean package -DskipTests# 运行阶段
FROM eclipse-temurin:17-jre-alpine
RUN addgroup -S sdkj && adduser -S sdkj -G sdkj
WORKDIR /app
COPY --from=builder /build/target/*.jar ./app.jar
RUN mkdir -p /app/logs && chown -R sdkj:sdkj /app/logs
ENV TZ=Asia/Shanghai
ENV JAVA_OPTS="-Xms512m -Xmx1024m"
ENV SPRING_PROFILE=prod
EXPOSE 48087
USER sdkj
ENTRYPOINT ["sh", "-c"]
CMD ["exec java $JAVA_OPTS -jar app.jar $ARGS"]

关键点:

  • 多阶段构建:减少最终镜像体积
  • 非 root 用户:提升安全性
  • 日志目录赋权:避免 logback 报错
  • 环境变量可覆盖:灵活配置 JVM 与 Profile

二、GitLab CI/CD 自动化构建与推送 Harbor

参考阅读:Spring Boot 项目 GitLab CI/CD 自动构建并推送到 Harbor 教程

1. 环境准备

  • GitLab Runner(Docker executor,挂载宿主机 Docker)
  • Harbor 私有仓库(已创建项目与机器人账号)
  • GitLab CI/CD 变量配置:
    • HARBOR_USER / HARBOR_PASS
    • CI_REGISTRY = 192.168.0.12:5080

2. .gitlab-ci.yml 核心配置

stages:- build- pushvariables:DOCKER_HOST: unix:///var/run/docker.sockDOCKER_BUILDKIT: "1"REGISTRY: 192.168.0.12:5080PROJECT: ayy-serverIMAGE_NAME: ayy-server-java17.docker-base: &docker-baseimage: docker:20.10.24before_script:- echo "$HARBOR_PASS" | docker login -u "$HARBOR_USER" --password-stdin $REGISTRYbuild-test:<<: *docker-basestage: buildscript:- export IMAGE_TAG="test-${CI_COMMIT_SHORT_SHA}"- docker build -t $REGISTRY/$PROJECT/$IMAGE_NAME:$IMAGE_TAG .- echo "IMAGE_TAG=$IMAGE_TAG" > build.envartifacts:reports:dotenv: build.envonly:- mainpush-test:<<: *docker-basestage: pushdependencies: [build-test]script:- docker push $REGISTRY/$PROJECT/$IMAGE_NAME:$IMAGE_TAGonly:- main

3. 流程说明

  • main 分支:构建并推送测试镜像(test-* 标签)
  • tag 发布:构建并推送生产镜像(vX.Y.Z + prod-latest
  • 缓存镜像:利用 BuildKit 内联缓存加速二次构建
  • 清理策略:推送后清理 Runner 本地镜像,避免磁盘膨胀

三、完整流程回顾

  1. 编写 Dockerfile —— 多阶段构建、非 root、安全可配置
  2. 本地验证 —— docker build + docker run
  3. 配置 GitLab Runner —— 挂载宿主机 Docker,信任 Harbor 证书
  4. 编写 CI/CD 流水线 —— 分支/标签策略、缓存加速、推送 Harbor
  5. 验证与上线 —— Harbor 中查看镜像,部署到测试/生产环境

四、总结

通过本文,读者可以从零到一完成:

  • Spring Boot 项目容器化(Dockerfile 最佳实践)
  • CI/CD 自动化(GitLab Runner + Harbor 推送)

最终实现 代码提交 → 自动构建 → 镜像推送 → 部署上线 的完整闭环。

http://www.dtcms.com/a/574567.html

相关文章:

  • 基于springboot的web的音乐网站开发与设计
  • AIIData数据中台商业版+开源版双模式
  • 音画同步革命:IndexTTS2深度解析——B站开源的情感化+时长可控TTS新标杆
  • 如果做淘宝网站wordpress 七牛视频播放
  • 成都模版网站制作网站建设项目结构分析
  • Transformer原理与过程详解
  • 迷你主机做网站c语言开发网站
  • 水利建设相关网站百度手机版下载
  • Nestjs框架: 微服务注册中心架构设计与Consul实战
  • 给别人网站做跳转网络公司排名中国
  • Apollo Monitor模块技术深度解析
  • 济南市建设银行网站温州城乡建设学校
  • 广告联盟没有网站怎么做商城网站建设公司排名
  • 英伟达41页VLA框架:Alpamayo-R1凭“因果链推理”重塑端到端自动驾驶
  • TCP三握四挥TLS握手
  • 做网站用到什么技术wordpress常用页面
  • 用织梦做的网站怎样看作品集模板
  • C++中实现多线程编程
  • 编程网站入口免费建网站平台哪个好
  • 外贸网站服务器选择南京市江宁区建设局网站
  • 项目经历怎么填写百度seo网站排名
  • 网站建设的难点和问题网站建设信用卡取消
  • 《新概念英语青少年版》Starter A 知识点全整理
  • 饿了吗网站建设思路郑州网站定制
  • 英德市建设局网站网站的pv uv
  • 哈尔滨网站建设自助建站网上做室内设计的网站
  • AI Coding 资讯 2025-11-05.md
  • 嵌入式Linux——解密 ARM 性能优化:LDR 未命中时,为何 STR 还能“插队”?
  • 怎样可以查看网站是由哪个公司做的做网站每个月可以赚多少钱
  • 铜陵市建设工程管理局网站网站文字不能编辑器