当前位置: 首页 > 图灵资讯 > 技术篇> docker

docker

来源:图灵教育
时间:2023-04-25 11:02:16

  镜像和容器

  上图显示了镜像与容器之间的关系,从顶层设计层面。通常使用docker container run和docker service create命令从一个镜像中启动一个或多个容器。

  一旦容器从镜像开始,它们就变成了相互依赖的关系,在所有从镜像开始的容器停止之前,镜像就不能被删除。试图删除镜像而不停止或销毁使用它的容器会导致错误。镜像通常相对较小

  容器的目的是运行应用程序或服务,这意味着必须包含应用程序/服务操作所需的操作系统和应用程序文件。

  然而,容器追求快速和小,这意味着在构建镜像时,通常需要切断不必要的部分,以保持较小的体积。

  例如,Docker 镜像通常不包括在内 6 个不同的 Shell 让读者选择-通常 Docker 镜像中只有一个简化的Shell,甚至没有 Shell。

  镜像中不包含核心-容器共享 Docker 主机的核心。因此,有时容器只包含必要的操作系统(通常只包含操作系统文件和文件系统对象)。

  提示:Hyper-V 容器在特殊的轻量级容器中运行 VM 上,同时使用 VM 内部操作系统内核。

  Docker 官方镜像 Alpine Linux 大约只有 4MB,可以说是 Docker 镜像小巧的典型例子。

  然而,镜像更常见的状态是如此 Ubuntu 官方的 Docker 镜像一般,大约有 110MB。大部分无用的内容都被剪掉在这些镜像中。

  Windows 镜像要比 Linux 镜像比较大,这个和 Windows OS 工作原理相关。例如,最新的未压缩 Microsoft .NET 镜像(microsoft/dotnet:latest)超过 1.7GB。Windows Server 2016 Nano Server 镜像(microsoft/nanoserver:latest)拉取解压后,其体积略大于 1GB。 过滤器

  Docker 目前支持以下过滤器。 dangling:可以指定 true 或者 false,只返回悬虚镜像(true),或者非悬虚镜像(false)。 before:需要镜像名称或者 ID 作为参数,返回之前创建的所有镜像。 since:与 before 类似地,但返回的是指定镜像后创建的所有镜像。 label:根据标注(label)过滤镜像的名称或值。docker image ls命令输出中不显示标记内容。

  可使用其他过滤方法 reference。

  以下是使用 reference 过滤完成后,只显示标签 latest 的示例。

  $ docker image ls --filter=reference="*:latest"REPOSITORY TAG IMAGE ID CREATED SIZEalpine latest 3fd9065eaf02 8 days ago 4.15MBtest latest 8426e7efb777 3 days ago 122MB 镜像仓库服务

  Docker 镜像存储在镜像仓库服务中(Image Registry)当中。

  Docker 可配置客户端的镜像仓库服务,默认使用 Docker Hub。

  镜像仓库服务包括多个镜像仓库(Image Repository)。同样,一个镜像仓库可以包含多个镜像。

  也许这听起来有点令人困惑,所以下图显示了它包含的内容 3 镜像仓库的镜像仓库服务,每个镜像仓库都包含一个或多个镜像。

docker_docker

