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

Jenkins+Docker+Harbor快速部署Spring Boot项目详解

Jenkins+Docker+Harbor快速部署Spring Boot项目详解

Jenkins、Docker和Harbor是现代DevOps流程中的核心工具,结合使用可以实现自动化构建、测试和部署。下面我将详细介绍如何搭建这个集成环境。

一、各工具的核心作用

  1. Jenkins

    • 自动化CI/CD工具,负责拉取代码、编译、测试、构建Docker镜像并部署
    • 提供可视化界面管理Pipeline
  2. Docker

    • 容器化平台,将应用及其依赖打包成独立容器
    • 确保环境一致性,提高部署效率
  3. Harbor

    • 企业级Docker镜像仓库,存储和管理Docker镜像
    • 支持权限控制、镜像复制、安全扫描等功能

二、环境准备

  1. 服务器规划

    • Jenkins服务器:2核4G+,用于运行Jenkins服务
    • Harbor服务器:4核8G+,用于存储Docker镜像
    • 应用服务器:根据项目需求配置,运行Docker容器
  2. 软件安装

    • 在所有服务器安装Docker:
      curl -fsSL https://get.docker.com | bash
      systemctl enable docker && systemctl start docker
      
    • 在Jenkins服务器安装Docker Compose:
      curl -L "https://github.com/docker/compose/releases/download/v2.16.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
      chmod +x /usr/local/bin/docker-compose
      

三、Harbor安装与配置

  1. 下载并解压Harbor

    wget https://github.com/goharbor/harbor/releases/download/v2.8.3/harbor-offline-installer-v2.8.3.tgz
    tar xvf harbor-offline-installer-v2.8.3.tgz -C /opt/
    cd /opt/harbor
    
  2. 配置Harbor

    cp harbor.yml.tmpl harbor.yml
    vi harbor.yml
    

    修改以下关键配置:

    hostname: harbor.example.com  # 修改为你的域名或IP
    http:port: 80
    harbor_admin_password: Harbor12345  # 管理员密码
    data_volume: /data/harbor  # 数据存储路径
    
  3. 生成证书(可选,推荐使用HTTPS)

    mkdir -p /data/cert
    openssl req -newkey rsa:4096 -nodes -sha256 -keyout /data/cert/harbor.key -x509 -days 365 -out /data/cert/harbor.crt
    

    更新harbor.yml启用HTTPS:

    https:port: 443certificate: /data/cert/harbor.crtprivate_key: /data/cert/harbor.key
    
  4. 安装Harbor

    ./install.sh
    
  5. 验证Harbor

    • 访问http://harbor.example.com
    • 使用admin/Harbor12345登录

四、Jenkins安装与配置

  1. 使用Docker安装Jenkins

    mkdir -p /data/jenkins_home
    chown -R 1000:1000 /data/jenkins_home  # Jenkins用户UID为1000docker run -d \--name jenkins \-p 8080:8080 \-p 50000:50000 \-v /data/jenkins_home:/var/jenkins_home \-v /var/run/docker.sock:/var/run/docker.sock \-v $(which docker):/usr/bin/docker \jenkins/jenkins:lts
    
  2. 初始化Jenkins

    • 访问http://jenkins-server:8080
    • 获取初始密码:
      docker exec jenkins cat /var/jenkins_home/secrets/initialAdminPassword
      
    • 安装推荐插件,创建管理员账号
  3. 安装必要插件

    • Docker Pipeline
    • Pipeline
    • Git
    • Credentials Plugin

五、Jenkins与Harbor集成

  1. 在Jenkins中添加Harbor凭证

    • 进入Jenkins → 凭据 → 系统 → 全局凭据
    • 添加用户名密码凭证,用户名和密码为Harbor的账号密码
  2. 配置Docker Host

    • 进入Jenkins → 管理Jenkins → 系统设置 → Docker
    • 添加Docker Host:unix:///var/run/docker.sock

