此外,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 设计开发。