day-01 Docker

一、docker简介

        Docker 是一种开源的容器化平台,它可以帮助开发人员将应用程序及其依赖项打包成一个独立的、可移植的容器,而无需担心环境差异和依赖问题。通过使用 Docker,您可以更轻松地创建、分发和运行应用程序,无论是在开发、测试还是生产环境中。

        Docker 利用了 Linux 内核的特性,如 cgroups 和命名空间,来提供轻量级、隔离和可移植的容器。每个容器都是一个独立的运行时环境,具有自己的文件系统、进程空间和网络接口。这使得多个容器可以在同一台主机上同时运行,而互相之间不会产生冲突。

        使用 Docker,我们可以通过 Docker 镜像来定义应用程序的运行环境。镜像是一个只读的模板,它包含了运行应用程序所需的所有组件,包括操作系统、软件库和应用程序代码。可以基于现有的镜像构建自己的镜像,也可以将镜像上传到 Docker Hub 或私有的 Docker 仓库进行共享和发布。

除了提供容器化的运行环境,Docker 还提供了一套强大的命令行工具和 API,用于管理和操作容器。您可以使用这些工具来创建、启动、停止、删除和监控容器,以及管理应用程序的网络和存储等方面。

        总而言之,Docker 提供了一种便捷、可靠和高效的方式来打包、交付和运行应用程序,使得开发人员能够更加专注于应用程序的开发和部署,而无需担心环境配置和依赖问题。

1.docker与虚拟机的区别

        Docker 和传统虚拟机之间有以下几个主要区别:

  1. 架构差异:传统虚拟机使用 Hypervisor 在物理硬件上创建多个虚拟环境,并在每个虚拟机中运行完整的操作系统。而 Docker 则利用宿主机操作系统的内核来实现容器化,容器共享宿主机的操作系统,避免了运行多个完整操作系统的开销。

  2. 资源消耗:由于传统虚拟机需要运行完整的操作系统,因此每个虚拟机都需要独立分配一定的内存和计算资源。相比之下,Docker 容器直接运行在宿主机上,共享宿主机的资源,使得容器更加轻量级且资源消耗更少。

  3. 启动时间:传统虚拟机的启动时间较长,通常需要几分钟的时间来启动一个虚拟机。而 Docker 容器可以在几秒钟内启动,因为容器只需加载应用程序及其依赖项即可,无需启动操作系统。

  4. 部署速度:由于 Docker 容器具有轻量级和快速启动的特点,可以提供更快的应用程序部署速度。容器可以更快地部署、升级和扩展,从而提高了应用程序的迭代和交付效率。

  5. 系统隔离:传统虚拟机通过 Hypervisor 实现硬件级别的隔离,每个虚拟机都有自己独立的内核和资源。而 Docker 容器使用 Linux 内核的命名空间和 cgroups 功能来实现轻量级隔离,使得容器之间相互隔离但仍共享宿主机的内核。这种隔离方式在安全性和性能方面提供了一定的平衡。

        综上所述,Docker 和虚拟机在架构资源消耗启动时间部署速度系统隔离等方面存在较大区别(优势)。Docker 更加轻量级、快速和灵活,适合于应用程序的打包、交付和部署;而传统虚拟机则提供了更高的隔离性和多样化的操作系统支持,适合于运行不同操作系统的应用程序。根据具体需求,可以选择使用 Docker 或传统虚拟机来满足不同的场景和要求。

2.docker的组成 

        Docker 由以下几个核心组件组成:

  • Docker Engine:Docker 引擎是 Docker 的核心组件,负责管理容器的生命周期、构建和运行容器。它包括三个主要部分:Docker 守护进程(dockerd),API 接口和命令行工具(docker)。

  • Docker 镜像(Docker Images):Docker 镜像是用于创建容器的模板,包含了一个完整的文件系统,包括代码、运行时环境、系统工具、库文件等。可以通过 Dockerfile 或从 Docker Hub 等镜像仓库中获取现有的镜像,也可以自己构建定制化的镜像。

  • Docker 容器(Docker Containers):Docker 容器是基于 Docker 镜像创建的运行实例。每个容器都是独立且隔离的运行环境,包含了运行应用程序所需的所有依赖项。容器可以启动、停止、重启,并且可以与其他容器进行通信和交互。

  • Docker 仓库(Docker Registry):Docker 仓库用于存储和分享 Docker 镜像。Docker Hub 是最常用的公共 Docker 仓库,其中包含了大量的官方和社区维护的镜像供用户使用。除了公共仓库外,还可以搭建私有仓库,用于本地镜像的存储和管理。

  • Docker Compose:Docker Compose 是一个用于定义和运行多个容器应用的工具。通过编写一个 YAML 文件来定义多个容器之间的关系和配置,然后使用 docker-compose 命令进行一键式部署、启动和停止。

  • Docker Swarm:Docker Swarm 是 Docker 官方提供的容器集群管理工具,用于在多个主机上创建和管理容器集群。它可以将多个 Docker 主机组合成一个虚拟的计算资源池,自动调度和管理容器的部署和扩缩容。

