🎯学习小目标
1.了解容器的由来,以及容器的概念。 2.了解Docker是什么及其作用。 3.了解K8s是什么及其作用。
我们先来看看很久很久以前,服务器是怎么部署应用的!
纯物理服务器是指不依赖于虚拟化技术的物理服务器。在这种设置中,服务器的硬件资源(如CPU、内存、存储等)完全用于运行一个单一的操作系统和应用程序。
纯物理服务器的优点包括:
纯物理服务器包括以下在实际生活中的应用:
为了应对传统物理机的缺点,虚拟化技术就诞生了!
↑ 这张图就展示了你目前使用电脑的方式
尽管你在日常使用中不是直接使用虚拟机,但在一定程度上,你的操作系统利用了类似的虚拟化原则来管理资源,以便让你高效地运行多个应用程序。虚拟机技术主要应用在更复杂的场景,如服务器管理、软件开发和测试等。
虚拟化技术包括以下在实际生活中的应用:
相较于从前,部署成本降低,可充分利用服务器资源,利用虚拟机的模板功能(vmware模板克隆)便利了迁移与拓展。但是虚拟化也具有一定的局限性,每个虚拟机都是一个完整的操作系统,需要分配系统资源,虚拟机多到一定程度时,操作系统本身的资源也就消耗殆尽,必须扩容。
拓展:如果你想更加快捷稳定地使用Linux系统,也可以选择使用Xshell从本地计算机远程连接到远程的VPS进行操作。
[小情景]:超哥公司的产品运行在内部的虚拟化平台中,如VMware。但是随着不断增加的云端应用公司已经在云平台上运行了多台云主机,增加了对硬件资源的消耗,不断创建的虚拟机也为公司带来了难题。 此时,容器技术就排上用场了!
容器技术是一种高效的应用程序部署方法,允许开发人员在隔离环境中打包和运行应用程序,这一过程被称为容器化。容器技术的出现解决了传统部署方法中存在的一系列问题,使得软件开发和部署更加一致、高效。
常见的容器技术包括Docker、Kubernetes、LXC(Linux容器)等,它们提供了一套工具和平台,用于创建、管理和编排容器。容器技术已经在软件开发、云计算和大规模部署等领域广泛应用,为应用程序的开发、测试、交付和运维带来了许多便利和优势。
其中, Docker是一个容器化平台,它可以打包应用及其依赖项,使其成为容器。 K8s则用于管理这些容器的部署和编排。
Docker最初是DotCloud公司在法国期间发起的一个公司内部项目,后来以Apache2.0授权协议开源,代码在Github上维护。 Docker是基于Google公司推出的Golang语言开发而来,基于Linux内核的&groups、NameSpace,以及Union FS等技术对进程进行封装隔离,属于操作系统层面的虚拟化技术。(Docker的底层原理与作用) 由于隔离的进程独立于宿主机和其他隔离的进程,也被称之为容器。 最初的Docker是基于LXC的,后来去除LXC转而使用自行开发的Libcontainer。 Docker被定义为开源的容器引擎,可以方便的对容器进行管理。例如对镜像打包封装,引入Docker Registry对镜像统一管理。 利用Docker可以实现开发,测试,生产环境的部署一致性,极大的减少运维成本。
对于上述的小情景:
容器化(Containerization)是一种将应用程序及其所有依赖项(如库、配置文件和其他服务)打包在一个标准化的单元中(即“容器”)的技术。容器化的目标是实现软件的简单、一致和可移植的部署。
这样做的好处是什么? 虚拟出一台计算机的成本高还是只虚拟出一个隔离的程序运行环境的成本高? 答案很明显是前者。 一台物理机可能同时虚拟出10台虚拟机就已经开始感到乏力了,但同时虚拟出100个虚拟的执行环境却还是能够从容应对,这对于资源的充分利用可是有巨大的好处。 以下是容器化的一些核心概念和益处:
近几年大火的容器技术正是在这样的指导思想下诞生的!
程序开发情形
没有使用Docker时:
使用了Docker之后:
Kubernetes,从官方网站上可以看到,它是一个工业级的容器编排平台。Kubernetes 这个单词是希腊语,它的中文翻译是“舵手”或者“飞行员”。在一些常见的资料中也会看到“ks”这个词,也就是“K8s”,它是通过将 8 个字母“ubernete ”替换为“8”而导致的一个缩写。
Kubernetes 为什么要用“舵手”来命名呢?大家可以看一下这张图:
这是一艘载着一堆集装箱的轮船,轮船在大海上运着集装箱奔波,把集装箱送到它们该去的地方。我们之前其实介绍过一个概念叫做 container,container 这个英文单词也有另外的一个意思就是“集装箱”。Kubernetes 也就借着这个寓意,希望成为运送集装箱的一个轮船,来帮助我们管理这些集装箱,也就是管理这些容器。
这个就是为什么会选用 Kubernetes 这个词来代表这个项目的原因。更具体一点地来说:Kubernetes 是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。
整体结构图:
区别:Kubernetes(K8s)是一个容器编排系统,而Docker是一个用于构建、分发和运行容器的平台。 关系:它们可以协同工作,以实现更高效的应用程序部署和管理。在实际应用中,开发人员可以使用Docker来构建和打包应用程序容器,然后将其部署到Kubernetes集群中。Kubernetes和Docker之间的关系可以理解为一种互补关系,Docker位于Kubernetes的下层,为应用程序提供运行环境,而Kubernetes则位于上层,为容器化应用程序提供编排和管理功能。
Docker 的使用场景主要包括以下几个方面:
Kubernetes 的使用场景主要包括以下几个方面: