kubernetes01(k8s架构)

kubernetes01(k8s架构)

一.引子

上次我们聊到了docker容器技术,说到docke三剑客之一的docker swarm是用来做docker集群化管理的。然而由于kubernetes的出现,现在国内是很少用docker-swarm进行集群化管理了。到底kubernetes有什么魔力,可以让docker自研的管理工具毫无对抗性。下面让我们走进kubernetes的世界。

二.kubunetes基础概念

(一).kubernetes简介

Kubernetes是一个开源的,用于管理云平台中多个主机上的容器化的应用,Kubernetes的目标是让部署容器化的应用简单并且高效(powerful),Kubernetes提供了应用部署,规划,更新,维护的一种机制。
Kubernetes一个核心的特点就是能够自主的管理容器来保证云平台中的容器按照用户的期望状态运行着(比如用户想让apache一直运行,用户不需要关心怎么去做,Kubernetes会自动去监控,然后去重启,新建,总之,让apache一直提供服务),管理员可以加载一个微型服务,让规划器来找到合适的位置,同时,Kubernetes也系统提升工具以及人性化方面,让用户能够方便的部署自己的应用(就像canary deployments)
kubernetes的前世是google的Borg系统,也是一种多容器管理工具。borg系统在谷歌内部运行了十多年,在开源项目kubernetes上吸收了borg的各种经验,所以kubernetes的性能是完全不用担心的。

(二).kubernetes最小管理单元

此处对kubernetes的最小管理单元pod进行简单概述,接下来将会有一篇详细描述对pod的各项内容的介绍和管理。如果吧docker容器比作一个个集装箱的话,那我们的pod更像一条条货运船,货运船上有着一排排集装箱。而kubernetes就像是码头的控制台,管理着一条条货运船在码头的进出。

(三).kubernetes的架构及组件

1.kubernetes的分层架构

kubernets被誉为下一代的操作系统,能得到这种美誉,那必是不简单的。kubernetes的架构与Linux的架构非常相似,都属于分层架构。
kubernetes01(k8s架构)

  • 核心层:Kubernetes最核心的功能,对外提供API构建高层的应用,对内提供插件式应用执行环境
  • 应用层:部署(无状态应用、有状态应用、批处理任务、集群应用等)和路由(服务发现、DNS解析等)
  • 管理层:系统度量(如基础设施、容器和网络的度量),自动化(如自动扩展、动态Provision等)以及策略管理(RBAC、Quota、PSP、NetworkPolicy等)
  • 接口层:kubectl命令行工具、客户端SDK以及集群联邦
  • 生态系统:在接口层之上的庞大容器集群管理调度的生态系统,可以划分为两个范畴
  • Kubernetes外部:日志、监控、配置管理、CI、CD、Workflow、FaaS、OTS应用、ChatOps等
  • Kubernetes内部:CRI、CNI、CVI、镜像仓库、Cloud Provider、集群自身的配置和管理等

2.kubernetes架构组成

Kubernetes的架构分为Master和Node两部分,如图1所示。由上图可以看出这两部分由五种主要的组件构成,它们之间协同工作从而完成整个集群的管理,这五种组件分别为API Server、Controller Manager、Scheduler、Kubelet、etcd。
kubernetes01(k8s架构)
kubernetes01(k8s架构)

上面两图结合系统架构图:

kubernetes01(k8s架构)
在这张系统架构图中,我们把服务分为运行在工作节点上(pod级别)的服务和组成集群级别控制板的服务。
Kubernetes节点有运行应用容器必备的服务,而这些都是受Master的控制。每次个节点上当然都要运行Docker。Docker来负责所有具体的映像下载和容器运行。

3.kubernetes核心组件详解

  • etcd保存了整个集群的状态(持久化存储);所有master的持续状态都存在etcd的一个实例中。这可以很好地存储配置数据。因为有watch(观察者)的支持,各部件协调中的改变可以很快被察觉。
  • apiserver提供了资源操作的唯一入口,并提供认证、授权、访问控制、API注册和发现等机制;封装了核心对象的增删改查操作,以 RESTful API 接口方式提供给外部客户和内部组件调用。维护的 REST 对象持久化到 Etcd 中存储
  • controller manager负责维护集群的状态,比如故障检测、自动扩展、滚动更新等;
  • scheduler负责资源的调度,按照预定的调度策略将新建立的 Pod 进行节点 (node) 选择(即分配机器),。组件抽离,可以方便替换成其他调度器
  • kubelet负责维护容器的生命周期,同时也负责Volume(CVI)和网络(CNI)的管理;同时负责管理pods和它们上面的容器,images镜像、volumes、etc。
  • Container runtime负责镜像管理以及Pod和容器的真正运行(CRI);
  • kube-proxy负责为Service提供cluster内部的服务发现,和负载均衡;

4.除了核心组件,还有一些推荐的Add-ons:

  • kube-dns负责为整个集群提供DNS服务
  • Ingress Controller为服务提供外网入口
  • Heapster提供资源监控
  • Dashboard提供GUI
  • Federation提供跨可用区的集群
  • Fluentd-elasticsearch提供集群日志采集、存储与查询

本章笔者带带大家了解kubernetes的一些基础概念,大家主要要理解master节点和node节点的组件及作用。这对我们接下来的篇章理解有及其重要的辅助作用。