入门级容器技术解析:Docker和K8s的区别与关系

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 本文介绍了容器技术的发展历程及其重要组成部分Docker和Kubernetes。从传统物理机到虚拟机,再到容器化,每一步都旨在更高效地利用服务器资源并简化应用部署。容器技术通过隔离环境、减少依赖冲突和提高可移植性,解决了传统部署方式中的诸多问题。Docker作为容器化平台,专注于创建和管理容器;而Kubernetes则是一个强大的容器编排系统,用于自动化部署、扩展和管理容器化应用。两者相辅相成,共同推动了现代云原生应用的快速发展。

目录

🎯学习小目标:

关于容器

传统物理机🖥️

虚拟机💻

为什么使用容器技术呢?🤔

容器技术🥃

Docker—容器化平台

K8s(Kubernetes)—容器编排系统

Docker和K8s有什么关系和区别?🤔

Docker 的使用场景

Kubernetes 的使用场景


🎯学习小目标

1.了解容器的由来,以及容器的概念。

2.了解Docker是什么及其作用。

3.了解K8s是什么及其作用。

关于容器

我们先来看看很久很久以前,服务器是怎么部署应用的!

  • 传统物理机🖥️

image.gif

纯物理服务器是指不依赖于虚拟化技术的物理服务器。在这种设置中,服务器的硬件资源(如CPU、内存、存储等)完全用于运行一个单一的操作系统和应用程序。

纯物理服务器的优点包括:

  1. 性能:由于不需要虚拟化开销,纯物理服务器通常提供更高的性能,其是在要求高性能计算或IO密集型应用中。
  2. 管理:管理和配置相对简单,因为只有一个操作系统和应用程序。
  3. 资源利用率:相较于虚拟化环境,资源利用率可能较低,因为无法根据不同的负载动态分配资源。
  4. 稳定性:在某些情况下,物理服务器可以提供更高的稳定性和可靠性,特别是当应用程序对硬件有特定要求时。

纯物理服务器包括以下在实际生活中的应用:

  1. 数据中心和云计算:许多公司使用纯物理服务器构建数据中心,提供云计算服务。这些服务器存储和处理大量数据,保证了高性能和可靠性。
  2. 企业内部应用:许多企业依赖于纯物理服务器来运行关键的内部应用,如财务系统、客户关系管理(CRM)系统和人力资源管理系统(HRMS),以保证数据安全和稳定性。
  3. 高性能计算:在科学研究、工程设计和天气模拟等领域,纯物理服务器常用于高性能计算(HPC),进行复杂的模拟和数据分析。

为了应对传统物理机的缺点,虚拟化技术就诞生了!

  • 虚拟机💻

image.gif

↑ 这张图就展示了你目前使用电脑的方式

尽管你在日常使用中不是直接使用虚拟机,但在一定程度上,你的操作系统利用了类似的虚拟化原则来管理资源,以便让你高效地运行多个应用程序。虚拟机技术主要应用在更复杂的场景,如服务器管理、软件开发和测试等。

虚拟化技术包括以下在实际生活中的应用:

  1. 游戏和娱乐:许多在线游戏平台利用虚拟化技术来分配服务器资源,确保游戏流畅运行。
  2. 移动设备:智能手机和平板电脑中的多任务处理功能也依赖于虚拟化技术。
  3. 个人电脑:通过虚拟机(VM)技术,用户可以在同一台物理电脑上运行多个操作系统。

相较于从前,部署成本降低,可充分利用服务器资源,利用虚拟机的模板功能(vmware模板克隆)便利了迁移与拓展。但是虚拟化也具有一定的局限性,每个虚拟机都是一个完整的操作系统,需要分配系统资源,虚拟机多到一定程度时,操作系统本身的资源也就消耗殆尽,必须扩容。

拓展:如果你想更加快捷稳定地使用Linux系统,也可以选择使用Xshell从本地计算机远程连接到远程的VPS进行操作。

为什么使用容器技术呢?🤔

[小情景]:超哥公司的产品运行在内部的虚拟化平台中,如VMware。但是随着不断增加的云端应用公司已经在云平台上运行了多台云主机,增加了对硬件资源的消耗,不断创建的虚拟机也为公司带来了难题。

 

此时,容器技术就排上用场了!

容器技术🥃

容器技术是一种高效的应用程序部署方法,允许开发人员在隔离环境中打包和运行应用程序,这一过程被称为容器化。容器技术的出现解决了传统部署方法中存在的一系列问题,使得软件开发和部署更加一致、高效。

image.gif

常见的容器技术包括Docker、Kubernetes、LXC(Linux容器)等,它们提供了一套工具和平台,用于创建、管理和编排容器。容器技术已经在软件开发、云计算和大规模部署等领域广泛应用,为应用程序的开发、测试、交付和运维带来了许多便利和优势。

其中, Docker是一个容器化平台,它可以打包应用及其依赖项,使其成为容器。 K8s则用于管理这些容器的部署和编排。

