写点什么

选型必看:Kubernetes 应用程序部署工具应该选哪些?

  • 2020-11-29
  • 本文字数:3033 字

    阅读完需:约 10 分钟

选型必看:Kubernetes 应用程序部署工具应该选哪些?

将应用程序部署到 Kubernetes 比较简单,但要进行大型项目管理实现配置自动化就相对复杂了,本文介绍了 Kubernetes 应用程序生命周期管理的各个阶段可能会使用的一些工具(主流非主流的都有),而且通过标注各项目背后的投资大佬,给大家提供一种选择的决策依据。


将应用程序部署到 Kubernetes 非常简单,只需要用 yaml 或 json 编写一些资源定义并将它们应用到 kubectl 中就可以了,但要实现配置自动化就相对复杂了。


在应用程序部署中,一个比较流行的做法是将持续部署和 GitOps 结合使用:每次对源代码进行更改后,资源都会自动部署。如果想要使用 GitOps 将应用程序部署到 Kubernetes,需要经历以下过程:


  • 容器映像构建, 将源代码和本地依赖关系构建到容器映像中。

  • 资源模板, 为环境定制部署资源的资源模板。

  • 包管理, 将多个资源捆绑到版本发布中,并管理包依赖关系。

  • 持续部署, 通常通过一系列操作和步骤,对环境进行更改。

  • 命令式部署, 以编程方式管理复杂的服务生命周期,并减少手动或简单的脚本化步骤。

  • 自动缩放, 根据资源使用情况和消耗情况,自动缩放来管理应用程序的响应和资源分配。


在本文中,我介绍了 Kubernetes 应用程序生命周期管理的各个阶段可能会使用的一些工具(主流非主流的都有)。由于很难客观地判断工具的流行性和成熟度, 因此我对这些工具进行了注释,说明了哪些大型公司对这些项目进行了投资,供你参考判断。不过请记住,大公司对一个项目通常可能会做多个竞争性投资,因此,仅仅因为项目拥有一位知名的投资者,并不能得出它可以长期生存和发展的结论。


希望此列表可以在你寻找应用程序部署问题解决方案时提供一些帮助。


容器镜像构建


  • Moby / buildkit (Docker) ——用于将源代码转换为构建工件的工具包。

  • kaniko (Google)—— 在容器或 Kubernetes 集群中从 Dockerfile 构建容器映像的工具。

  • img (Jess Frazelle) ——一个独立的,没有守护进程,非特权模式的 Dockerfile 和 OCI 兼容的容器映像构建器。

  • buildah (IBM/Red Hat)——用于构建开放式容器计划(OCI)容器映像的工具。

  • Source-To-Image (IBM/Red Hat)——用于从源构建工件并注入容器映像的工具。

  • Tanzu Build Service / kpack / pack (VMware/Pivotal) ——使用 Cloud Native Buildpacks 构建应用程序的 CLI 和服务。

  • Carvel / kbld (VMware/Pivotal)——用于构建映像并将其推入开发和部署工作流的服务。

  • Google Cloud Buildpacks (Google)——为运行在谷歌云的容器平台而设计的构建器和构建包。

  • Makisu (Uber) ——快速而灵活的 Docker 镜像构建工具,可以在 Mesos 和 Kubernetes 等非特权的容器环境中工作。


资源模板


  • Helm (Microsoft, Google) ——Kubernetes 包管理器。

  • Kustomize (Google, Apple)——用于定制原始的、无模板的 YAML 文件的 CLI,使原始的 YAML 保持原样并保持可用。

  • Carvel / ytt (VMware/Pivotal)——基于 YAML 结构的 YAML 模板工具。

  • jsonnet / go-jsonnet (Google) ——JSON 模板语言。

  • gomplate (Dave Henderson) ——用于 golang 模板渲染的 CLI,支持本地和远程数据源。

  • Mustache (Github) ——与框架无关的 JSON 模板引擎。

包管理



