带你读《云原生应用开发:Operator原理与实践》——1.1.2 Kubernetes:云原生基础设施

简介: 带你读《云原生应用开发:Operator原理与实践》——1.1.2 Kubernetes:云原生基础设施

1.1.2 Kubernetes:云原生基础设施


2014 年,Google 公司开源了 Kubernetes 项目。此时,在容器编排领域主要有两个竞争对手,即 Docker 公司的 Docker Swarm 和 Apache 基金会的 Mesos。虽然 Kubernetes诞生得较晚,但实际上其设计思想来源于 Google 公司内部的 Borg 和 Omega 系统特性,这些特性放到 Kubernetes 项目上,就是 Pod、Sidecar 等功能和设计模式。这些特性并不是几个工程师突发奇想的结果,而是 Google 公司在容器化基础设施领域多年来实践经验的沉淀与升华。为了推广 Kubernetes 项目,同时与 Docker 公司竞争,Google 和 Red Hat 联合发起 CNCF 基金会。有了这两家公司的背书,CNCF 和 Kubernetes 迅速发展,该基金会下的项目和围绕 Kubernetes 的二次创新项目大量涌现,包括容器监控的实施标准 Prometheus、微服务治理项目 Istio、有状态应用部署框架 Operator 等。2017 年,Docker 公司宣布将在自己的主打产品 Docker 企业版中内置 Kubernetes,这标志着容器编排之争落下了帷幕,Kubernetes 成为容器编排的事实标准。

从技术角度来讨论 Kubernetes 为何能获胜也是个有意思的话题。

Kubernetes 从应用的角度定义了多种资源,用来描述不同的应用类型以及相关能力(见代码清单 1-1)

代码清单 1-1

 $ kubectl run nginx --image=nginx --replicas=3
deployment.apps/nginx created
$ kubectl get deployment nginx -w
NAME READY UP-TO-DATE AVAILABLE AGE
nginx 0/3 3 0 0s
nginx 1/3 3 1 3s
nginx 2/3 3 2 3s

(1) Pod:最小的调度单元,一个 Pod 包含一组容器,容器之间通常存在密切关系,例如,使用 localhost(本地主机)进行本地通信会直接发生文件交换、需要共享 Linux Namespace。

(2) Deployment:通常用来部署多副本的 Pod,可以看到 Pod 的状态,在 Pod 异常时能够及时处理故障,使其恢复正常。

(3) Statefulset:描述有状态应用,可以控制 Pod 的启动顺序,为 Pod 绑定不同的存储等。

(4) Job、CronJob:这两种类型资源分别对应一次性任务和周期性任务。

(5) Daemonset:通常用来部署后台常驻任务,如在每个节点上的日志程序。

除了以上描述应用的资源,还有其他资源。

(1) Service:描述了一个应用的访问入口,通过 Label(标签)实现 Service 与后端服务(Pod)的关联,也就实现了服务发现功能。

(2) Ingress:支持 Kubernetes 集群以外的客户端访问应用。

(3) Configmap、Secret:描述应用所需的配置参数或加密的密钥等。

(4) PV、PVC、HostPath、EmptyDir:描述应用所需的各类存储,支持持久化存储、临时储。

有了这些资源对象,使用者可以很方便地描述应用程序。通常使用 Yaml 文件表示,一个 kubectl apply -f myapp.yaml 命令就可以等待 Kubernetes 完成应用部署,达到期望状态,其背后重要的设计理念就是声明式 API 和控制器模式。简单理解,用户通过Yaml 文件描述了期望的最终状态,比如“我需要用 Nginx 镜像启动 3 个 Pod,然后通过名为 Myapp 的 Service 暴露这个应用”。Kubernetes 接收到这个请求时,会将其保存到 ETCD 数据库中,由控制器创建 3 个 Pod 和 1 个 Service。由于创建资源需要一定时间,控制器会不断检查这些资源的状态,并且和期望的状态比较,如果不一致,持续处理(例如调度到其他节点),直到最终达成一致,这个过程如图 1-4 所示。

image.png

图 1-4 Kubernetes 声明式 API、控制器模式

此外,Kubernetes 具备可扩展性。其实优秀的开源项目都支持扩展,例如 Open Stack 在网络层面定义了 Neutron 网络插件(Network Plugin),用于支持开源的 Open vSwitch(OVS)、商业化的 SDN 产品;在存储层面,通过 Cinder Volume Driver,支持逻辑卷管理(LVM,Logical Volume Manager)以及各种商业化的存储;在调度器层面,支持自定义 Scheduler。类似地,Kubernetes 通过 CRI(容器运行时接口)、CSI(容器存储接口)、CNI(容器网络接口),也支持计算、存储、网络的扩展性。更重要的是,Kubernetes在 API 资源层面也支持扩展,使用者可以通过自定义资源定义(CRD,Custom Resource Definition)自定义资源,而且这些资源和 Pod、Deployment 等原生资源有同样的使用方式,同时对已有代码没有侵入性。这就大大激发了开发者的潜能。再加上 Sidecar、Operator等机制,一系列优秀的开源项目如雨后春笋般涌现,大大加速了 Kubernetes 的发展。可以说,“占领开发者心智”是 Kubernetes 的重磅武器。