除了以上核心组件外,还有一些辅助工具和服务,如 Docker Machine(用于在虚拟机或云端创建和管理 Docker 主机)、Docker Network(用于容器之间的网络连接)和第三方的监控和日志工具等,进一步增强了 Docker 的功能和生态系统。

综上所述,Docker 的主要组成部分包括 Docker 引擎、镜像、容器、仓库、Compose 和 Swarm 等。这些组件共同构成了 Docker 的基础架构,并提供了便捷、可移植和高效的容器化解决方案。

3.docker运行流程

Docker 的运行流程可以简要概括为以下几个步骤:

  1. 编写 Dockerfile:Dockerfile 是一个文本文件,用于定义 Docker 镜像的构建过程。在 Dockerfile 中,你可以指定基础镜像、添加和配置应用程序所需的依赖项、设置环境变量、复制文件等操作。

  2. 构建镜像:使用 Docker 命令行工具执行 docker build 命令,根据 Dockerfile 构建镜像。该命令会按照 Dockerfile 中的指令逐步执行,并生成一个新的镜像。在构建过程中,Docker 会下载所需的基础镜像和依赖项,并在每一步骤生成一个中间镜像。

  3. 运行容器:使用 docker run 命令来运行容器。该命令需要指定要运行的镜像名称或 ID,并可以通过参数设置容器的名称、端口映射、环境变量、挂载数据卷等配置选项。在运行时,Docker 会基于镜像创建一个新的容器实例,并启动其中的应用程序。

  4. 应用程序执行:一旦容器启动,Docker 将在容器内部运行应用程序。容器中的应用程序将具有自己的文件系统、进程空间和网络接口,与宿主机和其他容器隔离开。应用程序可以执行任何操作,运行所需的服务或应用逻辑。

  5. 交互和管理:Docker 提供了一系列命令和工具,用于与容器进行交互和管理。你可以使用 docker exec 命令在运行中的容器内执行命令,使用 docker logs 查看容器的日志输出,使用 docker stop 命令停止容器的运行等。同时,也可以使用 Docker Compose、Docker Swarm 等工具来管理多个容器的部署和协调。

  6. 停止和清理:当不再需要运行的容器时,可以使用 docker stop 命令停止容器的运行。如果需要移除容器,可以使用 docker rm 命令将其删除。对于不再使用的镜像,可以使用 docker rmi 命令进行清理。

        总结起来,Docker 的运行流程包括编写 Dockerfile 定义镜像构建过程使用 Docker 命令行工具构建镜像运行容器应用程序执行交互和管理容器最后停止和清理容器和镜像。这个流程使得 Docker 提供了一种便捷、可移植和轻量级的容器化解决方案。

4.docker数据卷

Docker 数据卷(Docker Volumes)是用于在容器和宿主机之间持久化存储数据的一种机制。它允许容器中的数据在容器生命周期内保留,并且独立于容器的停止和删除操作。

使用 Docker 数据卷的主要优势包括:

  1. 数据持久化:容器中的数据可以在容器终止、重启或删除后仍然保留,这样可以确保数据的持久性存储,不会因为容器的状态改变而丢失数据。

  2. 数据共享:多个容器可以共享同一个数据卷,使得容器之间可以交换和共享数据。这对于需要共享配置文件、日志目录或其他共享数据的应用程序非常有用。

  3. 数据备份和迁移:通过将数据卷映射到宿主机上的特定路径,可以轻松将数据从一个容器迁移到另一个容器或备份到宿主机的本地文件系统或远程存储等。

  4. 容器间通信:如果多个容器共享同一个数据卷,它们可以通过数据卷中的文件进行相互通信和数据交换。这在微服务架构和分布式应用程序中特别有用。

