CI/CD 流水线

CI/CD 流水线

  • CI 与 CD 的边界
    • CI 持续集成
    • CD(持续交付/持续部署)
    • 自动化流程示例:
  • Jenkins 引入到 CI/CD 流程
    • 在本地或服务器上安装 Jenkins。
    • 配置 Jenkins 环境
    • 流程设计
      • CI 阶段:Jenkins 流水线实现
      • CD 阶段:Jenkins 流水线实现
      • 完整流程概述
  • 发版
    • 发版的内容
    • 发版的过程
    • 发版的类型
    • 发版与版本号
    • 发版的目的

CI(Continuous Integration,持续集成)
CD(Continuous Delivery 或 Continuous Deployment,持续交付或持续部署)

在这里插入图片描述

CI 与 CD 的边界

CI:从代码提交到 Docker 镜像推送至 Docker Hub。
CD:从 Kubernetes 拉取镜像到应用运行及服务暴露

示例:

  • CI: 通过mvn 创建spring boot 项目,创建java类,通过dockerfile构建镜像至docker hub
  • CD: 在k8s拉取dockerhub镜像,运行应用程序,创建server进行端口映射,创建ingress暴露服务

CI 持续集成

CI 主要关注代码的开发、构建和质量保证,最终目标是生成一个稳定的可交付产物(如 Docker 镜像)

通过 Maven 创建 Spring Boot 项目

  • 初始化项目结构,编写代码逻辑。
  • 提交代码到版本控制系统(如 Git)

创建 Java 类

  • 开发新功能或修复问题,更新代码库。

通过 Dockerfile 构建镜像

  • 使用 Maven 构建项目 (mvn clean package) 并生成 JAR 文件。
  • 使用 Dockerfile 将 JAR 文件打包成 Docker 镜像。

推送镜像至 Docker Hub

使用 CI 工具(如 Jenkins、GitLab CI/CD)实现自动化:

  • 代码提交后触发流水线。
  • 运行测试(单元测试、集成测试)。
  • 构建并生成 Docker 镜像。
  • 将镜像推送至 Docker Hub 或其他镜像仓库。

CD(持续交付/持续部署)

CD 主要关注如何将 CI 生成的镜像部署到实际运行环境(如 Kubernetes 集群),并确保服务的正常暴露。

在 Kubernetes 上拉取 Docker Hub 镜像

  • 使用 Kubernetes Deployment 清单(YAML 文件)描述应用程序的镜像和资源需求。
  • 从 Docker Hub 拉取生成的镜像,创建容器实例。
  • 运行应用程序

通过 Kubernetes Deployment 控制器管理应用程序的副本(Pod)。

  • 创建 Service 并进行端口映射

定义 Kubernetes Service(如 ClusterIP、NodePort 或 LoadBalancer),将应用的内部端口映射到集群外部。

  • 创建 Ingress 暴露服务

定义 Ingress 资源,提供 HTTP(S) 路由规则,将外部流量路由到 Service。

  • 配置域名和证书(可选,支持 HTTPS)。

自动化流程示例:

CI 流程

  1. 开发者提交代码至 Git 仓库(触发 CI 流水线)。
  2. CI 工具执行以下步骤:
    拉取代码。
    使用 mvn clean package 构建项目。
    构建 Docker 镜像(基于 Dockerfile)。
    运行测试以验证代码和镜像质量。
    将镜像推送至 Docker Hub。

CD 流程

  1. 部署工具(如 ArgoCD、FluxCD 或 Jenkins)监听到新镜像的更新。
  2. 执行以下步骤:
    拉取新的 Docker 镜像到 Kubernetes 集群。
    创建/更新 Deployment,将镜像部署到 Pod 中。
    配置 Service 以进行端口映射。
    创建 Ingress 暴露服务,为用户提供访问入口。

Jenkins 引入到 CI/CD 流程

通过 Jenkins 的 CI/CD 流水线,整个开发到部署的流程自动化,减少人工干预,提高交付效率和可靠性。

基于Jenkins+K8S+harbor+git等技术链助力DevOps在企业落地实践

在这里插入图片描述

在本地或服务器上安装 Jenkins。

确保安装了必要的插件:

Pipeline(支持声明式流水线)。
Docker(支持 Docker 构建)。
Kubernetes CLI(支持 kubectl 命令)。
Git(拉取代码)。
Maven Integration(构建 Spring Boot 项目)

配置 Jenkins 环境

  • 配置全局工具:
    安装 JDK 和 Maven。
    配置 Docker 和 kubectl 的路径。
  • 添加 Jenkins 凭据:
    Docker Hub 凭据(用于推送镜像)。
    Kubernetes 集群凭据(用于 CD 部署)。

