Docker概念详解

文章目录

    • 一、Docker:容器化应用的基石
      • 1.1 环境
      • 1.2 Docker 是什么
      • 1.3 Docker镜像
        • 1.3.1 基础镜像(Base Image)
        • 1.3.2 Dockerfile
        • 1.3.3 容器镜像(Container Image)
      • 1.4 Registry
      • 1.5 容器
      • 1.6 Docker VS 虚拟机
    • 二、Docker 的架构原理
      • 2.1 C/S软件架构
      • 2.2 docker 命令
        • 2.2.1 docker build
        • 2.2.2 docker pull/push
        • 2.2.3 docker run
    • 三、Docker部署工具
      • 3.1 Docker Compose :多容器部署
      • 3.2 Docker Swarm :集群部署
      • 3.3 Kubernetes :开源的容器编排平台
    • 四、总结

  • 全文参考《Docker 是什么?》
  • golang全栈指南:
    图片

一、Docker:容器化应用的基石

1.1 环境

  我们经常能听到程序员说"这个程序在我环境里明明是好的啊,怎么到你这就不行了呢"?注意这里的关键词,程序和环境。程序是跑在操作系统上的,而操作系统上又装了各种不同版本的依赖库和配置,这些被程序所依赖的信息,我们统称为"环境"。

在这里插入图片描述

  作为一个程序员,如果你想安装一个 vim 文本编辑器,在不同环境里你得执行不同的命令。在 ubuntu,你需要执行 apt-get install vim,在 centos 里,你需要执行 yum install vim。装个小软件尚且如此,要是你想将自己写的代码部署到各个不同操作系统的服务器上,那依赖的软件和配置就更多了,需要针对每个环境单独写一套部署脚本,太麻烦了。

1.2 Docker 是什么

  Docker 是一种开源的容器化平台,它允许开发者将应用程序及其依赖的环境打包到一个独立的容器中,作为代码和操作系统之间的中间层。

在这里插入图片描述

Docker 有三大核心组件,分别是镜像(Image)、容器(Container)和仓库(Repository):

  • Docker 镜像:是一个只读的模板,用于创建 Docker 容器。它包含了容器运行所需的代码、运行时环境、库、环境变量和配置文件等。
  • 容器:镜像的可写运行实例,它包含了运行应用程序所需要的一切,包括代码、运行时、系统工具、系统库等。容器通过镜像创建,可以被启动、停止、删除等。
  • Docker 仓库:存储和分发镜像的场所,分为公共仓库(Docker Hub)和私有仓库。

1.3 Docker镜像

1.3.1 基础镜像(Base Image)

  容器是一个轻量级、可移植的执行环境,它与宿主机共享内核,但拥有独立的用户空间。通过 Docker,开发者可以在不同的操作系统和环境中一致地部署和运行应用程序,从而解决了“在我的机器上可以运行”的问题。

  既然上面提到环境不同,会导致程序运行结果不同,那么我们首先要做的最重要的事情,就是统一环境。而环境中,最最重要的就是操作系统。比如 centos 还是 ubuntu,我们得选一个,让所有程序都跑在同一个操作系统上。操作系统分为用户空间和内核空间,应用程序运行在用户空间。因此,我们可以阉割操作系统,只需要利用操作系统的用户空间部分,就能构建出应用所需的环境。

  其次就是统一程序语言依赖,比如要跑 python 应用,你得装个 python 解释器,要跑个 java 应用,得装个 JVM,要跑 go 应用,那就。。什么都不需要装。选中一个基础操作系统和语言后,我们将它们对应的文件系统,依赖库,配置等放一起打包成一个类似压缩包的文件,这就是所谓的基础镜像(Base Image)。

在这里插入图片描述

1.3.2 Dockerfile

  Dockerfile 是一个文本文件,它包含了一系列指令,定义了如何构建容器镜像。

  有了基础镜像之后还不够,我们经常还需要安装一些依赖,比如yum install gcc,甚至还要创建一些文件夹。最后才是运行我们的目标应用程序

  Linux 中,所有工作都可以通过命令行完成,所以我们可以将要做的事情以命令行的形式一行行列出来。就像一份 todo list。意思是要求在基础镜像的基础上按着 todo list 挨个执行命令。这份 todo list 长下面这样。

