CI/CD pipeline 集成的最佳实践|学习笔记

简介: 快速学习CI/CD pipeline 集成的最佳实践

开发者学堂课程【云原生实践公开课CI/CD pipeline 集成的最佳实践】学习笔记,与课程紧密联系,让用户快速学习知识

课程地址:https://developer.aliyun.com/learning/course/698/detail/12271


CI/CD pipeline 集成的最佳实践


内容介绍:

一、云原生DevOps概述

二、Jenkins on K8s

三、Jenkins Pipeline

四、Jenkins CI实践


一、云原生DevOps概述

为什么需要DevOps?

与传统IT方式相比,减少80%的成本

提高效率,快速迭代

image.png

1、唯快不破--业务应用快速上线;研发效能提升

2、稳中求变--既要满足业务的“稳态”又要满足快捷商业的“敏态”需求

3、节省资源--自动扩缩容;开发运维一体化;云原生架构

4、开拓创新--既要满足业务的“稳态”又要满足快捷商业的“敏态”需求。

云原生 DevOps 一充分利用与原生技术的优势:

1、弹性∶

自动弹性伸缩资源按需分配

2、高可用∶

环境一致性多副本自治

3、敏捷:

容器技术微服务架构

image.png

资源按需分配:资源动态创建动态销毁

更快速迭代:自动触发、减少人工误差、降低迭代成本、加快迭代频率

快速部署:自动化部署,提高部署效率

高可用性:应用多副本,保障业务高可用性

低成本:资源的高利用率降低了硬件成本;自动化方式降低了人力成本

环境一致性:应用容器化,保证应用再开发测试和生产环境中的一致性

自动伸缩:基于应用负载自动扩容缩容,保证业务的连续性

多租户:容器平台的多租户特性可以满足多项目组同时开发

持续集成/交付:

1、持续集成:

持续构建

持续测试

代码分析

持续反馈

2、持续交付:

容器镜像发布

应用部署

3、优势:

发现和处理bug更快

所有操作对用户透明

自动化构建

更短的构建周期

通知反馈机制

持续部署

 

二、Jenkins on K8s

Jenkins 安装部署和配置

  • 一键部署Jenkins Helm Chart
  • 动态Slave Pod模板配置
  • 配置容器镜像仓库访问权限
  • 配置Maven缓存
  • 配置构建任务

image.png


三、Jenkins Pipeline

Jenkins Pipeline —Jenkinsfile

构建节点设置

全局环境变量设置

Git拉取

Maven 构建

Kaniko 容器镜像构建

Kubectl 部署应用

例如:

image.png

包括JAVA源码、gitignore、Dockerfile、Jenkinsfile、

application-demo.yaml、deployment.yaml、pom.xml 等


四、Jenkins CI实践

使 Jenkins 完成应用构建和部署实践

image.png

创建新的任务 cicd-pipeline

image.png

选择流水线类型

image.png

做构建参数设置

image.png

做构建:

image.png

构建日志完全是按照jenkins-demo / Dockerfile去定义的:

1、拉取源码

2、做构建

3、根据 Dockerfile 去构建目标镜像

4、把镜像推送到镜像仓库里面

5、部署到容器环境里面

相关实践学习
Docker镜像管理快速入门
本教程将介绍如何使用Docker构建镜像,并通过阿里云镜像服务分发到ECS服务器,运行该镜像。
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
10月前
|
人工智能 Kubernetes jenkins
容器化AI模型的持续集成与持续交付(CI/CD):自动化模型更新与部署
在前几篇文章中,我们探讨了容器化AI模型的部署、监控、弹性伸缩及安全防护。为加速模型迭代以适应新数据和业务需求,需实现容器化AI模型的持续集成与持续交付(CI/CD)。CI/CD通过自动化构建、测试和部署流程,提高模型更新速度和质量,降低部署风险,增强团队协作。使用Jenkins和Kubernetes可构建高效CI/CD流水线,自动化模型开发和部署,确保环境一致性并提升整体效率。
|
5月前
|
Cloud Native 中间件 调度
云原生信息提取系统:容器化流程与CI/CD集成实践
本文介绍如何通过工程化手段解决数据提取任务中的稳定性与部署难题。结合 Scrapy、Docker、代理中间件与 CI/CD 工具,构建可自动运行、持续迭代的云原生信息提取系统,实现结构化数据采集与标准化交付。
186 1
云原生信息提取系统:容器化流程与CI/CD集成实践
|
10月前
|
监控 jenkins Shell
jenkins结合gitlab实现CI(持续集成)
通过本文的介绍,我们详细了解了如何结合Jenkins和GitLab实现持续集成。从环境准备、插件配置到Pipeline任务创建和CI流程监控,每一步都提供了详细的操作步骤和示例代码。希望本文能帮助开发者快速搭建起高效的CI系统,提高项目开发效率和代码质量。
941 9
|
存储 测试技术 持续交付
Docker与CI/CD的集成策略及其对软件开发效率和质量的提升作用
本文探讨了Docker与CI/CD的集成策略及其对软件开发效率和质量的提升作用。首先介绍了CI/CD的基本概念,接着阐述了Docker在环境一致性、快速部署、资源隔离和轻量化方面的优势。文章还详细讨论了构建、测试和部署阶段的具体集成方法,以及集成后带来的效率提升、可靠性增强、加速交付和易于管理等好处。最后,通过案例分析展示了集成的实际效果,强调了Docker与CI/CD结合的重要性和未来前景。
236 2
|
Java Maven Docker
gitlab-ci 集成 k3s 部署spring boot 应用
gitlab-ci 集成 k3s 部署spring boot 应用
|
消息中间件 监控 Java
您是否已集成 Spring Boot 与 ActiveMQ?
您是否已集成 Spring Boot 与 ActiveMQ?
405 0
|
监控 druid Java
spring boot 集成配置阿里 Druid监控配置
spring boot 集成配置阿里 Druid监控配置
1178 6
|
Java 关系型数据库 MySQL
如何实现Springboot+camunda+mysql的集成
【7月更文挑战第2天】集成Spring Boot、Camunda和MySQL的简要步骤: 1. 初始化Spring Boot项目,添加Camunda和MySQL驱动依赖。 2. 配置`application.properties`,包括数据库URL、用户名和密码。 3. 设置Camunda引擎属性,指定数据源。 4. 引入流程定义文件(如`.bpmn`)。 5. 创建服务处理流程操作,创建控制器接收请求。 6. Camunda自动在数据库创建表结构。 7. 启动应用,测试流程启动,如通过服务和控制器开始流程实例。 示例代码包括服务类启动流程实例及控制器接口。实际集成需按业务需求调整。
1006 4
|
消息中间件 Java 测试技术
【RocketMQ系列八】SpringBoot集成RocketMQ-实现普通消息和事务消息
【RocketMQ系列八】SpringBoot集成RocketMQ-实现普通消息和事务消息
1258 1
|
消息中间件 Java Kafka
springboot集成kafka
springboot集成kafka
528 2