以下是几种创建和使用 Docker 数据卷的方式:

  1. docker run 命令:可以使用 -v--volume 参数来创建一个数据卷,并将其映射到容器中的指定路径。例如:docker run -v /path/on/host:/path/in/container image_name

  2. Docker Compose:可以通过编写 docker-compose.yml 文件,在服务定义中指定 volumes 字段来创建和管理数据卷。这样可以实现多个容器之间的共享数据卷。

  3. Dockerfile:在 Dockerfile 中使用 VOLUME 关键字可以指定将哪些目录作为数据卷,例如:VOLUME ["/var/data"]。当镜像被用于创建容器时,该目录会自动转换为数据卷。

  4. 匿名数据卷:如果不指定数据卷的路径,Docker 会自动生成一个匿名数据卷,并将其挂载到容器中的随机路径上。这种类型的数据卷通常用于临时或临时性数据。

  5. 具名数据卷:可以使用 docker volume create 命令手动创建一个具名数据卷,并将其映射到容器中。这样可以更加灵活地管理数据卷的生命周期和配置。

总之,Docker 数据卷提供了一种方便的方式来持久化存储容器中的数据,并实现容器间的数据共享和通信。通过合理地使用数据卷,可以使得容器应用程序更加灵活、可移植和可靠。

二、docker的简单使用

镜像相关指令:

  • docker pull <镜像名称>: 从镜像仓库中拉取一个镜像到本地。
  • docker images: 显示本地已经下载的镜像列表。
  • docker build <选项> <上下文路径>: 根据 Dockerfile 构建一个自定义镜像。
  • docker push <镜像名称>: 将本地的镜像推送到镜像仓库。
  • docker rmi <镜像名称>: 删除本地的一个镜像。
  • docker tag <源镜像名称>:<标签> <目标镜像名称>:<标签>: 给本地镜像打标签。

容器相关指令:

  • docker run <选项> <镜像名称>: 在容器中运行一个镜像。
  • docker ps: 显示正在运行的容器列表。
  • docker start <容器ID>: 启动已停止的容器。
  • docker stop <容器ID>: 停止运行中的容器。
  • docker restart <容器ID>: 重启容器。
  • docker rm <容器ID>: 删除已停止的容器。
  • docker exec <选项> <容器ID> <命令>: 在运行中的容器中执行命令。
  • docker logs <容器ID>: 查看容器的日志输出。
  • docker inspect <容器ID>: 查看容器的详细信息。

网络和存储指令:

  • docker network ls: 显示 Docker 网络列表。
  • docker network create <网络名称>: 创建一个自定义的 Docker 网络。
  • docker volume ls: 显示 Docker 数据卷列表。
  • docker volume create <卷名称>: 创建一个 Docker 数据卷。
  • docker volume rm <卷名称>: 删除一个 Docker 数据卷。

其他常用指令:

  • docker-compose up: 在当前目录中使用 Docker Compose 启动容器。
  • docker-compose down: 在当前目录中使用 Docker Compose 停止容器并删除相关资源。
  • docker version: 显示 Docker 的版本信息。
  • docker info: 显示 Docker 的系统信息。

三、dockerfile文件的编写

Dockerfile 是一个文本文件,用于定义 Docker 镜像的构建过程。通过编写 Dockerfile,可以指定基础镜像、添加和配置应用程序所需的依赖项、设置环境变量、复制文件等操作。以下是 Dockerfile 常见的指令和使用方法:

  1. FROM:指定基础镜像,格式为 FROM <image>[:<tag>]。例如:FROM ubuntu:latest

  2. LABEL:给镜像添加元数据,格式为 LABEL <key>=<value>。可以用来提供作者信息、版本号、描述等信息。

  3. RUN:在镜像中执行命令或脚本,格式为 RUN <command>。例如:RUN apt-get update && apt-get install -y curl

  4. COPYADD:将文件从构建上下文复制到镜像中。COPY 指令格式为 COPY <src> <dest>ADD 指令格式为 ADD <src> <dest>。其中 <src> 是构建上下文中的文件或目录路径,<dest> 是目标镜像中的路径。

  5. WORKDIR:设置工作目录,格式为 WORKDIR <path>。后续的命令会在该路径下执行。

  6. ENV:设置环境变量,格式为 ENV <key>=<value>。例如:ENV JAVA_HOME=/usr/lib/jvm/java-11

  7. EXPOSE:声明容器运行时要监听的端口号,格式为 EXPOSE <port> [<port>/<protocol>...]。例如:EXPOSE 8080/tcp

  8. CMDENTRYPOINT:设置容器启动后执行的命令或脚本。CMD 格式为 CMD ["<executable>", "<param1>", "<param2>", ...]ENTRYPOINT 格式为 ENTRYPOINT ["<command>", "<param1>", "<param2>", ...]。可以使用多个 CMDENTRYPOINT,但最终只有最后一个指令生效。

