Jenkins 与Docker/Kubernetes的自动化CI流水(笔记)

一、CI/CD

        持续集成(continuous Integration,CI):代码合并、构建、部署、测试都在一起。不断执行这个过程,并对结果反馈。

        持续部署(Continuous Deployment,CD): 部署到测试环境、预生产环境、生产环境。

        持续交付(Continuous Delivery,CD):将最终产品发布到生产环境,给用户使用

 CI/CD 的最终目的是自动化,减少人工干预,提高总体的产品交付质量。

 非容器化的CI/CD常出现因为环境不一致导致各种问题。

 Pipeline优势:

  • 项目发布可视化,明确阶段,方便处理问题
  • 一个Jenkinsfile文件管理整个项目生命周期
  • Jenkinsfile可以放到项目代码中版本管理

 Jenkinsfile 文件就是指pipeline script的脚本保存的文件。在流水线中,可以使用pipeline脚本文件,处理文件比之前每个项目都点击按钮去修改配置要方便。

Jenkinsfile保持在仓库中,在Jenkins里面调用即可:

 Jenkins 与Docker/Kubernetes的自动化CI流水实践

 下面内容是核心,有4个步骤:拉取代码-代码编译-打包成镜像推送到镜像仓库-部署

 

镜像仓库:

 填写上需要构建的版本。

 以上是docker单机的发布流程。

下面讲解,基于kubernetes的集群实现方案。Jenkins会调用k8s动态创建pod,这个pod是作为Jenkins的slave来执行任务的(拉代码,构建,打包,发布),任务执行完了,这个pod会自动消除。而Jenkins原本的pod 是作为master。这样就解决了master并发数不够情况下等待的问题。

Jenkins在k8s集群中以容器方式运行:

 

 编写Jenkinsfile

 

 

 deploy.yaml 文件:

 

这几个文件就说明了这个项目怎么跑起来

 

 Jenkins做了master和slave

 

检查启动情况:

 访问:

原文地址:https://www.cnblogs.com/zoujiaojiao/p/11696426.html