Kubernetes 功能概述和架构 2022-5-4

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 工作原理

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值