# 指定基础镜像
FROM python:3.9# 设置工作目录
WORKDIR /app# 复制依赖文件到容器中
COPY requirements.txt .RUN yum install gcc
# 安装依赖
RUN pip install --no-cache-dir -r requirements.txt# 将当前目录下的所有文件复制到容器的 /app 目录下
COPY . /app# 设置容器启动时执行的命令
CMD ["python", "app.py"]

具体含义是,基于一个装了 python3.9 解释器的操作系统(基础镜像),再执行 pip install 等命令安装其他依赖,从而构建出一个适合程序运行的环境,最后用 python app.py 运行我们的目标应用程序。

  像这样一份列清楚了,从操作系统到应用服务启动,需要做哪些事情的清单文件(todo list),就是所谓的 Dockerfile。通过 Dockerfile,开发者可以清晰地描述应用程序的构建过程,确保每次构建的镜像都是一致的。

1.3.3 容器镜像(Container Image)

  Dockerfile 只是描述了要做哪些事情,并没有真正开始做。当我们用命令行执行 docker build 的时候,Docker 软件就会按着 Dockerfile 的说明,一行行构建环境+应用程序。最终将这个环境+程序,打包成一个类似"压缩包"的东西,我们叫它容器镜像(container image)。

在这里插入图片描述

  只要将容器镜像传到任意一台服务器上,对这个"压缩包"执行"解压缩",我们就能同时运行环境和程序。太完美了!但是现在还有个问题,怎么将容器镜像传到那么多服务器上呢?

1.4 Registry

  服务器那么多,挨个将容器镜像传过去也不是不行,就是将压力全给到发送方的网络带宽了。有没有更好的解决方案?有。可以参考 github 代码仓库 的做法,我们通常会使用 git push 将代码传到 github,有需要的人自己通过 git pull 的方式将代码从 github 拉到自己的机器上。

在这里插入图片描述

  那 Docker 也一样,弄一个镜像仓库,通过 docker push 将镜像推到仓库,有需要的时候再通过 docker pull 将镜像拉到机器上。这个负责管理镜像仓库推拉能力的服务,就叫 Docker Registry

  基于 Docker Registry 的能力,我们可以搭建各种官方或私人镜像仓库,比如官方的叫 DockerHub,非官方的有清华大学的 Tuna 等等,一般公司内部也会有自己的镜像仓库。

在这里插入图片描述

1.5 容器

  现在,我们解决了服务器间传输容器镜像的问题。我们可以跑到目的服务器上,执行 docker pull 拿到容器镜像。然后执行 docker run 命令,将这个类似"压缩包"的容器镜像给"解压缩",获得一个独立的环境和应用程序并运行起来。这样一个独立的环境和应用程序,就是所谓的容器(container)。我们可以在一个操作系统上同时跑多个容器。且这些容器之间都是互相独立,互相隔离的。

在这里插入图片描述

  • 隔离性 :容器之间相互隔离,每个容器都有自己独立的文件系统、进程空间和网络空间,不会互相干扰。这保证了应用程序在容器中运行的稳定性和安全性。
  • 轻量化 :容器共享宿主机的内核,不需要像虚拟机那样虚拟出一整个硬件环境,因此容器的启动速度非常快,通常只需要几秒钟,并且占用的资源也相对较少。
  • 可移植性 :由于容器是基于镜像运行的,而镜像在不同的环境(如开发、测试、生产环境)中都可以保持一致,因此容器可以在任何安装了 Docker 的机器上运行,具有很强的可移植性。

