K8S是用来解决什么问题的?

K8S是什么?

K8S是单词Kubernetes的缩写,是用于自动部署、扩缩和管理容器化应用程序的开源系统,K8S源自Google 15年生产环境的运维经验,同时凝聚了社区的最佳创意和实践。

K8S是用来解决什么问题的?

K8S在基于容器部署的方式上,提供了一个弹性分布式的框架,支持服务发现与负载均衡、存储、自动部署回滚、自动计算与调度、自动扩缩容等等一系列操作,目的是方便开发者不再需要关注服务运行细节,K8S能够自动进行容器与Pod调度、扩缩容、自动重建等等操作,保证服务尽可能健康的运行。

这样可能不够直观,问大家几个问题就知道K8S是用来干什么的了?

  • 某个容器发生故障,这个时候我们是不是该启动另一个容器?
  • 某台机器负载过高,那么我们之后的容器是不是不能部署在这台机器上?
  • 某个服务请求量突增,我们是不是应该多部署几个运行该服务的容器?
  • 如果某些容器之间需要互相配合怎么办?比如容器A需要容器B的资源,所以容器A一定要在容器B之后运行。
  • 运行多个容器时,我怎么做到它们的运行结果是原子性的?即要么全部成功,或者全部失败。亦或者如果某一个容器失败,我能够不断重启这个容器以达到我的预期状态。

以上问题,都可以交给K8S来解决,它提供了一系列的功能来帮助我们轻松管理和编排容器 ,以达到我们的预期状态,简单来说,K8S解放了开发者的双手,能够最大程度的让部署的服务健康运行,同时能够接入很多第三方工具(如服务监控、数据采集等等),满足开发者的定制化需求。

K8S的工作原理

一个kubernetes集群主要是由控制节点master工作节点node构成,每个节点上都会安装不同的组件。

master:集群的控制平面,负责集群的决策(管理)

Master节点上会安装四个重要组件,分别如下:

  • ApiServer:资源操作的唯一入口,接收用户输入的命令,提供认证、授权、API注册和发现等机制
  • Scheduler:负责集群资源调度,按照预定的调度策略将Pod调度到相应的node节点上
  • ControllerManager:负责维护集群的状态,比如程序部署安排、故障检测、自动扩展、滚动更新等
  • Etcd:负责存储集群中各种资源对象的信息,相当于K8S的数据库

Node:集群的数据平面,负责为容器提供运行环境(干活)

Node节点上会安装三个重要组件,分别如下:

  • Kubelet:负责维护容器的生命周期,即通过控制docker,来创建、更新、销毁容器
  • KubeProxy:负责提供集群内部的服务发现和负载均衡
  • Docker:负责节点上容器的各种操作

Pod

  • Pod是最小调度单元
  • Pod里面会包含一个或多个容器(Container)
  • Pod内的容器共享存储及网络,可通过localhost通信
相关推荐
姚不倒9 小时前
Go语言进阶:接口、错误处理与并发编程(goroutine/channel/context)
云原生·golang
仙柒41513 小时前
Docker存储原理
运维·docker·容器
快乐的哈士奇15 小时前
LangFuse 自托管实战:选型理由、Docker 部署与常用配置全解析
运维·人工智能·docker·容器
weixin_4492900117 小时前
Docker + MySQL 在 Windows 11 上的本地安装部署文档
mysql·docker·容器
Ysn071917 小时前
中文乱码:在 Docker 容器中设置中文语言环境
运维·python·docker·容器
米高梅狮子17 小时前
01.CentOS-Stream-8-packstack安装OpenStack
linux·云原生·容器·kubernetes·centos·自动化·openstack
亚空间仓鼠19 小时前
Docker容器化高可用架构部署方案(十三)
docker·容器·架构
米高梅狮子20 小时前
01.mysql的备份与恢复
运维·数据库·mysql·docker·容器·kubernetes·github
云游牧者21 小时前
K8S存储体系全解-从PV-PVC-SC到StatefulSet持久化实战
云原生·容器·kubernetes·pvc·pv·sc·进阶存储卷
古城小栈21 小时前
K8s 认证、授权 系统
云原生·容器·kubernetes