以上是 Dockerfile 中常用的指令,还有其他一些指令和参数可供使用,可以根据实际需求进行查阅和使用。编写完 Dockerfile 后,可以使用 docker build 命令根据 Dockerfile 构建镜像,例如:docker build -t my-image:tag .,其中 . 表示当前目录是构建上下文。

在构建过程中,Docker 会按照 Dockerfile 中的指令逐步执行,并生成一个新的镜像。每个指令都会在前一个指令的基础上进行修改,形成一条镜像层的链条。这种分层的结构使得镜像的构建和管理更加高效和灵活。

总之,Dockerfile 是用于定义 Docker 镜像构建过程的重要工具,通过编写指令来配置镜像的组件、配置和应用程序等。正确编写和使用 Dockerfile 可以大大简化镜像构建的流程,并提供可重复和可扩展的容器化解决方案。

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

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

相关文章

自然语言处理学习笔记(七)————字典树效率改进

目录 1. 首字散列其余二分的字典树 2.双数组字典树 3.AC自动机(多模式匹配) &#xff08;1&#xff09;goto表 &#xff08;2&#xff09;output表 &#xff08;3&#xff09;fail表 4.基于双数组字典树的AC自动机 字典树的数据结构在以上的切分算法中已经很快了&#x…

轴向磁通电驱动解析

轴向磁通电机的技术创新和量产应用&#xff0c;或将有效解决电动汽车领域目前所面临的一些突出难题&#xff0c;比如轻量化、扭矩密度和人们最为关心的续航里程等。在奔驰汽车刚刚发布的Vision One Eleven概念车&#xff0c;以及此前已经面世的法拉利SF90 Stradale、296GTB和迈…

【函数栈帧解析:代码的迷人堆积和无限嵌套】

本章重点 一、何为函数栈帧 二、函数栈帧特性 - 同栈 - 后进先出 三、认识内存空间布局图 四、认识相关寄存器 五、认识相关汇编命令 六、测试代码&#xff1a; 七、函数栈帧全过程 要解决的问题​​​​​​​ 局部变量是怎么创建的&#xff1f;为什么局部变量的值是随机值&am…

韶音骨传导耳机好不好,韶音骨传导耳机值得入手吗

韶音耳机的质量还是很不错的&#xff0c;其实力相比于百元价位的耳机而言领先了不少&#xff0c;具备多种功能&#xff0c;佩戴起来也是有着舒适性。它自主研发了骨传导音频技术&#xff0c;不过在今年开始&#xff0c;似乎已经将方向开始往运动偏移。 而在韶音的骨传导耳机中&…

git clone 报SSL证书问题

git命令下运行 git config --global http.sslVerify false 然后再进行重新clone代码

设计模式备忘录+命令模式实现Word撤销恢复操作

文章目录 前言思路代码实现uml类图总结 前言 最近学习设计模式行为型的模式&#xff0c;学到了备忘录模式提到这个模式可以记录一个对象的状态属性值&#xff0c;用于下次复用&#xff0c;于是便想到了我们在Windows系统上使用的撤销操作&#xff0c;于是便想着使用这个模式进…

day28 异常