1.6 Docker VS 虚拟机

  容器看起来很像我们用 vmware 或 kvm 整出来的传统虚拟机,但不同的是,传统虚拟机自带一个完整操作系统,而容器本身不带完整操作系统。

  容器的基础镜像实际上只包含了操作系统的核心依赖库和配置文件等必要组件,它利用一个叫 Namespace 的能力让它看起来就像是一个独立操作系统一样,再利用一个叫 Cgroup 的能力限制它能使用的计算资源。所以说,容器本质上只是个自带独立运行环境的特殊进程,底层用的其实是宿主机的操作系统内核

在这里插入图片描述

二、Docker 的架构原理

2.1 C/S软件架构

  现在,我们回到日常使用场景中,聊聊 Docker 的架构原理。它是经典的 Client/Server 架构。Client 对应 Docker-cliServer 对应 Docker daemon。我们在命令行里敲 Docker 命令,使用的就是 Docker-cli.

在这里插入图片描述

Docker是C/S软件架构

  Docker-cli 会解析我们输入的 cmd 命令,然后调用 Docker daemon 守护进程提供的 RESTful API,守护进程收到命令后,会根据指令创建和管理各个容器。再具体点,Docker Daemon 内部分为 Docker Server,Engine 两层。

  • Docker Server :本质上就是个 HTTP 服务,负责对外提供操作容器和镜像的 api 接口,接收到 API 请求后,会分发任务给 Engine
  • Engine 层:负责创建 Job,由 Job 实际执行各种工作。不同的 Docker 命令会执行不同类型的 Job 任务。

在这里插入图片描述

Docker daemon内部架构

2.2 docker 命令

2.2.1 docker build

  如果你执行的是 docker build 命令,Job 则会根据 Dockerfile 指令,像包洋葱皮似的一层层构建容器镜像文件。

在这里插入图片描述

docker build执行逻辑

2.2.2 docker pull/push

如果你执行的是 docker pullpush 之类的镜像推拉操作,Job 则会跟外部的 Docker Registry 交互,将镜像上传或下载。

在这里插入图片描述

docker pull/push执行逻辑

2.2.3 docker run

  如果你执行的是 docker run 命令,Job 就会基于镜像文件调用 containerd 组件,驱使 runC 组件创建和运行容器。

在这里插入图片描述

docker run执行逻辑

  现在我们再回过头来看这句话,Docker 本质上就是一个将程序和环境打包并运行的工具软件。具体点来说就是,它通过 Dockerfile 描述环境和应用程序的依赖关系, docker build 构建镜像, docker pull/push 跟 Docker Registry 交互实现存储和分发镜像,docker run 命令基于镜像启动容器,基于容器技术运行程序和它对应的环境,从而解决环境依赖导致的各种问题。

在这里插入图片描述

Docker到底是什么

好了,到这里,我们就了解了 Docker 的架构和基本运行原理了。接下来,我们再来聊聊跟 Docker 相关的几个周边。

三、Docker部署工具

3.1 Docker Compose :多容器部署

  我们现在知道了 Docker 容器 本身只是一个特殊进程,但如果我想要部署多个容器,且对这些容器的顺序有一定要求呢?比如一个博客系统,当然是先启动数据库,再启动身份验证服务,最后才能启动博客 web 服务。

  按理说挨个执行 docker run 命令当然是没问题的,但有没有更优雅的解决方案?有。我们可以通过一个 YAML 文件写清楚要部署的容器有哪些部署顺序是怎么样的,以及这些容器占用的 cpu 和内存等信息。

version: "3.8"services:A:image: "some-image-for-a"deploy:resources:limits:cpus: "0.50" # 限制 CPU 使用率为 50%memory: 256M # 限制内存使用量为 256MBB:image: "some-image-for-b"depends_on:- AC:image: "some-image-for-c"depends_on:- B

  然后,通过一行Docker-compose up命令,开始解析 YAML 文件,将容器们一键按顺序部署,就完成一整套服务的部署。这其实就是 Docker Compose 干的事情。Docker Compose 使得多容器应用的部署变得简单高效,特别适合开发和测试环境。

在这里插入图片描述

Docker compose