官方和非官方镜像仓库

  Docker Hub 也分为官方仓库(Official Repository)和非官方仓库(Unofficial Repository)。

  顾名思义,官方仓库的镜像是由 Docker 公司审查。这意味着镜像将及时更新,由高质量的代码组成。这些代码是安全的,有完善的文档和最佳实践。

  非官方仓库更像江湖侠客,镜像可能没有官方仓库的优势,但这并不意味着所有非官方仓库都不好!非官方仓库也有一些优秀的镜像。

  在信任非官方仓库的镜像代码之前,我们需要谨慎。说实话,读者在使用任何从互联网上下载的软件之前都应该小心,甚至在使用官方仓库的镜像之前。

  大多数流行的操作系统和应用程序 Docker Hub 官方仓库有相应的镜像。这些镜像很容易找到,基本上都在 Docker Hub 命名空间的顶层。 镜像 images

  查看本地镜像语法:

  docker images [OPTIONS] [REPOSITORY[:TAG]]

  OPTIONS:选项

  REPOSITORY:镜像名称

  TAG:版本号选项

  选项

  作用

  –all , -a

  显示所有镜像(默认情况下不会显示中间镜像)

  –digests

  显示镜像摘要信息

  –filter , -f

  根据给定条件筛选镜像

  –format

  指定自定义打印格式

  –no-trunc

  显示完整的镜像ID

  –quiet , -q

  只显示镜像ID 定制打印格式

  支持指定字段的自定义打印格式如下:

  字段

  描述

  .ID

  镜像 ID

  .Repository

  镜像名

  .Tag

  镜像tag

  .Digest

  镜像摘要

  .CreatedSince

  创建时间跨度

  .CreatedAt

  创建时间点

  .Size

  镜像磁盘的大小例子 docker根据镜像名和tag值查询 images python:3.9显示没有tag值的镜像docker images --filter="dangling=true删除docker,未打ta值额镜像 rmi -f $(docker images --filter="dangling=true" -q)显示镜像ID和镜像名docker images --format "{{.ID}}: {{.Repository}}" pull

  用于从镜像仓库中提取或更新指定的镜像。当我们操作容器并指定它时 Docker 当镜像不在本地时,它首先从仓库里拉出来。大多数时候,当我们使用官员时, Docker 创建自己的定制镜像作为基本镜像 Docker 镜像时,镜像是从“hub.docker.com下载的公共仓库。这个命令有不同的标志,但有些只适用于更新版本。语法

  docker pull [OPTIONS] NAME[:TAG|@DIGEST]OPTIONS:NAME选项:镜像名TAG:版本号 参数

  选项

  作用

  –all-tags, -a

  用于下载存储库中不同标签的所有镜像,docker pull 默认命令一次只拉一个镜像

  –disable-content-trust

  它会在拉出之前跳过镜像验证

  –platform

  用于设置平台,仅适用于目前使用的实验功能。如果您不熟悉镜像,例如它是如何工作或工作的,不建议下载未签名的镜像 Docker 镜像。

  –quiet, -q:

  用于静默拉取镜像(不冗长)。例子 拉没有任何标签的 ‘alpine’ 镜像,Docker 默认情况下,守护过程会拉带“latest“标签镜像,只有当有最新标签的镜像时,才会拉出镜像docker pull alpine拉带有特定标签的镜像,例如,我们将拉带有不同标签的相同“alpine”镜像,即“edge”docker pull alpine:通过摘要提取镜像dockeredge pull alpine@sha256:3e92a88546f6b15943678d323afdbf1d950368264e0317b45e469dfa81d53从不同的仓库或私人仓库拉出镜像docker pull localhost:5000/alpine拉一个包含所有可用标签的仓库docker pull --all-tags alpine拉取未签名并启用内容信任 Docker 镜像docker pull --disable-content-trust localhost:5000/alpine 拉取镜像docker,没有任何详细的输出 pull -q nginx:alpine build

  构建镜像语法 docker build [OPTIONS] PATH | URL | -OPTIONS:PATH选项:路径URL:URL 选项

  名称,简写

  默认

  说明

  --build-arg

  在构造过程中设置变量

  --cache-from

  应考虑作为缓存源的图像

  --cgroup-parent

  --cgroup-parent

  父cgroupp可选容器

  --compress

  false

  使用gzip压缩构建环境

  --cpu-period

  0

  限制CPU CFS周期(完全公平的调度程序)

  --cpu-quota

  0

  限制CPU CFS配额(完全公平的调度程序)

  --cpu-shares, -c

  0

  CPU比例(相对权重)

  --cpuset-cpus

  CPU(0-3,0)允许执行

  --cpuset-mems

  允许执行的内存(0-3,0.1)

  --disable-content-trust

  true

  跳过图像验证

  --file, -f

  Dockerfile的名字(默认为’PATH/Dockerfile‘)

  --force-rm

  false

  总是删除中间容器

  --isolation

  容器隔离技术

  --label

  元数据设置图像

  --memory, -m

  内存限制

  --memory-swap

  交换限制等于内存加交换:-1‘表示启用无限交换

  --network

  default

  在构建过程中设置RUN指令的组网模式

  --no-cache

  false

  构建图像时不要使用缓存

  --pull

  false

  总是试图拉一个更新版本的图像

  --quiet, -q

  false

  抑制构建输出,成功打印图像ID

  --rm

  true

  成功构建后移除中间容器

  --security-opt

  安全选项

  --shm-size

  /dev/shm默认值为:64MB

  --squash

  false

  将新建的层压成新的层

  --tag, -t

  “名称与可选”name:tag格式标签

  --ulimit

  Ulimit配置 例子 使用当前目录的Dockerfile创建镜像。docker build -t luo/ubuntu:v1 . 使用URL github.com/creack/docker-firefox 的 Dockerfile 创建镜像。docker build github.com/creack/docker-firefox search 语法

  docker search [OPTIONS] TERM

  OPTIONS:选项

  TERM:名称(模糊搜索) 选项

  命令选项

  描述

  –filter , -f

  过滤应根据给定的条件进行

  –format

  定制打印格式

  –limit

  显示搜索结果,默认值25

  –no-trunc

  回显结果不截断,全部显示 定制打印格式

  占位符

  描述

  .Name

  镜像名称

  .Description

  镜像描述

  .StarCount

  收集的镜像数量

  .IsOfficial

  镜像是否为官方镜像,如果是现实,“OK”

  .IsAutomated

  如果显示“镜像是否自动构建”OK” 例子 docker通过指定镜像名搜索 search busybox搜索结果不截断显示docker search busybox --no-trunc设置搜索结果仅显示10个docker search busybox --limit=10搜索结果过滤star收集的数量大于或等于3个docker search busybox --filter stars=搜索结果仅列出自动构建的镜像docker search busybox --filter is-automated=true搜索结果只列出了官方镜像docker search busybox --filter is-official=通过多种条件过滤true搜索结果,以下是过滤自动构建的镜像docker,收集量大于或等于3 search busybox --filter is-automated=true --filter stars=三是搜索nginx镜像,只显示镜像名称和镜像收藏数量的docker search --format "{{.Name}}: {{.StarCount}}" nginx格式化显示镜像名称、镜像收藏数量、镜像是否自动构建、镜像是否官方docker search --format "table {{.Name}}\t\t{{.StarCount}}\t\t{{.IsAutomated}}\t\t{{.IsOfficial}}" nginx history

  打印指定的 历史版本的Docker镜像信息。语法

  docker history [OPTIONS] IMAGE

  OPTIONS:选项

  IMAGE:镜像名称 选项

  参数

  说明

  -H

  以可读格式打印镜像的大小和日期,默认为true

  --no-trunc

  显示完整的提交记录

  -q

  仅列出提交记录的ID例子 打印指定的 历史版本的Docker镜像信息。docker history luo/ubuntu:v1 容器 run

  创建和运行新的容器语法 docker run [OPTIONS] IMAGE [COMMAND] [ARG...]OPTIONS 是可选参数,中括号中的参数是可选IMAGE:nginxCOMMAND等具体镜像表示:ARG是执行镜像中的命令..:表示COMMAND命令的参数 选项

  参数

  说明

  -a

  可选择指定标准输入输出内容类型 STDIN/STDOUT/STDERR 三项

  -d

  在后台操作容器并返回容器ID

  -i

  容器通常以交互模式运行 -t 同时使用

  -t

  通常与容器重新分配一个伪输入终端 -i 同时使用

  --name="nginx-lb"

  为容器指定一个名称

  --dns 8.8.8.8

  指定容器使用的DNS服务器默认与宿主一致

  --dns-search example.com

  指定容器DNS搜索域名,默认与宿主一致

  -h "mars"

  指定容器的hostname

  -e username="ritchie"

  设置环境变量

  --env-file=[]

  从指定文件读入环境变量

  --cpuset="0-2" or --cpuset="0,1,2"

  绑定容器到指定CPU运行

  -m

  使用内存最大值的设置容器

  --net="bridge"

  支持指定容器的网络连接类型bridge、host、none和container四种类型

  --link=[]

  添加链接到另一个容器

  --expose=[]

  打开一个端口或一组端口 例子 使用镜像nginx:latest在后台模式下启动容器,并将容器的80端口映射到主机随机端口docker run --name mynginx -d nginx:latest使用镜像nginxx:latest在后台模式下启动容器,并将容器的80端口映射到主机的随机端口-d:在后台启动一个容器P:将容器的80端口映射到主机随机端口docker run -P -d nginx:latest将宿主机的路径映射到容器中,各参数的含义如下:-d: 使用镜像nginx:latest在后台模式下启动容器-P:将容器80端口映射到主机80端口-v:主机目录/data映射到容器/datadocker run -p 80:80 -v /data:/data -d nginx:latest使用镜像nginxx:latest以交互模式启动容器,执行/执行/执行在容器内bin/bash命令:-i:容器以交互模式运行-t:为容器重新分配伪输入终端/bin/bash:执行容器中的命令$ docker run -it nginx:latest /bin/bash

  Docker命令行大全

  https://www.yiibai.com/docker/image_build.html