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:

      bash 复制代码
      curl -fsSL https://get.docker.com | bash
      systemctl enable docker && systemctl start docker
    • 在Jenkins服务器安装Docker Compose:

      bash 复制代码
      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

    bash 复制代码
    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

    bash 复制代码
    cp harbor.yml.tmpl harbor.yml
    vi harbor.yml

    修改以下关键配置:

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

    bash 复制代码
    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:

    yaml 复制代码
    https:
      port: 443
      certificate: /data/cert/harbor.crt
      private_key: /data/cert/harbor.key
  4. 安装Harbor

    bash 复制代码
    ./install.sh
  5. 验证Harbor

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

四、Jenkins安装与配置

  1. 使用Docker安装Jenkins

    bash 复制代码
    mkdir -p /data/jenkins_home
    chown -R 1000:1000 /data/jenkins_home  # Jenkins用户UID为1000
    
    docker 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

    • 获取初始密码:

      bash 复制代码
      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

    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

    groovy 复制代码
    pipeline {
        agent any
        
        environment {
            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 << EOF
                    docker login -u $HARBOR_CREDS_USR -p $HARBOR_CREDS_PSW harbor.example.com
                    docker stop spring-boot-demo || true
                    docker rm spring-boot-demo || true
                    docker run -d --name spring-boot-demo -p 8080:8080 $DOCKER_IMAGE:$DOCKER_TAG
                    EOF
                    """
                }
            }
        }
    }

七、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阶段后添加测试步骤:

    groovy 复制代码
    stage('Test') {
        steps {
            sh 'mvn test'
        }
        post {
            always {
                junit 'target/surefire-reports/*.xml'
            }
        }
    }
  2. 使用Docker Compose部署

    创建docker-compose.yml并使用它部署:

    yaml 复制代码
    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进行代码质量检测:

    groovy 复制代码
    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
相关推荐
Uranus^9 分钟前
利用Spring Boot和Redis构建高性能缓存系统
spring boot·redis·缓存·高性能
川川籽27 分钟前
minikube dashboard ImagePullBackOff 失败问题的解决方法
docker·k8s
caihuayuan51 小时前
使用 Java 开发 Android 应用:Kotlin 与 Java 的混合编程
java·大数据·vue.js·spring boot·课程设计
TPBoreas1 小时前
Jenkins服务器配置密钥对
运维·服务器·jenkins
万山y1 小时前
es疑惑解读
大数据·elasticsearch·jenkins
Uranus^2 小时前
深入解析Spring Boot与Kafka的集成实践
spring boot·kafka·消息队列·分布式系统
接着奏乐接着舞2 小时前
spring boot 注解 @bean
spring boot·后端·python