流程设计

CI 阶段:Jenkins 流水线实现
CI 的目标是构建、测试和将 Docker 镜像推送到 Docker Hub

CI 阶段:Jenkins 流水线实现

Jenkinsfile for CI
在项目根目录创建一个 Jenkinsfile,内容如下

pipeline {
    agent {
        docker { image 'maven:3.8.7-openjdk-17' } // 使用 Maven 镜像
    }
    environment {
        DOCKER_HUB_CREDENTIALS = credentials('docker-hub-id') // Docker Hub 凭据
        DOCKER_IMAGE = 'your-docker-hub-repo/spring-boot-app'
    }
    stages {
        stage('Checkout Code') {
            steps {
                checkout scm
            }
        }
        stage('Build and Test') {
            steps {
                sh 'mvn clean package'
            }
        }
        stage('Build Docker Image') {
            steps {
                sh 'docker build -t ${DOCKER_IMAGE}:latest .'
            }
        }
        stage('Push Docker Image') {
            steps {
                withDockerRegistry([credentialsId: 'docker-hub-id', url: '']) {
                    sh 'docker push ${DOCKER_IMAGE}:latest'
                }
            }
        }
    }
}

Jenkins 配置

  • 在 Jenkins 上创建一个 Pipeline Job,链接到代码仓库(如 GitHub)。
  • Jenkins 会自动执行流水线,完成代码构建、测试、镜像打包与推送。

CD 阶段:Jenkins 流水线实现

CD 的目标是将 Docker 镜像拉取到 Kubernetes 中,并完成部署。
创建 Kubernetes 配置文件

  • deployment.yaml(用于部署镜像到 Kubernetes 集群):
apiVersion: apps/v1
kind: Deployment
metadata:
  name: spring-boot-app
spec:
  replicas: 2
  selector:
    matchLabels:
      app: spring-boot-app
  template:
    metadata:
      labels:
        app: spring-boot-app
    spec:
      containers:
      - name: spring-boot-app
        image: your-docker-hub-repo/spring-boot-app:latest
        ports:
        - containerPort: 8080
  • service.yaml(用于暴露服务端口):
apiVersion: v1
kind: Service
metadata:
  name: spring-boot-service
spec:
  type: NodePort
  ports:
 - port: 8080
    targetPort: 8080
    nodePort: 30001
  selector:
    app: spring-boot-app
  • ingress.yaml(用于 Ingress 暴露服务):
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
  name: spring-boot-ingress
spec:
  rules:
  - host: springboot.example.com
    http:
      paths:
      - path: /
        pathType: Prefix
        backend:
          service:
            name: spring-boot-service
            port:
              number: 8080

Jenkinsfile for CD 在项目根目录扩展 Jenkinsfile 或创建新的 Pipeline Job:

pipeline {
    agent any
    environment {
        KUBECONFIG_CREDENTIALS = credentials('k8s-config-id') // Kubernetes 配置凭据
    }
    stages {
        stage('Deploy to Kubernetes') {
            steps {
                withKubeConfig([credentialsId: 'k8s-config-id']) {
                    sh 'kubectl apply -f deployment.yaml'
                    sh 'kubectl apply -f service.yaml'
                    sh 'kubectl apply -f ingress.yaml'
                }
            }
        }
    }
}

Jenkins 配置

  • 创建新的 Pipeline Job,配置为自动触发(如监控 Docker Hub 镜像更新)。
  • Jenkins 执行流水线,完成镜像拉取和 Kubernetes 部署。

完整流程概述

CI 阶段
提交代码到 Git 仓库后,触发 CI。
Jenkins 构建 Spring Boot 项目,生成 Docker 镜像,并推送至 Docker Hub。

CD 阶段
Jenkins 检测到新镜像(或手动触发),执行 Kubernetes 部署。
创建 Deployment、Service 和 Ingress 资源,将应用运行在 Kubernetes 集群中。

发版

发版是软件开发和运维过程中常见的术语,指的是将开发完成的功能、修复或改动版本发布给用户或部署到生产环境的过程。它是软件开发生命周期中的一个重要阶段。

发版的内容

发版通常包含以下内容:

  • 新功能: 提供给用户的新特性或增强功能。
  • Bug 修复: 修复已知问题或漏洞。
  • 性能优化: 提高软件运行效率或资源利用率。
  • 版本升级: 依赖库、框架或工具的版本更新。
  • 配置更新: 改动配置项以适应新的需求或部署环境。