持续部署


  • Spinnaker (Netflix, Google) ——多云持续交付平台,用于快速高质量迭代发布软件变更。

  • Terraform Kubernetes Provider (Hashicorp) ——一个Terraform插件,支持 Kubernetes 资源的完整生命周期管理。

  • Concourse (VMware/Pivotal)——一个基于容器的连续事务处理程序,用 Go 和 Elm 编写。

  • JenkinsX (CloudBees)—— 用于 Kubernetes 的自动化 CI / CD,提供使用TektonKnativeLighthouseSkaffold和 Helm 的 pull 请求预览环境

  • Argo CD (Intuit)—— 用于 Kubernetes 的高效 GitOps 持续交付工具。

  • Tekton / Tekton Pipelines (Google) ——一个 Kubernetes 控制器, 提供 CI / CD 样式的管道资源。

  • Cloud Build (Google)——在谷歌云平台基础设施上执行构建的服务。

  • Skaffold (Google)——促进 Kubernetes 应用程序持续开发的 CLI。

  • Azure DevOps / Azure Pipelines (Microsoft) ——一种云服务,它可以自动构建和测试项目的代码,并将其提供给其他用户。

  • Brigade (Microsoft) —— Kubernetes 的基于事件的脚本。

  • Habitat / habitat-operator (Chef) ——Kubernetes 控制器,在 Kubernetes 上运行和管理 Habitat 服务。

  • gitkube (Hasura) ——使用 git push 在 Kubernetes 上构建和部署 Docker 镜像的工具。

命令式部署


  • Kubebuilder (CNCF, Google, Apple, IBM/Red Hat) ——用于使用 CRD 构建 Kubernetes API(以及控制器和操作符)的 SDK。

  • Operator Framework / Operator SDK (IBM/Red Hat/CoreOS) ——用于构建 Kubernetes 应用程序操作符的 SDK。

  • KUDO (D2IQ) ——使用声明式方法构建生产级 Kubernetes 操作符的框架。

  • Pulumi (Pulumi)——可以作为代码 SDK 的基础设施,用于在各种云上创建和部署使用容器、无服务器功能、托管服务和基础架构的云软件。

  • Carvel / kapp / kapp-controller (VMware/Pivotal)——CLI 和 Kubernetes 控制器,用于安装应用程序 CRD 所描述的配置(helm 图表, ytt 模板,yaml 文件)。

  • Isopod (Cruise)——在没有 YAML 的情况下,用于 Kubernetes 资源配置的表达性 DSL 和框架。


自动缩放


  • Horizontal Pod Autoscaler (built-in)—— Kubernetes 控制器,它根据配置的指标自动伸缩复制控制器、部署、复制集或有状态集中的 Pods 数量。

  • Vertical Pod Autoscaler (Google)——一组 Kubernetes 组件,自动调整运行在 Kubernetes 集群中的 pods 请求的 CPU 和内存数量。

  • Addon Resizer (Google) ——垂直 Pod 自动调用器的简化版本,它根据 Kubernetes 集群中的节点数量修改部署的资源请求。

  • KEDA (Microsoft)——一个基于 kubernet 的事件驱动的自动缩放组件。

  • Watermark Pod Autoscaler Controller (DataDog) ——扩展了 Horizontal Pod Autoscaler (HPA)的自定义控制器。

  • Pangolin (Damian Peckett)—— 针对 Kubernetes 的一个增强的 Horizontal Pod Autoscaler,它基于 Prometheus 指标来扩展部署,使用各种高度可配置的控制策略。

  • Predictive Horizontal Pod Autoscaler (IBM) —— 自定义 Pod Autoscaler,类似于 Horizontal Pod Autoscaler,但是添加了预测元素。

  • Horizontal Pod Autoscaler Operator (Banzai Cloud)——Kubernetes 控制器,它监视部署或状态集,并基于 autoscale 注释自动创建 Horizontal Pod Autoscaler 资源。


写在最后


正如 DevOps 倡导者宣扬的那样:这与工具无关,而与观念有关。没有一个工具能给你带来让你兴奋的全生命周期端到端管理体验,因为每种工具都有他们自己的工具组合,通过与脚本和集成代码配合完成工作。


你可以找到能够很好地完成一件事情的工具,易于替换和扩展,也可以选择为你提供最大性价比的工具,让你更容易对项目进行管理,集成成本也更低,同时还拥有较好的端到端用户体验。以上的选择都没有什么错。