to{}catch{} try{}catch{}的流传输 try {fis new FileInputStream("file-APP\\fos.txt");fos new FileOutputStream("fos.txt");int a ;while ((a fis.read())! -1){fos.write(a);}System.out.println(a); } catch (IOException e) {e.printStackTrace()…

24.排序,插入排序,交换排序

目录 一. 插入排序 &#xff08;1&#xff09;直接插入排序 &#xff08;2&#xff09;折半插入排序 &#xff08;3&#xff09;希尔排序 二. 交换排序 &#xff08;1&#xff09;冒泡排序 &#xff08;2&#xff09;快速排序 排序&#xff1a;将一组杂乱无章的数据按一…

高可用集群介绍

一、高可用集群概念 高可用集群&#xff08; High Availability Cluster, HA 集群&#xff09;&#xff0c;其中高可用的含义是最大限度地可以使用。从集群 的名字上可以看出&#xff0c;此类集群实现的功能是保障用户的应用程序持久、不间断地提供服务。当应用程序出现故障或…

【笔记】PyCharm快捷键大全

PyCharm是一种Python集成开发环境&#xff08;IDE&#xff09;&#xff0c;由JetBrains公司开发。它被认为是Python开发中最强大、最流行的IDE之一。PyCharm具有完整的Python开发工具链&#xff0c;包括先进的代码编辑器、代码分析工具、集成的调试器、版本控制系统集成、自动化…

前端将UTC时间格式转化为本地时间格式-uniapp写法

UTC时间格式是什么 首先我们先简单的了解一下&#xff1a;UTC时间&#xff08;协调世界时&#xff0c;Coordinated Universal Time&#xff09;使用24小时制&#xff0c;以小时、分钟、秒和毫秒来表示时间 HH:mm:ss.SSSHH 表示小时&#xff0c;取值范围为00到23。mm 表示分钟…

Python股票交易---均值回归

免责声明&#xff1a;本文提供的信息仅用于教育目的&#xff0c;不应被视为专业投资建议。在做出投资决策时进行自己的研究并谨慎行事非常重要。投资涉及风险&#xff0c;您做出的任何投资决定完全由您自己负责。 在本文中&#xff0c;您将了解什么是均值回归交易算法&#xff…

ChatGPT癌症治疗“困难重重”,真假混讲难辨真假,准确有待提高

近年来&#xff0c;人工智能在医疗领域的应用逐渐增多&#xff0c;其中自然语言处理模型如ChatGPT在提供医疗建议和信息方面引起了广泛关注。然而&#xff0c;最新的研究表明&#xff0c;尽管ChatGPT在许多领域取得了成功&#xff0c;但它在癌症治疗方案上的准确性仍有待提高。…

leetcode 392. 判断子序列

2023.8.25 本题要判断子序列&#xff0c;可以使用动态规划来做&#xff0c;定义一个二维dp数组。 接下来就是常规的动态规划求解子序列的过程。 给出两种定义dp数组的方法。 二维bool型dp数组&#xff1a; class Solution { public:bool isSubsequence(string s, string t) …

在云原生环境中构建可扩展的大数据平台:方法和策略

文章目录 1. **选择适当的云提供商&#xff1a;**2. **采用容器化和微服务架构&#xff1a;**3. **分层架构设计&#xff1a;**4. **弹性计算资源&#xff1a;**5. **使用分布式计算框架&#xff1a;**6. **数据分区和分片&#xff1a;**7. **使用列式存储&#xff1a;**8. **缓…

qt day 1

this->setWindowIcon(QIcon("D:\\zhuomian\\wodepeizhenshi.png"));//設置窗口的iconthis->setWindowTitle("鵬哥快聊");//更改名字this->setFixedSize(500,400);//設置尺寸QLabel *qlnew QLabel(this);//創建一個標簽ql->resize(QSize(500,20…

【计算机视觉|生成对抗】用于高保真自然图像合成的大规模GAN训练用于高保真自然图像合成的大规模GAN训练(BigGAN)

本系列博文为深度学习/计算机视觉论文笔记&#xff0c;转载请注明出处 标题&#xff1a;Large Scale GAN Training for High Fidelity Natural Image Synthesis 链接&#xff1a;[1809.11096] Large Scale GAN Training for High Fidelity Natural Image Synthesis (arxiv.org…

Rabbitmq消息积压问题如何解决以及如何进行限流

一、增加处理能力 优化系统架构、增加服务器资源、采用负载均衡等手段&#xff0c;以提高系统的处理能力和并发处理能力。通过增加服务器数量或者优化代码&#xff0c;确保系统能够及时处理所有的消息。 二、异步处理 将消息的处理过程设计为异步执行&#xff0c;即接收到消息…

基于机器学习的fNIRS信号质量控制方法

摘要 尽管功能性近红外光谱(fNIRS)在神经系统研究中的应用越来越广泛&#xff0c;但fNIRS信号处理仍未标准化&#xff0c;并且受到经验和手动操作的高度影响。在任何信号处理过程的开始阶段&#xff0c;信号质量控制(SQC)对于防止错误和不可靠结果至关重要。在fNIRS分析中&…

FreeSWITCH 1.10.10 简单图形化界面5 - 使用百度TTS

FreeSWITCH 1.10.10 简单图形化界面5 - 使用百度TTS 0、 界面预览1、注册百度AI开放平台&#xff0c;开通语音识别服务2、获取AppID/API Key/Secret Key3、 安装百度语音合成sdk4、合成代码5、在PBX中使用百度TTS6、音乐文件-TTS7、拨号规则-tts_command 0、 界面预览 http://…