day-01 Docker

news2024/10/6 14:32:50

一、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.coloradmin.cn/o/949965.html

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

相关文章

Apipost: 开发者们的瑞士军刀

在当今的数字化时代&#xff0c;数据流通是推动社会进步的关键因素之一。其中&#xff0c;API&#xff08;应用编程接口&#xff09;已经成为跨平台数据交互的标准。然而&#xff0c;API开发和管理并非易事&#xff0c;Apipost一体化研发协作赋能平台&#xff0c;支持从API设计…

并发编程(四)---死锁 synchronized、volatile详解

一.关键字 1.synchronized关键字&#xff1a; a.重量级锁&#xff0c;功能完整的锁 b.修饰类、方法、静态方法、代码块&#xff0c;但不可以在声明的时候修饰 c.synchronized是实现同步的基础&#xff0c;Java中不管是对象还是方法&#xff0c;都可加上锁。synchronized分为三…

音频应用编程

目录 ALSA 概述alsa-lib 简介sound 设备节点alsa-lib 移植编写一个简单地alsa-lib 应用程序一些基本概念打开PCM 设备设置硬件参数 ALPHA I.MX6U 开发板支持音频&#xff0c;板上搭载了音频编解码芯片WM8960&#xff0c;支持播放以及录音功能&#xff01; 本章我们来学习Linux …

探索散列表和哈希表:高效存储与快速检索的魔法

文章目录 散列函数的原理散列表和哈希表的概念与操作解决冲突的方法案例分析&#xff1a;电话簿的实现拓展&#xff1a;性能与碰撞结论 &#x1f389;欢迎来到数据结构学习专栏~探索散列表和哈希表&#xff1a;高效存储与快速检索的魔法 ☆* o(≧▽≦)o *☆嗨~我是IT陈寒&#…

【模拟集成电路】反馈系统加载效应——基础到进阶(三)

【模拟集成电路】反馈系统加载效应——基础到进阶&#xff08;三&#xff09; -----------------------文末附往期文章链接-------------------- 1.概述2.二端口网络方法2.1二端口网络模型2.2电压-电压反馈的加载2.2电流-电压反馈的加载2.3电压-电流反馈的加载2.4电流-电流反馈…

一文速学-让神经网络不再神秘,一天速学神经网络基础-输出层(四)

前言 思索了很久到底要不要出深度学习内容&#xff0c;毕竟在数学建模专栏里边的机器学习内容还有一大半算法没有更新&#xff0c;很多坑都没有填满&#xff0c;而且现在深度学习的文章和学习课程都十分的多&#xff0c;我考虑了很久决定还是得出神经网络系列文章&#xff0c;不…

Flutter 混合开发调试

针对Flutter开发的同学来说&#xff0c;大部分的应用还是Native Flutter的混合开发&#xff0c;所以每次改完Flutter代码&#xff0c;运行整个项目无疑是很费时间的。所以Flutter官方也给我们提供了混合调试的方案【在混合开发模式下进行调试】&#xff0c;这里以Android Stud…

Python基础学习第四天:Python注释

创建注释 注释以 &#xff03; 开头&#xff0c;Python 将忽略它们&#xff1a; 实例 #This is a comment print("Hello, World!")运行实例 注释可以放在一行的末尾&#xff0c;Python 将忽略该行的其余部分&#xff1a; 实例 print("Hello, World!")…

1-8 隐语小课|私有信息检索(PIR)及其应用场景

“隐语”是开源的可信隐私计算框架&#xff0c;内置 MPC、TEE、同态等多种密态计算虚拟设备供灵活选择&#xff0c;提供丰富的联邦学习算法和差分隐私机制 开源项目 github.com/secretflow gitee.com/secretflow 前言 欢迎来到小剧场全新系列节目「隐语小课」&#xff01;本…

Run the Docker daemon as a non-root user (Rootless mode)

rootless 简介 rootless模式是指以非root用户身份运行Docker守护程序和容器。那么为什么要有rootless mode呢&#xff1f;因为在root用户下安装启动的容器存在安全问题。存在的安全问题具体来说是容器内的root用户就是宿主机的root用户&#xff0c;容器内uid1000的用户就是宿主…

csp认证真题——重复局面——Java题解

目录 题目背景 问题描述 输入格式 输出格式 样例输入 样例输出 样例说明 子任务 提示 【思路解析】 【代码实现】 题目背景 国际象棋在对局时&#xff0c;同一局面连续或间断出现3次或3次以上&#xff0c;可由任意一方提出和棋。 问题描述 国际象棋每一个局面可以…

vscode 清除全部的console.log

在放页面的大文件夹view上面右键点击在文件夹中查找 console.log.*$ 注意&#xff1a;要选择使用正则匹配 替换为 " " (空字符串)

多线程应用——单例模式

单例模式 文章目录 单例模式一.什么是单例模式二.如何实现1.口头实现2.利用语法特性 三.实现方式&#xff08;饿汉式懒汉式&#xff09;1.饿汉式2.懒汉式3.线程安全的单例模式4.双重检查锁5.禁止指令重排序 一.什么是单例模式 单例模式&#xff08;Singleton Pattern&#xff…

数据集学习笔记(六):目标检测和图像分割标注软件介绍和使用,并转换成YOLO系列可使用的数据集格式

文章目录 一、目标检测1.1 labelImg1.2 介绍1.3 安装1.4 使用1.5 转换1.6 验证 二、图像分割2.1 labelme2.2 介绍2.3 安装2.4 使用2.5 转换2.6 验证 一、目标检测 1.1 labelImg 1.2 介绍 labelImg是一个开源的图像标注工具&#xff0c;用于创建图像标注数据集。它提供了一个…

2023-08-30 LeetCode每日一题(到家的最少跳跃次数)

2023-08-30每日一题 一、题目编号 1654. 到家的最少跳跃次数二、题目链接 点击跳转到题目位置 三、题目描述 有一只跳蚤的家在数轴上的位置 x 处。请你帮助它从位置 0 出发&#xff0c;到达它的家。 跳蚤跳跃的规则如下&#xff1a; 它可以 往前 跳恰好 a 个位置&#x…

OpenCVSharp入门学习①-获取本地摄像头数据

1. nuget包安装opencvsharp4和opencvsharp4.extensiongs和opencvsharp4.runtime.win 如果不安装opencvsharp4.runtime.win的话会报 System.TypeInitializationException:““OpenCvSharp.Internal.NativeMethods”的类型初始值设定项引发异常。”DllNotFoundException: 无法加…

vue v-for 例子

vue v-for 例子 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title> </head&…

AssemblyManager 程序集管理器

AssemblyManager 程序集管理器 程序执行中使用反射对框架的搭建有着强大的影响&#xff0c;如何管理程序集方便使用反射获取类型操作对象是本文章的重点 1.AssemblyInfo 对于一个程序集这里使用一个AssemblyInfo对象进行管理 Assembly &#xff1a;对应的程序集AssemblyTyp…