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 小时前
01_虚拟机中间件部署_root 用户安装 docker 容器,配置非root用户权限
docker·中间件·容器
JH_Kong10 小时前
解决 WSL 中 Docker 权限问题:从踩坑到完整修复
docker·容器
陈桴浮海11 小时前
Kustomize实战:从0到1实现K8s多环境配置管理与资源部署
云原生·容器·kubernetes
张小凡vip12 小时前
Kubernetes--k8s中部署redis数据库服务
redis·kubernetes
Hello.Reader13 小时前
Flink Kubernetes HA(高可用)实战原理、前置条件、配置项与数据保留机制
贪心算法·flink·kubernetes
ShiLiu_mtx14 小时前
k8s - 7
云原生·容器·kubernetes
MonkeyKing_sunyuhua17 小时前
docker compose up -d --build 完全使用新代码打包的方法
docker·容器·eureka
醇氧18 小时前
【docker】mysql 8 的健康检查(Health Check)
mysql·docker·容器
匀泪21 小时前
云原生(LVS NAT模式集群实验)
服务器·云原生·lvs
70asunflower21 小时前
用Docker创建不同的容器类型
运维·docker·容器