3.2 Docker Swarm :集群部署

  • Docker :解决的是一个容器的部署。
  • Docker Compose :解决的是多个容器组成的一整套服务的部署。
  • Docker Swarm:解决的是这一整套服务在多台服务器上的集群部署问题。

  Docker Swarm 是 Docker 官方提供的容器编排工具,用于在多台主机上管理和部署容器集群。它允许开发者将多个 Docker 主机组成一个虚拟的 Docker 环境,从而实现容器的高可用性、弹性伸缩和负载均衡。

  在 Docker Swarm 中,容器可以自动在不同的主机之间迁移,当某个主机出现故障时,其他主机可以接管其上的容器,确保应用程序的持续运行。此外,Swarm 还支持服务的扩缩容,可以根据业务需求动态调整容器的数量。

在这里插入图片描述

Docker swarm

3.3 Kubernetes :开源的容器编排平台

  Kubernetes(通常简称为 k8s)是一个开源的容器编排平台,它与 Docker Swarm 的目标类似,都是用于管理和部署容器集群。

  1. Docker 是 Kubernetes 的运行时基础
    在 Kubernetes 中,容器是应用程序的基本运行单元,而 Docker 容器是 Kubernetes 支持的主要容器运行时之一(除了支持 Docker 的容器外,还支持别人家的容器)。Docker 提供了容器的隔离、打包和分发机制,而 Kubernetes 则在此基础上提供了更高级的编排功能,如服务发现、负载均衡、自动扩缩容等。

  2. Pod 与 Docker 容器
    Kubernetes 的核心概念是 Pod,Pod 是 Kubernetes 中最小的部署单元,它封装了一个或多个紧密相关的容器。在 Kubernetes 中,一个 Pod 中的容器共享相同的网络命名空间、存储卷等资源,它们可以像一个整体一样被调度和管理。从某种意义上说,Pod 可以被视为一个“超级容器”,它将多个 Docker 容器组(本质上就是一个服务进程)合在一起,形成一个逻辑单元。Docker 容器是 Pod 的组成部分,而 Pod 是 Kubernetes 编排的基本对象。
    在这里插入图片描述

    k8s会在多台 Node 服务器上调度 Pod,进行部署和扩缩容。每个 Pod 内部可以含有多个 container

  3. Kubernetes 的编排功能
    Kubernetes 提供了强大的容器编排功能,它通过一系列的控制器(如 Deployment、StatefulSet、DaemonSet 等)来管理 Pod 的生命周期。这些控制器可以根据预定义的策略自动创建、更新、删除 Pod,并确保应用程序的高可用性和一致性。此外,Kubernetes 还提供了服务发现和负载均衡机制,通过定义 Service 对象,可以将 Pod 暴露为一个网络服务,客户端可以通过 Service 的虚拟 IP 地址访问 Pod 提供的服务。Kubernetes 的自动扩缩容功能可以根据业务负载动态调整 Pod 的数量,从而实现资源的高效利用。

  4. 对比Docker Compose
    Docker Compose 基于多个 container 创建的一整套服务,其实就是 k8s 里的 pod。而 Docker Swarm 做的事情和 k8s 一样,本质上就是在调度 pod。k8s 的官方定义,叫容器编排引擎,将它理解为,以 API 程的方式管理安各个容器的引擎

  现在,我们再>回过头来看下 Docker 的图标,是一个个集装箱,放在一艘船上,这一个个集装箱指的就是互相隔离的容器,而 k8s 的图标,则是一个轮船上的方向盘,意思是 k8s 控制着轮船的航向,其实指的就是调度容器。这波联想就非常形象了,现在大家通了吗?

在这里插入图片描述

