k8s 和 Docker 的区别是什么?

一则或许对你有用的小广告

欢迎加入小哈的星球 ,你将获得:专属的项目实战 / 1v1 提问 / Java 学习路线 / 学习打卡 / 每月赠书 / 社群讨论

  • 新项目:《从零手撸:仿小红书(微服务架构)》 正在持续爆肝中,基于 Spring Cloud Alibaba + Spring Boot 3.x + JDK 17...点击查看项目介绍
  • 《从零手撸:前后端分离博客项目(全栈开发)》 2 期已完结,演示链接: http://116.62.199.48/

截止目前, 星球 内专栏累计输出 80w+ 字,讲解图 3365+ 张,还在持续爆肝中.. 后续还会上新更多项目,目标是将 Java 领域典型的项目都整一波,如秒杀系统, 在线商城, IM 即时通讯,权限管理,Spring Cloud Alibaba 微服务等等,已有 2700+ 小伙伴加入学习 ,欢迎点击围观

简单来说, k8s 和 Docker 并不是一个维度的东西,不具有可比性。它们之间是相互依存的关系,Docker 是容器引擎,而 k8s 是用来编排 Docker 等容器的协调器。

前面小节 中我们已经知道了什么是 Docker,接下来我们说下 k8s 。

什么是 k8s ?

K8S 的功能K8S 的功能

k8s 是 Kubernetes 的缩写, 这个单词来自于希腊语,含义是 舵手领航员是一个可以基于容器的集群管理平台。

k8s 由 Google 开发,它的前身是 Google 自己倒腾了十多年的 Borg 系统,在 2014 年 6 月由 Google 公司正式公布出来并宣布开源。

Google 利用在容器管理多年的经验和专业知识推出了 k8s,主要用于自动化部署应用程序容器,可以支持众多容器化工具包括现在非常流行的 Docker。

目前 k8s 是容器编排市场的领导者,开源并公布了一系列标准化方法,主流的公有云平台都宣布支持。

K8S 解决了哪些痛点?

随着公司大小业务使用 Docker 越来越多,随之而来,也出现了一系列问题:

  • 1、如何协调、调度和管理这些容器?
  • 2、如何在升级应用程序时 不中断服务
  • 3、如何 监视 应用程序的运行状况?
  • 4、如何批量重新启动容器里的程序?
  • 5、负载均衡
  • 6、鉴权安全性问题
  • 7、服务之间通信问题
  • 8、多平台部署
  • ...

于是乎,k8s 出现了,它能够很好的解决这些问题。

容器编排除了 k8s 外,还有 Mesos、Docker Swarm, 只不过目前业界最流行的是 k8s 。

k8s 架构与组件

整体架构

下图清晰表明了 Kubernetes 的架构设计以及组件之间的通信协议。

Kuberentes 架构Kuberentes 架构

下面是更抽象的一个视图:

kubernetes 整体架构示意图kubernetes 整体架构示意图

Master 架构

Kubernetes master 架构示意图Kubernetes master 架构示意图

Node 架构

kubernetes node 架构示意图kubernetes node 架构示意图

分层架构

Kubernetes 设计理念和功能其实就是一个类似 Linux 的分层架构,如下图所示。

Kubernetes 分层架构示意图Kubernetes 分层架构示意图

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

k8s 与 Docker Swarm 比较

k8s 与 Docker Swarm 比较k8s 与 Docker Swarm 比较

Docker Swarm 与 k8s 都是容器编排技术。Docker Swarm 是 Docker 官方提供的针对集群化部署管理的解决方案,优点很明显,可以更紧密集成到 Docker 生态系统中。

虽说 Swarm 是 Docker 亲儿子,但依旧没有 k8s 流行,不流行很大程度是因为商业、生态的原因,不多解释。

生产实践中,关于 k8s 的相关疑问

  • 1、使用了 Docker, 一定要上 k8s 吗?

非必须,得结合实际业务综合考量, 如果是一家小型公司,本身业务并不复杂,没有那么大的用户量,是可以直接仅使用 Docker 的。相反,如果是类似阿里这种用户量大,业务复杂,需要服务器集群,那么上 k8s 就很有必要了。

  • 2、没有用到 Docker, 可以使用 k8s 吗?

可以,要知道 k8s 只是一个容器编排工具,需要和容器搭配使用。而目前最流行的容器技术就是 Docker, 所以通常将它们放在一起来说,但是也可以使用其他的容器,如 RunC、Containerted 等。

  • 3、Docker Swarm 和 k8s 选哪个?

选 k8s 。2019 年底 Docker Enterprise 已经出售给 Mirantis,Mirantis 声明要逐步淘汰 Docker Swarm,后续会将 k8s 作为默认编排工具。