Docker—容器化平台     image.gif

Docker最初是DotCloud公司在法国期间发起的一个公司内部项目,后来以Apache2.0授权协议开源,代码在Github上维护。

Docker是基于Google公司推出的Golang语言开发而来,基于Linux内核的&groups、NameSpace,以及Union FS等技术对进程进行封装隔离,属于操作系统层面的虚拟化技术。(Docker的底层原理与作用)

由于隔离的进程独立于宿主机和其他隔离的进程,也被称之为容器

最初的Docker是基于LXC的,后来去除LXC转而使用自行开发的Libcontainer。

Docker被定义为开源的容器引擎,可以方便的对容器进行管理。例如对镜像打包封装,引入Docker Registry对镜像统一管理。

利用Docker可以实现开发,测试,生产环境的部署一致性,极大的减少运维成本。

对于上述的小情景:

image.gif

容器化(Containerization)是一种将应用程序及其所有依赖项(如库、配置文件和其他服务)打包在一个标准化的单元中(即“容器”)的技术。容器化的目标是实现软件的简单、一致和可移植的部署。

这样做的好处是什么?

虚拟出一台计算机的成本高还是只虚拟出一个隔离的程序运行环境的成本高? 答案很明显是前者。 一台物理机可能同时虚拟出10台虚拟机就已经开始感到乏力了,但同时虚拟出100个虚拟的执行环境却还是能够从容应对,这对于资源的充分利用可是有巨大的好处。

以下是容器化的一些核心概念和益处:

  1. 轻量级和高效:容器共享宿主操作系统的内核,相比传统的虚拟机更轻量,占用资源更少,启动速度更快。
  2. 一致性:容器在开发、测试和生产环境中具有相同的运行时,这减少了“在我电脑上可以运行”的问题。开发人员可以在本地环境中构建容器,并确保它在其他环境中也能正常工作。
  3. 依赖项管理:容器将应用程序及其所有所需的依赖项捆绑在一起,这样可以避免版本冲突和依赖缺失的问题。
  4. 可移植性:容器可以在不同的计算环境中运行,例如个人电脑、数据中心或云平台,使得应用程序可以更加灵活地部署。
  5. 快速部署与扩展:由于容器的轻量特性,应用程序可以快速启动和停止。这使得动态扩展和缩减资源变得更加容易。
  6. 隔离性:每个容器在独立的环境中运行,避免了不同应用程序间的相互影响。

近几年大火的容器技术正是在这样的指导思想下诞生的!

程序开发情形

没有使用Docker时:

image.gif

使用了Docker之后:

image.gif 编辑

K8s(Kubernetes)—容器编排系统 image.gif

Kubernetes,从官方网站上可以看到,它是一个工业级的容器编排平台。Kubernetes 这个单词是希腊语,它的中文翻译是“舵手”或者“飞行员”。在一些常见的资料中也会看到“ks”这个词,也就是“K8s”,它是通过将 8 个字母“ubernete ”替换为“8”而导致的一个缩写。

Kubernetes 为什么要用“舵手”来命名呢?大家可以看一下这张图:

image.gif 编辑

这是一艘载着一堆集装箱的轮船,轮船在大海上运着集装箱奔波,把集装箱送到它们该去的地方。我们之前其实介绍过一个概念叫做 container,container 这个英文单词也有另外的一个意思就是“集装箱”。Kubernetes 也就借着这个寓意,希望成为运送集装箱的一个轮船,来帮助我们管理这些集装箱,也就是管理这些容器。

这个就是为什么会选用 Kubernetes 这个词来代表这个项目的原因。更具体一点地来说:Kubernetes 是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。

整体结构图:

image.gif

Docker和K8s有什么关系和区别?🤔

区别:Kubernetes(K8s)是一个容器编排系统,而Docker是一个用于构建、分发和运行容器的平台。

关系:它们可以协同工作,以实现更高效的应用程序部署和管理。在实际应用中,开发人员可以使用Docker来构建和打包应用程序容器,然后将其部署到Kubernetes集群中。Kubernetes和Docker之间的关系可以理解为一种互补关系,Docker位于Kubernetes的下层,为应用程序提供运行环境,而Kubernetes则位于上层,为容器化应用程序提供编排和管理功能。

Docker 的使用场景

Docker 的使用场景主要包括以下几个方面:

  1. 应用程序的打包和交付:Docker 可以将应用程序和所有依赖项打包到一个容器中,从而实现应用程序的打包和交付。
  2. 应用程序的部署和维护:Docker 可以在不同的环境中提供一致的应用程序运行环境,从而简化了应用程序的部署和维护。
  3. 应用程序的可移植性:Docker 可以在不同的平台上运行,提供了应用程序的可移植性。
  4. 应用程序的隔离和安全性:Docker 可以提供应用程序的隔离和安全性,防止应用程序之间相互干扰。

