Kubernetes 章节目录
一. Kubernetes 简介
Kubernetes,首字母 K,尾字母 s,中间 8 个字母,简称 K8s。
二、 Kubernetes 功能
目前只需要知道 Kubernetes 有以下 9 个功能,关于这 9 个功能,后面详细介绍。
1 自动装箱
基于容器对应用运行环境的资源配置要求自动部署应用容器
2 自我修复
当容器失败时,会对容器进行重启
当所部署的 Node 节点有问题时,会对容器进行重新部署和重新调度
当容器未通过监控检查时,会关闭此容器直到容器正常运行时,才会对外提供服务
3 水平扩展
通过简单的命令、用户 UI 界面或基于 CPU 等资源使用情况,对应用容器进行规模扩大或规模剪裁
当我们有大量的请求来临时,我们可以增加副本数量,从而达到水平扩展的效果
4 服务发现
用户不需使用额外的服务发现机制,就能够基于 Kubernetes 自身能力实现服务发现和负载均衡
5 滚动更新
可以根据应用的变化,对应用容器运行的应用,进行一次性或批量式更新
6 版本回退
可以根据应用部署情况,对应用容器运行的应用,进行历史版本即时回退
7 密钥和配置管理
在不需要重新构建镜像的情况下,可以部署和更新密钥和应用配置,类似热部署。
8 存储编排
自动实现存储系统挂载及应用,特别对有状态应用实现数据持久化非常重要
存储系统可以来自于本地目录、网络存储 (NFS、Gluster、Ceph 等)、公共云存储服务
9 批处理
提供一次性任务,定时任务;满足批量数据处理和分析的场景
三、 Kubernetes 架构组件
Kubernetes 架构主要包含两部分:Master(主控节点)和 Work node(工作节点)。
Kubernetes 组件
1 Master:主控节点
- API Server:集群统一入口,以 restful 风格进行操作,同时交给 etcd 存储
提供认证、授权、访问控制、API 注册和发现等机制 - scheduler:节点的调度,选择 node 节点应用部署
- controller-manager:处理集群中常规后台任务,一个资源对应一个控制器
- etcd:存储系统,用于保存集群中的相关数据
2 Worker node:工作节点
- Kubelet:master 派到 node 节点代表,管理本机容器
- 一个集群中每个节点上运行的代理,它保证容器都运行在 Pod 中
- 负责维护容器的生命周期,同时也负责 Volume(CSI) 和 网络 (CNI) 的管理
- kube-proxy:提供网络代理,负载均衡等操作
3 容器运行环境【Container Runtime】
- 容器运行环境是负责运行容器的软件
- Kubernetes 支持多个容器运行环境:Docker、containerd、cri-o、rktlet 以及任何实现 Kubernetes CRI (容器运行环境接口) 的软件。
4 fluentd
- 是一个守护进程,它有助于提升集群层面日志
四、 Kubernetes 核心概念
1 Pod
- Pod 是 K8s 中最小的单元,是一组容器的集合
- 共享网络【一个 Pod 中的所有容器共享同一网络】
- 生命周期是短暂的(服务器重启后,就找不到了,发生变化)
2 Volume
- 声明在 Pod 容器中可访问的文件目录
- 可以被挂载到 Pod 中一个或多个容器指定路径下
- 支持多种后端存储抽象【本地存储、分布式存储、云存储】
3 Controller
- 确保预期的 pod 副本数量【ReplicaSet】
- 无状态应用部署【Deployment】
无状态就是指,不需要依赖于网络或者 ip - 有状态应用部署【StatefulSet】
有状态需要特定的条件
确保所有的 node 运行同一个 pod 【DaemonSet】 - 一次性任务和定时任务【Job 和 CronJob】
4 Deployment
- 定义一组 Pod 副本数目,版本等
- 通过控制器【Controller】维持 Pod 数目【自动回复失败的 Pod】
- 通过控制器以指定的策略控制版本【滚动升级、回滚等】
5 Service
- 定义一组 pod 的访问规则
- Pod 的负载均衡,提供一个或多个 Pod 的稳定访问地址
- 支持多种方式【ClusterIP、NodePort、LoadBalancer】
6 Label
label:标签,用于对象资源查询,筛选
7 Namespace
- 命名空间,逻辑隔离
- 一个集群内部的逻辑隔离机制【鉴权、资源】
- 每个资源都属于一个 namespace
- 同一个 namespace 所有资源不能重复
- 不同 namespace 可以资源名重复
8 API
我们通过 Kubernetes 的 API 来操作整个集群
同时我们可以通过 kubectl 、ui、curl 最终发送 http + json/yaml 方式的请求给 API Server,然后控制整个 K8S 集群,K8S 中所有的资源对象都可以采用 yaml 或 json 格式的文件定义或描述
五、Kubernetes 工作原理