写点什么

结合 AWS 服务与 Kubernetes 的持续集成

  • 2019-10-18
  • 本文字数:1817 字

    阅读完需:约 6 分钟

结合 AWS 服务与 Kubernetes 的持续集成

用户可以结合 AWS 和 Kubernetes 去创建一个完全托管,可持续部署的容器应用。这种结合充分利用开源 Kubernetes 平台的容器编排能力以及 AWS 开发者工具的代码管理,编译打包和持续集成的能力


本篇文章描述了如何去创建一个可持续部署容器应用。其使用 AWS CodeCommit , AWS CodePipeline , AWS CodeBuild , 和 AWS Lambda 将容器应用部署到 Kubernetes 集群中去。在这个环境中,开发者可以专注于代码开发而无需考虑如何部署,同时这种方式总是可以保障最新的代码被部署到环境中去

什么是持续部署?

有许多的文章和会议已经发表过持续部署的实践案例, 而本文将持续部署归纳为以下几点:


  • 代码可以频繁地被部署到生产环境

  • 任何代码修改将触发低风险发布。同时也可以轻松回滚

  • 全自动化部署,仅需少量人工操作

如何使用 AWS 和 Kubernetes 去实现持续部署?

你可以以最小的人工操作为代价,用 AWS 服务自动将代码从代码仓库取出然后部署到 Kubernetes 生产集群。为了达成这个目的,你可以创建一个 pipeline,在条件满足时该 pipeline 将自动构建并且部署已提交的代码。


你可以使用下面这些服务,去创建一个 pipeline


  • AWS CodePipeline . AWS CodePipeline 是一个自动化交付服务,它模块化,可视化,自动化了软件的部署流程。在 pipeline 中可以定义若干步骤,例如从代码管理仓库中拉取代码,将代码构建成为可发布包,测试发布包,将其部署到生产环节。只有成功通过上述步骤的代码才会予以部署。同时,你可以针对 pipeline 增添一些额外的流程,例如人工批准:只有被批准的修改才会被部署到生产环节。

  • AWS CodeCommit . AWS CodeCommit 是一个安全,可扩展,托管的私有 Git 代码仓库服务。你可以将私有代码或其他文件存储在云上,同时配置 pipeline 自动获取仓库中的改动。

  • AWS CodeBuild . AWS CodeBuild 是一个 aws 上的构建服务,用来编译代码,运行单元测试和生成部署包. 同时你可以在部署之前使用 AWS CodeBuild 来构建和测试部署包。

  • AWS Lambda. AWS Lambda 是一种计算服务,该服务可以让你运行代码的同时而无需部署或者管理服务器。你可以在 pipeline 中触发 Lambda 函数来准备构建和为 Kubernetes 测试部署包。

  • Kubernetes . Kubernetes 是一个开源的自动化部署,扩容和管理容器应用的框架。 它为运行,部署和管理可扩展的容器提供了便利的平台。

持续部署到 Kubernetes 的举例:

下面这个例子,说明了如何使用 AWS 开发者工具持续将应用部署到 Kubernetes 集群



  1. 开发者将代码提交到 AWS CodeCommit 同时创建一个 pull request 来审核针对生产环境代码的修改。 当 pull request 合并到 master 分支后,AWS CodePipeline 会自动检测到代码分支上的修改,并通过 pipeline 启动针对代码修改的处理。

  2. AWS CodeBuild 将代码修改以及相关依赖包构建成为 Docker 镜像。 同时你也可以配置 pipeline 的其他步骤来测试代码或生成包。

  3. 在构建及测试步骤完成之后,Docker 镜像将被推送到 Amazon ECR

  4. AWS CodePipeline 触发 AWS Lambda 函数,该函数使用到 Kubernetes Python 客户端来对 Kubernetes 进行操作。 Lambda 函数将 Kubernetes deployment 配置文件中 Docker Image tag 替换为刚被推送到 ECR 中的镜像

  5. 在 Kubernetes deployment 的参数修改完之后,AWS Lambda 将调用 Kubernetes API 去重新部署 Kubernetes deployment 以完成 deployment 中 docker 镜像的更新

  6. Kubernetes 将使用会滚动升级 pods 中的应用,使得所有 pod 都使用 ECR 中的相应 docker 镜像。至此为止,Pipeline 成功响应了 CodeCommit 上 master 代码分支的修改。同时该 pipeline 很容易扩展,你可以在代码被部署到生产环节之前,增加测试环节或者增加部署到预生产环境的环节


下面展示了一个支持该流程的 AWS CodePipeline 的例子:


结论:

我们非常高兴你能使用这些 pipeline 更为轻松的在 Kuberntes 上开发和部署容器应用。你可以在 CodeSuite – Continuous Deployment Reference Architecture for Kubernetes上找到更多相关的 AWS CloudFormation 模版。该仓库详细的描述了如何创建 pipeline 并使用它去部署应用。 如果有更多的问题,意见,反馈,请及时让我们知道。


作者介绍:


张恒


AWS 中国区专业服务咨询顾问,拥有多年互联网开发经验,精通虚拟化及容器技术。
复制代码


本文转载自 AWS 技术博客。


原文链接:


https://amazonaws-china.com/cn/blogs/china/continuous-deployment-to-kubernetes-using-aws-codepipeline-aws-codecommit-aws-codebuild-amazon-ecr-and-aws-lambda/


2019-10-18 08:00965
用户头像

发布了 1855 篇内容, 共 122.0 次阅读, 收获喜欢 79 次。

关注

评论

发布
暂无评论
发现更多内容

易于使用的 PDF 编辑器和注释器 PDF Expert for Mac

Rose

云起无垠入围“2024第五届“科创中国”科技创新创效大赛总决赛TOP10企业榜单”

云起无垠

如何区分产品研发管理和研发项目管理?实用指南

易成研发中心

项目管理 产品研发 产品研发管理

探究亚马逊详情API接口:开发与应用

科普小能手

API API 接口 亚马逊API 亚马逊商品详情API 亚马逊API接口

电子电器组装行业MES系统解决方案

万界星空科技

mes 万界星空科技mes 电子mes 电子行业 电子电器行业

一文读懂计算机视觉「目标检测」的基本原理和主流模型

Zilliz

人工智能 计算机视觉 目标检测

百度智能云 VectorDB 优势项目数量并列 TOP 1

Baidu AICLOUD

Milvus Zilliz 向量数据库 VDB

Downie 4 for Mac(网站在线视频下载工具)

Mac相关知识分享

一文解读GaussDB(DWS)监控运维诊断优化能力

华为云开发者联盟

sql 数据仓库 GaussDB

Linux 文件处理命令:掌握文件管理的利器

测试人

软件测试

从 MongoDB 迁移到 TiDB

TiDB 社区干货传送门

TiDB数据库的垃圾回收机制

TiDB 社区干货传送门

监控 管理与运维

Final Cut Pro for Mac(fcp专业视频后期制作软件中文版)

Mac相关知识分享

量子计算与人工智能的交汇:科技未来的新引擎

天津汇柏科技有限公司

人工智能 量子计算

TiDB v8.5 LTS 新版本解密

TiDB 社区干货传送门

数据库前沿趋势 8.x 实践

利用人工智能 ChatGPT 提升测试开发能力:通往高效之路

测试人

软件测试

小公司如何做好项目管理工作?管理者的实战经验

易成研发中心

项目管理 程序员 项目软件管理

SQL Server 迁移到 TiDB

TiDB 社区干货传送门

SqlServer 到 TiDB(DATAX)

TiDB 社区干货传送门

Go Web服务中如何优雅平滑重启?

左诗右码

淘宝商品详情API:如何通过商品ID获取全面信息

代码忍者

API 接口 pinduoduo API

数据规模超 1PB !揭秘网易游戏规模化 TiDB SaaS 服务建设

TiDB 社区干货传送门

集群管理

我们是如何实现 TiDB Cloud Serverless 的 - 成本篇

TiDB 社区干货传送门

TiDB Cloud

荣誉|奇点云入选首批“百舸企业”名单

奇点云

「混合专家模型」可视化指南:A Visual Guide to MoE

Baihai IDP

程序员 AI LLMs MoE 混合专家模型

从 Oracle 迁移到 TiDB (OGG)

TiDB 社区干货传送门

从 DB2 迁移到 TiDB (CDC)

TiDB 社区干货传送门

电脑重装系统后硬盘数据可以恢复吗?系统重装后以前的文件怎么找回来?

阿拉灯神丁

EasyRecovery 数据恢复软件 电脑 备份 & 恢复 系统还原

基于 TiDB Vector 开发的 TiDB AI 小助手上线啦!招募 200 名试用体验官,开启高效问题解决之旅

TiDB 社区干货传送门

星辰资讯 | TiDB v7.5.4 & v8.4.0 发版

TiDB 社区干货传送门

版本升级

空壳产品之路:直面自身的缺点

iofomo

产品 设计 工具 摸鱼 微信分身

结合 AWS 服务与 Kubernetes 的持续集成_文化 & 方法_亚马逊云科技 (Amazon Web Services)_InfoQ精选文章