四、总结

  • Docker 本质上就是一个将程序和环境打包并运行的工具软件,而 Docker 容器本质上只是个自带独立运行环境的特殊进程,底层用的其实是宿主机的操作系统内核

  • Docker 软件 通过 Dockerfile 描述环境和应用程序的依赖关系, docker build 构建镜像, docker pull/pushDocker Registry 交互实现存储和分发镜像,docker run 命令基于镜像启动容器,基于容器技术运行程序和它对应的环境,从而解决环境依赖导致的各种问题。

  • Docker 解决的是一个容器的部署问题,Docker Compose 解决的是多个容器组成的一套服务的部署问题,Docker Swarm 解决的是多个容器组成的一套服务在多台服务器上的部署问题k8s 则是 Docker Swarm 的竞品,在更高维度上兼容了 Docker 容器,实现了容器编排调度。

  在现代的云原生架构中,Docker 和 Kubernetes 已成为不可或缺的技术,它们为开发和运维团队提供了强大的工具,使得应用程序的开发、部署和管理变得更加高效和可靠。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/902334.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux查看及修改用户过期时间

修改用户有效期 密码到期时间 sudo chage -E 2025-12-31 username sudo chage -M 180 username sudo chage -d $(date %F) username 查询用户密码到期时间 for user in $(cat /etc/passwd |cut -d: -f1); do echo $user; chage -l $user | grep "Password expires"; …

CGAL 计算直线之间的距离(3D)

文章目录 一、简介二、实现代码三、实现效果一、简介 这里的计算思路很简单: 1、首先将两个三维直线均平移至过原点处,这里两条直线可以构成一个平面normal。 2、如果两个直线平行,那么两条直线之间的距离就转换为直线上一点到另一直线的距离。 3、如果两个直线不平行,则可…

<项目代码>YOLO小船识别<目标检测>

项目代码下载链接 YOLOv8是一种单阶段(one-stage)检测算法,它将目标检测问题转化为一个回归问题,能够在一次前向传播过程中同时完成目标的分类和定位任务。相较于两阶段检测算法(如Faster R-CNN)&#xff0…

基于RK3588+FPGA+AI YOLO全国产化的无人船目标检测系统(二)平台设计