发版的过程

发版通常包括以下几个步骤:

  1. 开发和测试
    开发团队完成代码开发。
    测试团队进行功能测试、回归测试、性能测试等,确保版本质量。
  2. 打包和构建
    使用构建工具(如 Maven、Gradle)将代码打包。
    可能会生成可执行文件、Docker 镜像或其他可交付产物。
  3. 版本管理
    确定发版版本号(如 v1.0.0)。
    提交对应的版本标签到版本控制系统(如 Git 标签)。
  4. 部署
    将构建好的版本部署到生产或预生产环境。
    可以通过 CI/CD 流水线实现自动化部署。
  5. 通知和发布
    发布版本公告,包括新增功能说明、修复内容和已知问题。
    通知用户或相关方新版本已上线。
  6. 监控和验证
    部署后监控系统运行状况,确保应用正常运行。
    根据用户反馈修复问题(如果有)。

发版的类型

根据影响范围和目标环境,发版可以分为以下几种类型:

  • 测试环境发版: 部署到测试环境,用于测试功能是否符合预期。
  • 预生产环境发版: 部署到与生产环境一致的预生产环境,用于模拟真实场景验证。
  • 生产环境发版: 正式发布到用户可访问的生产环境。
  • 灰度发布: 部分用户或节点先体验新版本,验证稳定性后逐步扩大范围。
  • 紧急发版: 修复重大问题或安全漏洞的快速发版,通常跳过部分流程。

发版与版本号

发版通常伴随版本号的更新,遵循 语义化版本号 的规则:

  • 主版本号(Major):重大更新或不兼容改动(如 1.0.0 -> 2.0.0)。
  • 次版本号(Minor):新增功能,向下兼容(如 1.0.0 -> 1.1.0)。
  • 修订版本号(Patch):Bug 修复或小的改进(如 1.0.0 -> 1.0.1)。

发版的目的

  • 将新功能或改进快速、安全地交付给用户。
  • 修复系统问题,保证用户体验和系统稳定性。
  • 保持软件版本的可管理性和一致性。

发版是一种规范化的软件发布过程,从开发完成到生产环境上线都需要经过严格的管理。它可以通过 CI/CD 工具自动化,并根据不同需求选择适合的发版策略(如灰度发布、蓝绿部署等)。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/953118.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

编程题-二分查找

题目: 给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜索 nums 中的 target,如果目标值存在返回下标,否则返回 -1 解法一(循环遍历查找)&#xff…

OOM排查思路

K8S 容器的云原生生态,改变了服务的交付方式,自愈能力和自动扩缩等功能简直不要太好用。 有好的地方咱要夸,不好的地方咱也要说,真正的业务是部署于容器内部,而容器之外,又有一逻辑层 Pod 。 对于容器和…

Github Copilot学习笔记

(一)Prompt Engineering 利用AI工具生成prompt设计好的prompt结构使用MarkDown语法,按Role, Skills, Constrains, Background, Requirements和Demo这几个维度描述需求。然后收输入提示词:作为 [Role], 拥有 [Skills], 严格遵守 […

在 Rider 中使用 C# 创建 Windows 窗体应用 Winforms

1,创建项目 new solution 创建一个解决方案 2,打开设计器 在 Form1.cs 上右键打开设计器 认识一下 Rider 的界面 参考微软官方的例子,添加如下属性:注:这里 Listbox 的大小设置成 120, 94 失败,默认的是 12…

R数据分析:多分类问题预测模型的ROC做法及解释

有同学做了个多分类的预测模型,结局有三个类别,做的模型包括多分类逻辑回归、随机森林和决策树,多分类逻辑回归是用ROC曲线并报告AUC作为模型评估的,后面两种模型报告了混淆矩阵,审稿人就提出要统一模型评估指标。那么肯定是统一成ROC了,刚好借这个机会给大家讲讲ROC在多…

#Java-集合进阶-Map

1.Map 声明1 1.1 双列集合的特点 单列集合一次只能添加一个元素,双列集合一次可以添加一对元素 例: 小米手机2000华为手机5000苹果手机9000 这三对元素,左边的我们称之为键,右边的称为值。他们是一一对应的关系 所以双列集合中…

IntelliJ IDEA和MAVEN基本操作:项目和缓存存储到非C盘

为了将 IntelliJ IDEA 的所有项目和缓存存储到 C 盘以外的地方,以下是你需要调整的设置和步骤: 1. 更改项目默认存储位置 打开 IntelliJ IDEA。点击顶部菜单的 File > Settings (Windows)或 IntelliJ IDEA > Preferences &…

【Linux系列】`find / -name cacert.pem` 文件搜索

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

RabbitMQ基础(简单易懂)

RabbitMQ高级篇请看: RabbitMQ高级篇-CSDN博客 目录 什么是RabbitMQ? MQ 的核心概念 1. RabbitMQ 的核心组件 2. Exchange 的类型 3. 数据流向说明 如何安装RabbitQueue? WorkQueue(工作队列): Fa…

《Spring Framework实战》5:Spring Framework 概述

欢迎观看《Spring Framework实战》视频教程 Spring 使创建 Java 企业应用程序变得容易。它为您提供一切 需要在企业环境中采用 Java 语言,并支持 Groovy 和 Kotlin 作为 JVM 上的替代语言,并且可以灵活地创建许多 类型的架构。从 Spring Framework 6.0 开…

有限元分析学习——Anasys Workbanch第一阶段笔记(10)桌子载荷案例分析_实际载荷与均布载荷的对比

目录 0 序言 1 桌子案例 2 模型简化 3 方案A 前处理 1)分析类型选择 2)材料加载 3)约束、载荷及接触 4)控制网格(网格大小需要根据结果不断调整) 初始计算结果 加密后计算结果 4 方案B、C 前处理 1)分析…