六、Spring Boot项目配置

  1. 添加Dockerfile
    在Spring Boot项目根目录下创建Dockerfile

    FROM openjdk:17-jdk-slim
    VOLUME /tmp
    ARG JAR_FILE=target/*.jar
    COPY ${JAR_FILE} app.jar
    ENTRYPOINT ["java","-jar","/app.jar"]
    
  2. 添加Jenkinsfile
    在项目根目录添加Jenkinsfile

    pipeline {agent anyenvironment {DOCKER_IMAGE = "harbor.example.com/devops/spring-boot-demo"DOCKER_TAG = "${env.BUILD_NUMBER}"HARBOR_CREDS = credentials('harbor-credentials')}stages {stage('Build') {steps {sh 'mvn clean package -DskipTests'}}stage('Build Docker Image') {steps {sh "docker build -t $DOCKER_IMAGE:$DOCKER_TAG ."}}stage('Push to Harbor') {steps {sh "docker login -u $HARBOR_CREDS_USR -p $HARBOR_CREDS_PSW harbor.example.com"sh "docker push $DOCKER_IMAGE:$DOCKER_TAG"sh "docker tag $DOCKER_IMAGE:$DOCKER_TAG $DOCKER_IMAGE:latest"sh "docker push $DOCKER_IMAGE:latest"}}stage('Deploy') {steps {sh """ssh user@deploy-server << EOFdocker login -u $HARBOR_CREDS_USR -p $HARBOR_CREDS_PSW harbor.example.comdocker stop spring-boot-demo || truedocker rm spring-boot-demo || truedocker run -d --name spring-boot-demo -p 8080:8080 $DOCKER_IMAGE:$DOCKER_TAGEOF"""}}}
    }
    

七、Jenkins Pipeline配置

  1. 创建新Pipeline项目

    • 进入Jenkins → 新建任务 → 输入名称 → 选择Pipeline → 确定
  2. 配置Pipeline

    • 进入项目配置 → Pipeline部分
    • 定义方式选择"Pipeline script from SCM"
    • SCM选择Git,填写项目Git仓库地址
    • 指定Jenkinsfile路径

八、关键配置说明

  1. Harbor关键配置

    • harbor.yml中的hostname必须正确配置
    • 生产环境建议启用HTTPS
    • 可配置磁盘配额和垃圾回收策略
  2. Jenkins关键配置

    • 确保Jenkins用户有访问Docker的权限
    • 正确配置Harbor凭证
    • 确保Jenkins服务器可以SSH到部署服务器
  3. Jenkinsfile关键参数

    • DOCKER_IMAGE:镜像名称,格式为Harbor地址/项目名/镜像名
    • DOCKER_TAG:建议使用构建号或Git提交哈希
    • HARBOR_CREDS:Harbor凭证ID

九、优化建议

  1. 添加测试阶段
    Build阶段后添加测试步骤:

    stage('Test') {steps {sh 'mvn test'}post {always {junit 'target/surefire-reports/*.xml'}}
    }
    
  2. 使用Docker Compose部署
    创建docker-compose.yml并使用它部署:

    version: '3'
    services:spring-boot-demo:image: harbor.example.com/devops/spring-boot-demo:${BUILD_NUMBER}ports:- "8080:8080"environment:- SPRING_PROFILES_ACTIVE=prod
    
  3. 添加质量检测
    集成SonarQube进行代码质量检测:

    stage('Code Quality') {steps {sh 'mvn sonar:sonar'}
    }
    

十、故障排除

  1. Docker连接问题

    • 确保Jenkins容器可以访问宿主机的Docker daemon
    • 检查/var/run/docker.sock权限
  2. Harbor认证失败

    • 检查Harbor凭证配置是否正确
    • 确保Harbor服务器可以访问
    • 如果使用HTTPS,确保证书已正确配置
  3. 部署失败

    • 检查部署服务器SSH配置
    • 确保部署服务器可以访问Harbor
    • 检查容器运行日志:docker logs spring-boot-demo

相关文章:

  • 基于正点原子阿波罗F429开发板的LWIP应用(3)——Netbiosns功能
  • Python爬虫(30)Python爬虫高阶:Selenium+Scrapy+Playwright融合架构,攻克动态页面与高反爬场景
  • 采集需要登录网站的教程
  • [每日一题] 3355. 零数组变换 i
  • [ 计算机网络 ] 深入理解TCP/IP协议
  • MySQL 8.0 OCP 1Z0-908 161-170题
  • C++23 新增扁平化关联容器详解
  • 数据挖掘:从数据堆里“淘金”,你的数据价值被挖掘了吗?
  • 题海拾贝:P2285 [HNOI2004] 打鼹鼠
  • Linux线程互斥与同步(上)(29)
  • vue3 + echarts(5.6.0)实现渐变漏斗图
  • Rocketmq broker 是主从架构还是集群架构,可以故障自动转移吗
  • Android Edge-to-Edge
  • C++ Pimpl(Pointer to Implementation)设计思想
  • 香港科技大学广州香港科技大学硕博士研究生学位项目宣讲会(智能制造硕博士物理学硕士)—深圳大学专场
  • TuyaOpen横空出世!涂鸦智能如何用开源框架重构AIoT开发范式?
  • PostgreSQL简介安装
  • 分频电路设计
  • WIFI信号状态信息 CSI 深度学习之数据集
  • taro 小程序 CoverImage Image src无法显示图片的问题
  • 中方敦促美国停止将溯源问题政治化
  • “复旦源”一源六馆焕新启幕,设立文化发展基金首期1亿元
  • 一旅客因上错车阻挡车门关闭 ,株洲西高铁站发布通报
  • 以军证实空袭也门多个港口
  • 著名词作家陈哲逝世,代表作《让世界充满爱》《同一首歌》等
  • 占地57亩的“潮汕豪宅”面临强制拆除:曾被实施没收,8年间举行5次听证会