基于项目需求确定国产 AI 平台的总体架构设计,完成硬件单元的选择和搭建以及开发工具链的配置工作。 4.1 国产 AI 平台总体架构 本文设计了一套灵活高效的国产 AI 平台总体架构,设计方法是在嵌入式平 台上使用串行总线( Peripheral Co…

Typescript中的泛型约束extends keyof

概要 本文主要分享Typescript中泛型约束的使用方法。在开发过程中,通过使用该方法,可以在编译阶段,帮助我们查找到一些潜在的空值引用错误。 代码和实现 我们预先定义了IUser接口,接口包括了id,姓名,性别…

C++ 2025 展望:现代编程需求与新兴技术驱动下的变革

C 作为一门成熟的语言,在多个领域(嵌入式系统、高性能计算、图形渲染、游戏开发等)依旧占据重要地位。在 2024 年,C 开发继续在许多传统领域保持强劲的势头,同时也面临着新的挑战与发展方向。展望 2025 年,…

包管理工具有哪些?主流软件分享

常见的包管理工具主要有:npm、Yarn、pnpm、Composer、Maven、pip、Conda 等,其中 npm 是目前全球使用最广泛的JavaScript包管理工具,以丰富的生态、便捷的使用体验以及强大的社区支持闻名。npm具备依赖管理、版本控制、脚本执行等强大功能&am…

2025年世界职业院校技能大赛实施方案(意见稿)

为贯彻落实《教育强国建设规划纲要(2024—2035年)》,进一步提升世界职业院校技能大赛(以下简称“大赛”)内涵质量,发挥大赛引领作用,提升高技能人才培养质量,服务现代职业教育体系建…

Redis 慢查询分析与优化

Redis 慢查询分析与优化 参考书籍 : https://weread.qq.com/web/reader/d5432be0813ab98b6g0133f5kd8232f00235d82c8d161fb2 以下从配置参数、耗时细分、分析工具、优化策略四个维度深入解析 Redis 慢查询问题,结合实战调优建议,帮助开发者…

AI之pdf解析:Tesseract、PaddleOCR、RapidPaddle(可能为 RapidOCR)和 plumberpdf 的对比分析及使用建议

目录标题 Tesseract、PaddleOCR、RapidPaddle(可能为 RapidOCR)和 plumberpdf 的对比分析1. Tesseract类型: 开源 OCR 引擎特点:缺点:适用场景: 2. PaddleOCR (推荐)类型:特点:缺点:适用场景: 复杂版式文档、多语言混合文本、需要高精度识别的场景&#…

算法 | 成长优化算法(Growth Optimizer,GO)原理,公式,应用,算法改进研究综述,matlab代码

===================================================== github:https://github.com/MichaelBeechan CSDN:https://blog.csdn.net/u011344545 ===================================================== 成长优化算法 一、算法原理二、核心公式三、应用领域四、算法改进研究五…

网络原理(TCP协议—协议格式,性质(上),状态)

目录 1.TCP协议段格式。 2.TCP协议传输时候的性质。 2.1确认应答。 2.2超时重传。 2.3连接管理。 2.3.1 三次握手。 2.3.2四次挥手。 3.TCP常见的状态。 1.TCP协议段格式。 TCP协议段是由首部和数据两部分构成的。首部包含了TCP通信所需要的各种控制信息,而…

XAML 标记扩展

# XAML 标记扩展详解 标记扩展(Markup Extensions)是XAML中一种特殊的语法结构,允许在XAML属性中嵌入动态值或引用,而不是简单的静态值。它们使用花括号{}作为标识,是XAML强大功能的核心组成部分。 ## 基本语法结构 所有标记扩展都遵循以下…

DeepSeek+Cursor+Devbox+Sealos项目实战

黑马程序员DeepSeekCursorDevboxSealos带你零代码搞定实战项目开发部署视频教程,基于AI完成项目的设计、开发、测试、联调、部署全流程 原视频地址视频选的项目非常基础,基本就是过了个web开发流程,但我在实际跟着操作时,ai依然会…

Ethan独立开发产品日报 | 2025-04-20

1. Checklist GG 基于人工智能的清单管理工具 checklist.gg是一个基于人工智能的清单管理工具,旨在帮助组织确保每次都能正确完成任务。 关键词:AI驱动, 检查清单, 管理工具, 任务管理, 效率提升, 组织管理, 工作流程, 自动化工具, 清单管理, 协作工具…

第十四届蓝桥杯 2023 C/C++组 冶炼金属

目录 题目: 题目描述: 题目链接: 思路: 核心思路: 思路详解: 代码: 代码详解: 题目: 题目描述: 题目链接: 蓝桥云课 冶炼金属 洛谷 P92…

【数字图像处理】彩色图像处理(1)

研究彩色图像处理的原因 1:利用颜色信息,可以简化目标物的区分,以及从场景中提取出目标物 2:人眼对颜色非常敏感,可以分辨出来几千种颜色色调和亮度,却只能分别出几十种灰度 彩色图像分类 伪彩色图像处理&…

pytest自动化中关于使用fixture是否影响用例的独立性

第一个问题:难道使用fixture 会影响用例独立吗? ✅ 简单回答: 使用 fixture ≠ 不独立。 只要你的 fixture 是每次测试都能自己运行、自己产生数据的,那么测试用例依然是“逻辑独立”的。 ✅ 怎么判断 fixture 是否影响独立性&a…

C++计算 n! 中末尾零的数量

* 详细说明* 给定一个整数作为输入。目标是找出该数的阶乘结果中末尾零的数量。 一个数 N 的阶乘是范围 [1, N] 内所有数的乘积。* * 我们知道,只有当一个数是 10 的倍数或者有因数对 (2, 5) 时,才会产生末尾零。 在任何大于 5 的数的阶乘中,…

推荐系统/业务,相关知识/概念2

一、漫画库更新大量新作品,如何融入推荐系统? 参考答案: 快速提取新作品特征:除基础属性外,利用自然语言处理技术提取漫画简介关键词等丰富特征向量,分析情节、角色设定等深层次特征结合物品画像体系分类…