Git 基础——《Pro Git》

⭐获取 Git 仓库 获取 Git 仓库有两种方式: 将未进行版本控制的本地目录转换为 Git 仓库。从其他服务器克隆一个已存在的 Git 仓库。 在已存在目录中初始化 Git 仓库 进入目标目录 在 Linux 上:$ cd /home/user/my_project在 macOS 上:$ c…

Java 将RTF文档转换为Word、PDF、HTML、图片

RTF文档因其跨平台兼容性而广泛使用,但有时在不同的应用场景可能需要特定的文档格式。例如,Word文档适合编辑和协作,PDF文档适合打印和分发,HTML文档适合在线展示,图片格式则适合社交媒体分享。因此我们可能会需要将RT…

R语言在森林生态研究中的魔法:结构、功能与稳定性分析——发现数据背后的生态故事!

森林生态系统结构、功能与稳定性分析与可视化研究具有多方面的重要意义,具体如下: 一、理论意义 ●深化生态学理论 通过研究森林生态系统的结构、功能与稳定性,可以深化对生态系统基本理论的理解。例如,生物多样性与生态系统稳定性…

Delphi+SQL Server实现的(GUI)户籍管理系统

1.项目简介 本项目是一个户籍管理系统,用于记录住户身份信息,提供新户登记(增加)、户籍变更(修改)、户籍注销(删除)、户籍查询、曾用名查询、迁户记录查询以及创建备份、删除备份共8…

第2课 “Hello World” 与 print

1 Hello World 2 print 函数解析 2.1 基本用法 2.2 输出多个对象 2.3 使用sep参数 2.4 使用flush参数 2.5 输出到文件 3 格式化输出 3.1 格式化输出整数 3.2 格式化输出16进制整数 3.3 格式化输出浮点数(float) 3.4 格式化输出字符串(string) 3.5 输出列表与字典 …

计算机网络(四)网络层

4.1、网络层概述 简介 网络层的主要任务是实现网络互连,进而实现数据包在各网络之间的传输 这些异构型网络N1~N7如果只是需要各自内部通信,他们只要实现各自的物理层和数据链路层即可 但是如果要将这些异构型网络互连起来,形成一个更大的互…

qt 窗口(window/widget)绘制/渲染顺序 QPainter QPaintDevice Qpainter渲染 失效 无效 原因

qt窗体布局 窗体渲染过程 qt中窗体渲染逻辑顺序为 本窗体->子窗体/控件 递归,也就是说先渲染父窗体再渲染子窗体。其中子窗体按加入时的先后顺序进行渲染。通过下方的函数调用堆栈可以看出窗体都是在widget组件源码的widgetprivate::drawwidget中进行渲染的&am…

网络安全-kail linux 网络配置(基础篇)

一、网络配置 1.查看网络IP地址, 我的kail:192.168.15.128 使用ifconfig查看kail网络连接情况,ip地址情况 又复制了一台kail计算机的IP地址。 再看一下windows本机:使用ipconfig进行查看: 再看一下虚拟机上的win7I…

Edge浏览器内置的截长图功能

Edge浏览器内置截图功能 近年来,Edge浏览器不断更新和完善,也提供了长截图功能。在Edge中,只需点击右上角的“...”,然后选择“网页捕获”->“捕获整页”,即可实现长截图。这一功能的简单易用,使其成为…