Docker 与 Kubernetes:开发者必知的4大差异!

Docker 与 Kubernetes:开发者必知的4大差异!-mikechen

k8s和docker是云原生的核心,也是云技术的重要组成,下面重点谈谈两者的4大核心区别@mikechen

Docker

Docker 与 Kubernetes:开发者必知的4大差异!-mikechen

Docker 是一种开源的容器化平台,主要简化应用程序的构建、部署、和管理。

Docker最NB的地方,就在于:Docker 通过将应用程序、及其所有依赖项,打包在一个容器中。

类似集装箱:

Docker 与 Kubernetes:开发者必知的4大差异!-mikechen

这就像把一个完整的货物,连同它的包装箱一起打包,形成一个独立的运输单元。

集装箱内的货物不会影响其他集装箱,Docker容器也是如此,每个容器都有自己独立的运行环境,互不干扰。

Docker,确保了从开发到测试-再到生产环境的一致性,这解决了“在我的机器上可以正常运行”的常见问题,减少了因环境差异导致的错误。

并且,Docker具有快速部署、环境隔离、资源利用率高、可移植性强…等优点,在云计算。。。等领域得到了广泛应用。

 

K8s

Kubernetes(K8s),是”Google”开发的容器编排工具。

K8s,提供了 容器编排的自动化、扩展性…等等,使得大规模分布式系统的管理变得更高效、更稳定。

Docker 与 Kubernetes:开发者必知的4大差异!-mikechen

K8s 能根据集群资源、节点状态、容器需求…等,自动决定将容器部署到哪台机器上,优化资源的利用率。

K8s 支持应用的自动化部署、更新和回滚,可以在不影响服务可用性的情况下进行版本更新,减少人工干预。

K8s可以轻松管理成千上万个容器,可以应用大规模的微服务架构…等等场景。

 

Docker VS K8S

Docker 与 Kubernetes:开发者必知的4大差异!-mikechen

1. 定位不同

Docker,就像是一个集装箱,负责把应用程序和它的依赖打包成一个独立的单元(镜像),方便运输,专注于单个容器的创建和管理。

Kubernetes,就像是一个港口,负责管理大量的集装箱(容器),并协调它们的调度、装卸和运输,关注的是多个容器组成的集群的整体管理。

2. 层次不同

Docker关注的是单个容器的层面,提供了一个轻量级的、可移植的容器化平台。

Kubernetes,站在更高的抽象层次,将多个容器作为一个整体进行管理。

3. 功能不同

Docker,更关注容器的生命周期管理,比如:如何创建、启动、停止和删除容器。

Kubernetes,更关注容器集群的整体管理,包括:服务的发现、负载均衡、自动伸缩、配置管理…等。

4. 使用场景不同

Docker,适用于小型项目、或单个应用,或者作为Kubernetes的基础设施。

Kubernetes,适用于大规模容器化应用、微服务架构,以及需要高可用性和可扩展性的场景。

mikechen睿哥

mikechen睿哥,十余年BAT架构经验,资深技术专家,就职于阿里、淘宝、百度等一线互联网大厂。

关注「mikechen」公众号,获取更多技术干货!

后台回复面试即可获取《史上最全阿里Java面试题总结》,后台回复架构,即可获取《阿里架构师进阶专题全部合集

评论交流
    说说你的看法