1. 前言
开个新坑,记录下自己的Kubernetes渐进式学习笔记,整个过程大概会分为三个部分,核心概念篇,实战进阶篇,运维管理篇。
2. 什么是Kubernetes
Kubernetes 是一个开源的,用于管理云平台中多个主机上的容器化的应用,Kubernetes 的目标是让部署容器化的应用简单并且高效(powerful),Kubernetes 提供了应用部署,规划,更新,维护的一种机制。
Kubernetes 这个名字源于希腊语,意为“舵手”或“飞行员”。k8s 这个缩写是因为 k 和 s 之间有八个字符的关系。 Google 在 2014 年开源了 Kubernetes 项目。 Kubernetes 建立在 Google 大规模运行生产工作负载十几年经验的基础上, 结合了社区中最优秀的想法和实践。
3. 为什么需要Kubernetes
我们首先来看看应用部署发展的三大阶段
3.1. 应用部署的三大阶段
(1)传统部署
程序员/运维工程师手动操作部署应用,直接将应用部署在目标机器上,由于资源不隔离,容易出现资源争抢、依赖冲突等各方面问题。
(2)虚拟化部署
利用 OpenStask / VMware 等虚拟化技术,将一台目标机器虚拟化为多个虚拟机器,按照需求将应用部署到不同的虚拟机中,对虚拟机进行动态的水平扩容等管理操作。
相对传统部署自动化、资源隔离的能力提升了,带来的问题是虚拟化的逻辑过重,导致效率不高,且耗费资源较多。
(3)容器部署
可以理解为轻量级的虚拟化,完美弥补虚拟化技术过重的问题,且由于直接共享主机硬件资源,只是通过系统提供的命名空间等技术实现资源隔离,损耗更小,且效率更高。
容器化部署相比与前两者可能轻松了不少,但是如果对于几十个几百个上千个容器,我们肯定不能通过手动来创建,我们需要一种方法来管理大规模容器化的应用程序,而Kubernetes提供了一种高效的方式来编排这些容器,运用较为广泛。
3.2. K8S的特点
K8S的特点包括但不限于如下:
- 自动化部署与回滚:Kubernetes允许用户自动化容器的部署和更新。如果更新后的容器不健康,它还能自动回滚到之前的版本。
- 服务发现和负载均衡:Kubernetes可以使用DNS名或自己的IP地址自动发现容器,如果容器的流量过大,Kubernetes也能够负载均衡流量,确保部署稳定。
- 存储编排:Kubernetes允许您自动挂载您选择的存储系统,无论是本地存储、公共云提供商如GCP或AWS,还是网络存储系统如NFS或iSCSI等。
- 自我修复:Kubernetes能够确保部署的容器是健康的,如果不是,它会自动重启容器,确保服务一直是可用的。
- 水平扩展:您可以使用简单的命令、用户界面或基于CPU等使用情况的自动设置来扩大或缩小应用。
- 弹性伸缩:Kubernetes可以根据资源使用情况或自定义指标自动扩容或缩容应用程序。
- 批处理:除了服务之外,Kubernetes还可以管理批处理作业,确保任务可靠地完成。
4. 企业级容器调度平台对比
4.1. Apache Mesos
Mesos 是一个分布式调度系统内核,早于 Docker 产生,Mesos 作为资源管理器,从 DC/OS (数据中心操作系统)的角度提供资源视图。主/从结构工作模式,主节点分配任务,并用从节点上的 Executor 负责执行,通过 Zookeeper 给主节点提供服务注册、服务发现功能。通过 Framework Marathon 提供容器调度的能力。
优势:
经过时间的检验,作为资源管理器的 Apache Mesos 在容器之前就已经出现很久了,支持运行容器化化和非容器化的工作负载。可以支持应用程序的健康检查,开放的架构。支持多个框架和多个调度器,通过不同的 Framework 可以运行 Haddop/Spark/MPI等多种不同的任务。
支持超大型规模的节点管理,模拟测试支持超过 5w+ 节点,在大规模上拥有较大优势。
4.2. Docker Swarm
Docker Swarm 是一个由 Docker 开发的调度框架。由 Docker 自身开发的好处之一就是标准 Docker API 的使用,Swarm 由多个代理(Agent)组成,把这些代理称之为节点(Node)。这些节点就是主机,这些主机在启动 Docker Daemon 的时候就会打开相应的端口,以此支持 Docker 远程 API。这些机器会根据 Swarm 调度器分配给它们的任务,拉取和运行不同的镜像。
优势:
从 Docker1.12 版本开始,Swarm 随 Docker 一起默认安装发布。由于随 Docker 引擎一起发布,无需额外安装,配置简单。支持服务注册、服务发现,内置 Overlay Network 以及 Load Balancer。与 Docker CLI 非常类似的操作命令,对熟悉 Docker 的人非常容易上手学习。
入门门槛、学习成本较低,使用更便捷,适用于中小型系统。
4.3. Google Kubernetes(K8S)
Kubernetes 是基于 Google 在过去十五年来大量生产环境中运行工作负载的经验。Kubernetes 的实现参考了 Google 内部的资源调度框架,但并不是 Borg 的内部容器编排系统的开源,而是借鉴 Google 从运行 Borg 获得的经验教训,形成了 Kubernetes 项目。
它使用 Label 和 Pod 的概念来将容器划分为逻辑单元。Pods 是同地协作(co-located)容器的集合,这些容器被共同部署和调度,形成了一个服务,这是 Kubernetes 和其他两个框架的主要区别。相比于基于相似度的容器调度方式(就像 Swarm 和Mesos),这个方法简化了对集群的管理。
优势:
最流行等容器编排解决方案框架,基于 Google 庞大的生态圈及社区产生的产品。通过 Pods 这一抽象的概念,解决 Container 之间的依赖于通信问题。Pods,Services,Deployments 是独立部署的部分,可以通过 Selector 提供更多的灵活性。内置服务注册表和负载平衡。
适用度更广,功能更强大,相较于 Mesos 来说节点规模较小。
5. 总结
Kubernetes 是一个开源的容器编排平台,用于自动化计算机软件的部署、扩展和管理。本次简单的介绍了什么是Kubernetes,从应用部署方面出发思考为什么需要Kubernetes,以及各个容器调度平台之间的对比。