我真的需要Kubernetes吗?

简介: ​Kubernetes会做什么?改善单体应用增强单体应用不再使用单体应用​

222.jpg

如果你关注技术新闻,那么Kubernetes似乎无处不在。它已经变得非常流行。实际上,如果不使用Kubernetes,开发人员和DevOps团队可能会觉得他们的应用程序开发流水线已经过时了。

Kubernetes是用于容器化应用程序的编排工具。从Docker容器开始,Kubernetes可以控制云应用程序和微服务的资源分配和流量管理。

这样,Kubernetes简化了面向服务的应用程序基础结构的许多方面。除了持续集成和持续部署(CI/CD),Kubernetes还提供了扩展这些应用程序的基础设施,而无需付出大量的工作。

使用Kubernetes来管理云和混合云环境有很多令人兴奋的事情。但是很多团队经常追赶热点并过早地迁移到Kubernetes,常常会造成会大量时间,金钱浪费,和开发人员的挫败感。

在本文中,我们将尝试并帮助你回答以下问题:我真的需要Kubernetes?

Kubernetes会做什么?

Kubernetes是用于容器化应用程序的编排工具。它负责:

    • 部署镜像和容器
    • 管理容器和集群的扩展
    • 容器和集群的资源管理
    • 服务的流量管理

    当你的应用程序由运行在不同容器中的多个服务组成时,Kubernetes确实会带来很多好处。对于具有静态用户群的单体应用,这可能超出了必要。

    构建,测试并将应用程序交付到容器仓库的任务不是Kubernetes的一部分,这些使用CI/CD工具就可以完成工作。除了CI/CD流水线,Kubernetes还可以帮助你将应用部署到生产环境中而不会造成服务停机。

    改善单体应用

    大多数应用程序都是以单体形式开始的--将整个应用程序放在一个地方,可以快速轻松地进行和部署更改。但是,如果你的应用程序发展壮大,你需要很快找到扩大规模的方法。

    这是否意味着该是Kubernetes的时候了?可能不是。

    通常,扩展更多地是关于应用程序的内部,而不是高级架构和工具。例如,你可以通过使用支持相似性标签的负载均衡器部署多个实例来扩展整体。

    扩展应用程序时要考虑的第一步是测试驱动开发(TDD),它可以确保软件质量并防止随着应用程序的增长而出现问题。尽管较小的模块或服务更易于测试,但模块化也意味着对mocking需求增加,并且需要额外的工具来配置和维护。良好的测试可以使你轻松自信地构建和扩展应用程序。

    当你开始扩展整体时,Chef和Ansible等配置管理工具会派上用场。你可以使用它们来自动配置新服务器,以确保它们准备好运行你的应用程序。你甚至可以更进一步,并使用Terraform之类的工具来帮助配置新的服务器VM,这样你就不必手动创建它们。

    当应用程序的其他部分成为瓶颈(例如数据库)时,你也可以扩展这些部分。例如,如果数据库成为瓶颈,则可以将经常访问的数据移至高性能内存数据存储(如Redis)中,以减少数据库的负载。

    无论你使用哪种配置管理和配置工具,都必须有一个良好的CI/CD流水线。第一次部署应用程序时,你可能已通过FTP将zip文件复制到服务器,但是这种方法无法扩展。简化的CI/CD流水线可确保自动构建,测试和部署你的应用程序,而无需你或你的团队进行任何额外的工作。

    你甚至可以使用AWS Elastic Beanstalk,Google App Engine或Azure App Service等云服务自动缩放单体应用。与Kubernetes相比,所有这些都带来了更少的管理开销,并且它们都可以与CI/CD工具很好地协同工作。

    在开发新应用程序时,请专注于开发最佳应用程序。像Kubernetes这样的复杂工具可能是管理应用程序基础结构的正确解决方案。

    增强单体应用

    随着应用程序的不断增长,你可能最终将无法继续添加功能到单体应用中。这通常是因为该应用,接近单个开发团队可以从事的工作的极限。

    在这一点上,许多团队选择拆分单体应用并完全迁移到微服务中。尽管这是一个颇受欢迎的决定,但它既不是必需的决定,也不是灵丹妙药。组织,可以考虑从添加单体应用的功能服务开始,而不是整体替换单体应用。这些支持服务中的某些实际上可能就是微服务-因此,你可以在合理的情况下使用小型服务而受益,同时仍可利用单体应用的好处。

    即使引入微服务,你可能也不需要或不想从Kubernetes开始。Kubernetes擅长运行和扩展相关服务和微服务容器的Pod。但是,采用Kubernetes的某些方面很容易被忽略,例如,Kubernetes没有用于保护Pod,节点和集群的强大内置工具,并且在多云环境中部署Kubernetes集群会增加很多复杂性。

    从像Azure Service Fabric和AWS Fargate这样的单云平台开始,可以更轻松地启动和扩展服务,而不必强迫你进行Kubernetes集群的管理。

    另一个选择是完全避免具有维护开销的服务,并选择功能即服务(FaaS),例如AWS Lambda或Azure Functions。FaaS是一种在向应用程序添加服务时最大程度地减少潜在基础架构开销的好方法。此外,如果你最终需要使用Kubernetes编排的集群,则可以使用FaaS功能进行增强。

    不再使用单体应用

    现在,想象你的单体应用已经增长得如此之快,以至于你不能采用单体应用方式,开始需要迁移到微服务架构。

    慢慢地,你拥有了各种各样的服务,其中许多服务需要彼此通信。你需要确保相互依赖的服务始终处于正常运行状态并且彼此可见。

    此外,你有时还需要考虑跨多个可用性区域(甚至可能跨多个云供应商)运行。

    在这一点上,你可能需要像Kubernetes这样的协调器。它使你可以轻松定义相关服务的模块(Pods),并可以自动缩放应用实例并在服务之间进行负载均衡。

    为了使Kubernetes发挥作用,组织需要:

      • 操作几个或几十个虚拟机
      • 分配人员进行Kubernetes专门的配置和维护
      • 使大部分同类服务部署自动化
      • 与云(或托管)提供商无关

      此外,Kubernetes内置了对高可用性(Amazon RDS Multi-AZ)部署的支持,这使得提高应用程序的可靠性和可用性变得更加容易。

      当然,这确实带来了开销:需要时间和工程资源来创建和管理集群,定义Pod以及创建适合部署到Kubernetes的容器化应用程序。但是,如果你的应用足够大,可以从Kubernetes中受益,那么管理开销是值得的。

      结论

      Kubernetes功能强大,但这并不意味着它是每个团队和每个应用程序的正确选择。与任何技术一样,它可以解决某些问题。如果你没有遇到Kubernetes想要解决的问题,那就麻烦多了。

      首先,建议使用简单可用工具将应用程序快速发布。当你的应用程序达到其部署和扩展成为自身运转的一部分时,就有必要开始考虑编排,并且自然而然地将Kubernetes作为编排工具。

      相关实践学习
      通过Ingress进行灰度发布
      本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
      容器应用与集群管理
      欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
      目录
      相关文章
      |
      8月前
      |
      Kubernetes 负载均衡 Linux
      Kubernetes的应用
      Kubernetes的应用
      79 0
      |
      运维 Kubernetes 负载均衡
      Kubernetes介绍篇:是什么?为什么要用?
      是时候该学习Kubernetes了,不然都不敢说自己了解容器、了解Docker。
      1319 0
      Kubernetes介绍篇:是什么?为什么要用?
      |
      5月前
      |
      Kubernetes 负载均衡 调度
      在K8S中,什么是kubernetes?
      在K8S中,什么是kubernetes?
      |
      5月前
      |
      存储 Kubernetes 负载均衡
      Kubernetes(K8S) 介绍
      Kubernetes(K8S) 介绍
      52 1
      |
      8月前
      |
      Kubernetes 前端开发 网络协议
      Kubernetes服务
      Kubernetes服务
      72 0
      Kubernetes服务
      |
      8月前
      |
      Kubernetes 虚拟化 容器
      带你一分钟看懂 “kubernetes”
      从官方网站上可以看到,它是一个工业级的容器编排平台。Kubernetes 这个单词是希腊语,它的中文翻译是“舵手”或者“飞行员”。在一些常见的资料中也会看到“ks”这个词,也就是“K8s”,它是通过将 8 个字母“ubernete ”替换为“8”而导致的一个缩写。
      131 2
      |
      8月前
      |
      Kubernetes 监控 关系型数据库
      了解Kubernetes
      kubernetes入门
      48 0
      |
      Kubernetes 容器
      Kubernetes的ExternalName详解
      ExternalName类型的Service在Kubernetes中用于将外部服务(不是Kubernetes集群内的服务)映射到Kubernetes集群内的Service。 # 样例 其创建方法如下: ``` kind: Service apiVersion: v1 metadata: name: my-external-service namespace: cv-console-dev labels: app: my-external-service annotations: kubesphere.io/creator: sunjq kubesph
      364 0
      |
      Kubernetes 调度 Docker
      了解和使用 Kubernetes
      通过 [《容器集群管理工具 Docker Swarm》](https://wangbinguang.blog.csdn.net/article/details/131082281)可以知道,在部署、调度、扩展和管理较多的容器时,如果有一个工具帮忙做这些事,那无疑会大大提高工作效率了。那 Docker Swarm 就是这样的工具,同样 Kubernetes(简称k8s)也是这样的一个工具,相对于 Docker Swarm, Kubernetes 生态比较庞大,有更多的支持、服务和工具。至于用哪个,萝卜青菜各有所爱吧。
      107 0
      |
      存储 人工智能 Kubernetes
      Kubernetes-k8s
      Kubernetes(通常简称为"k8s")是一种开源容器编排平台,用于自动化部署、扩展和管理容器化应用程序。它最初由Google开发,并于2014年发布为开源项目,目前由云原生计算基金会(CNCF)管理和维护。
      128 1