Kubernetes 的使用场景

Kubernetes 的使用场景主要包括以下几个方面:

  1. 容器化应用程序的部署和管理:Kubernetes 可以用于管理和部署容器化应用程序,提供高可用性、可伸缩性和自我修复能力。
  2. 容器化应用程序的负载均衡:Kubernetes 可以通过集群自动化来实现容器化应用程序的负载均衡。
  3. 容器化应用程序的高可用性:Kubernetes 可以通过集群自动化来实现容器化应用程序的高可用性。
  4. 混合云和多云部署:Kubernetes 支持多云、混合云和混合部署等场景,因此可以应用于云原生应用程序的开发和部署。

>>看个视频,巩固一下😎

image.gif 编辑

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
1月前
|
缓存 Kubernetes Docker
GitLab Runner 全面解析:Kubernetes 环境下的应用
GitLab Runner 是 GitLab CI/CD 的核心组件,负责执行由 `.gitlab-ci.yml` 定义的任务。它支持多种执行方式(如 Shell、Docker、Kubernetes),可在不同环境中运行作业。本文详细介绍了 GitLab Runner 的基本概念、功能特点及使用方法,重点探讨了流水线缓存(以 Python 项目为例)和构建镜像的应用,特别是在 Kubernetes 环境中的配置与优化。通过合理配置缓存和镜像构建,能够显著提升 CI/CD 流水线的效率和可靠性,助力开发团队实现持续集成与交付的目标。
|
1月前
|
数据库 Docker 容器
docker容器为啥会开机自启动
通过配置适当的重启策略,Docker容器可以在主机系统重启后自动启动。这对于保持关键服务的高可用性和自动恢复能力非常有用。选择适合的重启策略(如 `always`或 `unless-stopped`),可以确保应用程序在各种情况下保持运行。理解并配置这些策略是确保Docker容器化应用可靠性的关键。
226 93
|
7天前
|
网络协议 API Docker
Docker+consul容器服务的更新与发现
通过本文的介绍,我们详细探讨了如何结合Docker和Consul来实现容器服务的更新与发现。通过Consul的服务注册和发现功能,可以高效地管理和监控容器化服务,确保系统的高可用性和可扩展性。希望本文能帮助您在实际项目中更好地应用Docker和Consul,提高系统的可靠性和管理效率。
42 23
|
7天前
|
Ubuntu API 网络虚拟化
ubuntu22 编译安装docker,和docker容器方式安装 deepseek
本脚本适用于Ubuntu 22.04,主要功能包括编译安装Docker和安装DeepSeek模型。首先通过Apt源配置安装Docker,确保网络稳定(建议使用VPN)。接着下载并配置Docker二进制文件,创建Docker用户组并设置守护进程。随后拉取Debian 12镜像,安装系统必备工具,配置Ollama模型管理器,并最终部署和运行DeepSeek模型,提供API接口进行交互测试。
143 15
|
1月前
|
存储 运维 Kubernetes
正式开源,Doris Operator 支持高效 Kubernetes 容器化部署方案
飞轮科技推出了 Doris 的 Kubernetes Operator 开源项目(简称:Doris Operator),并捐赠给 Apache 基金会。该工具集成了原生 Kubernetes 资源的复杂管理能力,并融合了 Doris 组件间的分布式协同、用户集群形态的按需定制等经验,为用户提供了一个更简洁、高效、易用的容器化部署方案。
正式开源,Doris Operator 支持高效 Kubernetes 容器化部署方案
|
30天前
|
存储 监控 对象存储
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
针对本地存储和 PVC 这两种容器存储使用方式,我们对 ACK 的容器存储监控功能进行了全新升级。此次更新完善了对集群中不同存储类型的监控能力,不仅对之前已有的监控大盘进行了优化,还针对不同的云存储类型,上线了全新的监控大盘,确保用户能够更好地理解和管理容器业务应用的存储资源。
172 66
|
1月前
|
Ubuntu NoSQL Linux
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
165 6
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
|
1月前
|
存储 监控 对象存储
ACK容器监控存储全面更新:让您的应用运行更稳定、更透明
介绍升级之后的ACK容器监控体系,包括各大盘界面展示和概要介绍。
|
1月前
|
数据库 Docker 容器
docker容器为啥会开机自启动
通过配置适当的重启策略,Docker容器可以在主机系统重启后自动启动。这对于保持关键服务的高可用性和自动恢复能力非常有用。选择适合的重启策略(如 `always`或 `unless-stopped`),可以确保应用程序在各种情况下保持运行。理解并配置这些策略是确保Docker容器化应用可靠性的关键。
63 17
|
1月前
|
运维 Java 虚拟化
《docker基础篇:1.Docker简介》,包括Docker是什么、容器与虚拟机比较、能干嘛、去哪下
《docker基础篇:1.Docker简介》,包括Docker是什么、容器与虚拟机比较、能干嘛、去哪下
122 12