从 Kubernetes 诞生至今,它已经成为云原生基础设施的代名词。越来越多的开源项目 都 支 持 Kubernetes 部 署, 如 数 据 库 领 域 的 MySQL、MongoDB、Redis、TiDB, 大数据领域的 Spark、Splunk,监控领域的 Prometheus、Dynatrace OneAgent、Sysdig Agent Operator,安全领域的 Falco,微服务领域的 Istio、Linkerd 等。Kubernetes 在新兴领域也有很多项目,如人工智能领域的 Kubeflow,边缘计算领域的 KubeEdge、k3s等。在云服务商的产品目录中,Kubernetes 早已成为标配。Amazon Elastic Kubernetes Service、Azure Kubernetes Service、Google Kubernetes Engine、Alibaba Cloud Container Service for Kubernetes、Tencent Kubernetes Engine、China Mobile eCloud Kubernetes Container Service,从名字就可以看出,国内外云服务商的容器产品都围绕Kubernetes 设计开发。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
6天前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
49 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
1月前
|
Kubernetes Cloud Native 微服务
云原生入门与实践:Kubernetes的简易部署
云原生技术正改变着现代应用的开发和部署方式。本文将引导你了解云原生的基础概念,并重点介绍如何使用Kubernetes进行容器编排。我们将通过一个简易的示例来展示如何快速启动一个Kubernetes集群,并在其上运行一个简单的应用。无论你是云原生新手还是希望扩展现有知识,本文都将为你提供实用的信息和启发性的见解。
|
1月前
|
运维 Kubernetes Cloud Native
云原生技术入门:Kubernetes和Docker的协同工作
【10月更文挑战第43天】在云计算时代,云原生技术成为推动现代软件部署和运行的关键力量。本篇文章将带你了解云原生的基本概念,重点探讨Kubernetes和Docker如何协同工作以支持容器化应用的生命周期管理。通过实际代码示例,我们将展示如何在Kubernetes集群中部署和管理Docker容器,从而为初学者提供一条清晰的学习路径。
|
1月前
|
Kubernetes Cloud Native 云计算
云原生入门:Kubernetes 和容器化基础
在这篇文章中,我们将一起揭开云原生技术的神秘面纱。通过简单易懂的语言,我们将探索如何利用Kubernetes和容器化技术简化应用的部署和管理。无论你是初学者还是有一定经验的开发者,本文都将为你提供一条清晰的道路,帮助你理解和运用这些强大的工具。让我们从基础开始,逐步深入了解,最终能够自信地使用这些技术来优化我们的工作流程。
|
25天前
|
运维 Cloud Native 持续交付
深入理解云原生架构及其在现代企业中的应用
随着数字化转型的浪潮席卷全球,企业正面临着前所未有的挑战与机遇。云计算技术的迅猛发展,特别是云原生架构的兴起,正在重塑企业的IT基础设施和软件开发模式。本文将深入探讨云原生的核心概念、关键技术以及如何在企业中实施云原生策略,以实现更高效的资源利用和更快的市场响应速度。通过分析云原生架构的优势和面临的挑战,我们将揭示它如何助力企业在激烈的市场竞争中保持领先地位。
|
23天前
|
Kubernetes Cloud Native 微服务
探索云原生技术:容器化与微服务架构的融合之旅
本文将带领读者深入了解云原生技术的核心概念,特别是容器化和微服务架构如何相辅相成,共同构建现代软件系统。我们将通过实际代码示例,探讨如何在云平台上部署和管理微服务,以及如何使用容器编排工具来自动化这一过程。文章旨在为开发者和技术决策者提供实用的指导,帮助他们在云原生时代中更好地设计、部署和维护应用。
|
1月前
|
Cloud Native Devops 云计算
云计算的未来:云原生架构与微服务的革命####
【10月更文挑战第21天】 随着企业数字化转型的加速,云原生技术正迅速成为IT行业的新宠。本文深入探讨了云原生架构的核心理念、关键技术如容器化和微服务的优势,以及如何通过这些技术实现高效、灵活且可扩展的现代应用开发。我们将揭示云原生如何重塑软件开发流程,提升业务敏捷性,并探索其对企业IT架构的深远影响。 ####
44 3
|
1月前
|
Cloud Native 持续交付 云计算
云原生架构的演进与挑战
随着云计算技术的不断发展,云原生架构已成为企业数字化转型的重要支撑。本文深入探讨了云原生架构的概念、发展历程、核心技术以及面临的挑战,旨在为读者提供一个全面了解云原生架构的视角。通过分析Kubernetes、Docker等关键技术的应用,以及微服务、持续集成/持续部署(CI/CD)等实践案例,本文揭示了云原生架构在提高应用开发效率、降低运维成本、增强系统可扩展性等方面的显著优势。同时,也指出了云原生架构在安全性、复杂性管理等方面所面临的挑战,并提出了相应的解决策略。
|
23天前
|
运维 Cloud Native 持续交付
云原生技术深度探索:重塑现代IT架构的无形之力####
本文深入剖析了云原生技术的核心概念、关键技术组件及其对现代IT架构变革的深远影响。通过实例解析,揭示云原生如何促进企业实现敏捷开发、弹性伸缩与成本优化,为数字化转型提供强有力的技术支撑。不同于传统综述,本摘要直接聚焦于云原生技术的价值本质,旨在为读者构建一个宏观且具体的技术蓝图。 ####
|
26天前
|
弹性计算 运维 Cloud Native
云原生架构的崛起与未来展望
在数字化转型的浪潮中,云原生架构凭借其高效、灵活和可扩展的特性,正逐渐成为企业IT战略的核心。本文旨在探讨云原生架构的定义、关键特性、实施优势以及面临的挑战,同时展望未来的发展趋势。通过深入分析,我们期望为读者提供一个关于云原生架构全面而深入的视角,助力企业在云计算时代做出更明智的决策。
33 3