权衡这些因素后,你还需要看看这些项目背后的大佬,它是哪家公司投资的、项目的流行度如何?那些拥有大型公司或者有着多样化投资者的主流工具更具有持续成长性。不然,你选择后,项目不更新或者被抛弃了,那你只能花自己的时间和精力来维护这些工具了。


原文链接


https://medium.com/@KarlKFI/compendium-of-kubernetes-application-deployment-tools-80a828c91e8f


2020-11-29 17:342617

评论

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

Sentieon DNAscope:适配多测序平台数据的快速精准分析流程

INSVAST

基因测序 基因数据分析 DNAscope

NFT公链 联盟链 DAPP区块链开发部署

V\TG【ch3nguang】

公链 DAPP系统开发 NFT

生命数字化时代来临:全基因组计算成本不到1美元

INSVAST

基因测序 基因数据分析

DNAscope白皮书: 基于机器学习的高精度胚系变异检测流程

INSVAST

基因测序 基因数据分析

一文了解新能源汽车中包含多少种芯片

华秋电子

英伟达 汽车

TiDB 源码编译之 TiProxy 篇

TiDB 社区干货传送门

版本测评 新版本/特性解读 7.x 实践

苹果电脑推荐 Office 2019 v16.77 beta永久激活版+激活工具

胖墩儿不胖y

Mac软件 office办公套件 Office 2019中文版

诚邀报名 | 开放原子开发者工作坊:源安全——论开源项目的安全之道

开放原子开源基金会

开源

常见API架构介绍

java易二三

Java 程序员 计算机 API

NFT代币智能合约交易所系统开发部署[源码搭建]

V\TG【ch3nguang】

智能合约 交易所开发 NFT

Sentieon | 每周文献-Long Read Sequencing(长读长测序)-第七期

INSVAST

基因测序 长读长测序 Long Read

仓库进销存ERP管理系统开发搭建部署

V\TG【ch3nguang】

进销存系统 ERP管理系统

高效模拟常见业务数据的 Mock 功能

Apifox

程序员 前端 API Mock Mock 服务

项目开展CICD的实践探路 | 京东物流技术团队

京东科技开发者

CI/CD 测试 单元测试 Bamboo 企业号 8 月 PK 榜

理解TiDB集群的P99计算方式

TiDB 社区干货传送门

数据库架构设计 应用适配

Android图片资源检测插件实现

java易二三

Java 程序员 计算机 插件 APK

财务数智化十年“老兵”的六条财务共享中心建设体会

用友BIP

智能财务 财务共享

Sentieon|应用教程:利用Sentieon Python API引擎为自研算法加速

INSVAST

开源软件 基因测序 Python API

解放双手!ChatGPT助力编写JAVA框架! | 京东云技术团队

京东科技开发者

Java java框架 ChatGPT 企业号 8 月 PK 榜

似懂非懂的 AspectJ

江南一点雨

spring

揭秘 | RocketMQ文件清理机制~

java易二三

Java 程序员 计算机

靶向RNA-seq全面解决方案和加速分析,只看这篇就够了!

INSVAST

基因测序 基因数据分析 RNAseq

【保护你的上线】风险治理的防范与排查之路 | 京东云技术团队

京东科技开发者

运维 测试 企业号 8 月 PK 榜 上线风险 风险排查

用好「留存」,闭环小程序运营链路

FinClip

基因组大数据计算: CPU和GPU加速方案深度评测

INSVAST

基因测序 基因数据分析

EDS从小白到专家丨生态产业链高效协同的一计良策

华为云开发者联盟

云计算 后端 华为云 华为云开发者联盟 企业号 8 月 PK 榜

Hap-eval:Sentieon开源的多测序平台SV精度评估工具

INSVAST

代码 基因测序 Hap-eval

使用Sentieon加速甲基化WGBS数据分析

INSVAST

基因测序 dna WGBS 甲基化

DAPP智能合约交易所系统开发搭建

V\TG【ch3nguang】

DAPP智能合约交易系统开发

tidb数据库5.4.3和6.5.3版本性能测试对比

TiDB 社区干货传送门

版本测评 性能测评 6.x 实践

选型必看:Kubernetes 应用程序部署工具应该选哪些?_服务革新_Karl Isenberg_InfoQ精选文章