Docker - 镜像、容器、仓库

原文地址,使用效果更佳!

Docker - 镜像、容器、仓库 | CoderMast编程桅杆Docker - 镜像、容器、仓库 提示 这个章节涉及到 Docker 最核心的知识,也是在使用过程中最常使用到的,需要重点学习。 什么是Docker镜像、容器、仓库? Docker镜像:镜像是一个只读的模板,其中包含了创建 Docker 容器的说明,可以用来创建 Docker 容器。镜像可以包含操作系统、应用程序、依赖库、配置文件等。 Docker容...icon-default.png?t=N7T8https://www.codermast.com/dev-tools/docker/docker-object.html

提示

这个章节涉及到 Docker 最核心的知识,也是在使用过程中最常使用到的,需要重点学习。

什么是Docker镜像、容器、仓库?

  • Docker镜像:镜像是一个只读的模板,其中包含了创建 Docker 容器的说明,可以用来创建 Docker 容器。镜像可以包含操作系统、应用程序、依赖库、配置文件等。

  • Docker容器:容器是代码的隔离环境。这意味着容器并不直接在操作系统上运行。容器是 Docker 镜像的一个运行实例,可以理解为一个轻量级的虚拟机,用面向对象的思想来看,其就是一个镜像的运行对象。容器包含了运行应用程序所需的所有组件,包括操作系统、应用程序、依赖库等。

  • Docker仓库:仓库是用来存储和管理 Docker 镜像的地方,类似于代码仓库。Docker 官方提供了 Docker Hub 仓库,可以在其中存储和分享 Docker 镜像。用户也可以自建私有仓库来存储和管理自己的 Docker 镜像。

镜像、容器、仓库之间的关系

 

Docker 镜像可以看做是一个静态模板,Docker 容器是对镜像的一个实例化,一个镜像可以实例化多个容器,这几个容器相互独立,互不影响。

Docker 仓库就是存放 Docker 镜像的地方,严格意义上来说可以分为本地仓库和远程仓库,远程仓库由 Docker 官方维护,包含了几乎所有的 Docker 镜像,Docker 本地仓库只有你拉取的镜像。

在使用 Docker 镜像创建对象之前,需要先拉取 Docker 镜像,这里的拉取通常是指从 Docker 官方仓库拉取。

故使用 Docker 的基本步骤可以清晰的总结为:

  1. 从仓库拉取 Docker 镜像

  2. 使用 Docker 镜像实例化一个 Docker 容器

  3. 运行 Docker 容器

Docker镜像

当运行容器时,使用的 Docker 镜像不在本地仓库中,Docker 就会从默认的 Docker 仓库中下载该镜像。一般是从 Docker 官方提供的 Docker Hub 仓库中下载。

下面来学习关于 Docker 镜像的相关操作。

镜像列表

docker images

 

  • REPOSITORY:表示镜像的仓库源
  • TAG:镜像的标签, 同一仓库源可以有多个 TAG,代表这个仓库源的不同个版本
  • IMAGE ID:镜像ID
  • CREATED:镜像创建时间
  • SIZE:镜像大小

查找镜像

注意

本小节以查找 Redis 镜像为例做演示说明,其他镜像的操作同理。

  1. 在 Docker Hub查找

使用 Docker Hub 中提供的查找功能:https://hub.docker.com/search?q=redis&type=imageopen in new window

这里就已经找到了 Redis 的镜像信息

 

可以查看 Redis 镜像的各种版本信息。

 

  1. 使用 Docker Search查找

docker search redis

 

  • NAME: 镜像仓库源的名称
  • DESCRIPTION: 镜像的描述
  • OFFICIAL: 是否 docker 官方发布
  • STARS: 类似 Github 里面的 star,表示点赞、喜欢的意思。
  • AUTOMATED: 自动构建。
  1. 使用 Docker Desktop 查找

 

直接在 Docker Desktop 中搜索即可。

拉取镜像

拉取镜像即从 Docker 仓库中拉取 Docker 镜像,本质上就是从远程的仓库中下载镜像到本地。

这里仍以 Redis 为样例进行编写,其他镜像的拉取同理。

docker pull redis

 

这里默认拉取的是 Redis 的最新版本,如果要是想拉取指定版本时可以进行如下执行,如拉取 redis7.0

docker pull redis:7.0

 

删除镜像

这里我们演示删除之前下载的那个 Hello-World 镜像

docker rmi hello-world

 

这里如果使用了该镜像创建了容器,那么就会报错。

 

如果出现这种情况,就说明我们使用了该镜像创建了容器,那么就必须先删除使用该镜像的所有容器,才能够删除该镜像。

  • 先查看 Docker 容器

docker ps -a

 

  • 然后删除 Docker 容器

docker rm 8c0dde3e3fb4

 

使用的是 Docker 容器的 ID 删除。

  • 删除 Docker 镜像

docker rmi hello-world

 

提示

如果一个镜像创建了多个容器,那么在删除该镜像之前,必须删除所有使用该镜像的容器,才能够删除该镜像。

更新镜像

Dokcer 镜像的更新就是在目前运行的 Docker 容器上进行修改,然后将更新后的 Docker 容器的所有内容,导出为一个 Docker 镜像,随后就可以使用该镜像创建 Docker 容器。

  1. 先下载一个 Ubuntu20.04 镜像

docker pull ubuntu:20.04

 

  1. 创建一个该镜像的容器

docker run -t -i ubuntu:20.04

 

  1. 在该容器内运行 apt-get update 指令,更新 ubuntu 系统,更新后 exit 退出这个容器到我们本地的命令控制端。

apt-get update

 

  1. 提交容器副本

docker commit -m="update ubuntu20.04" -a="CoderMast" 13999fa6f4f6 codermast/ubuntu:latest

 

各个参数说明:

  • -m: 提交的描述信息

  • -a: 指定镜像作者

  • 13999fa6f4f6:容器 ID

  • codermast/ubuntu:latest: 指定要创建的目标镜像名

  1. 查看镜像列表

docker images

 

这里可以看到已经创建成功了,并且大小和之前的不一样了。

  1. 使用该镜像创建一个容器

docker run -t -i codermast/ubuntu:latest

 

生成镜像

镜像标签

我们可以使用 docker tag 命令为镜像添加一个新的标签。

docker tag e650c5f208da codermast/ubuntu:v1
  • e650c5f208da:为镜像的 ID
  • codermast/ubuntu:v1:Tag 名

 

此时我们在创建 Docker 容器时,既可以使用 codermast/ubuntu:latest 也可以使用 codermast/ubuntu:v1

Tag 可以看做是给镜像起别名,其本质的镜像 ID 不变,具体底层就是同一个镜像的不同引用而已。

镜像导入和导出

  1. 镜像导出

docker save > codermast-ubuntu-latest.tar e650c5f208da
  • codermast-ubuntu-latest.tar:要导出的文件名
  • e650c5f208da:要导出的镜像 ID

 

  1. 镜像导入

在镜像导入之前,为了方便观察,先删除掉该镜像。

docker load < codermast-ubuntu-latest.tar
  • codermast-ubuntu-latest.tar:为要导入的文件名。

 

注意

  • 若是只想备份images,使用save、load即可
  • 若是在启动容器后,容器内容有变化,需要备份,则使用export、import

Docker容器

在上面的 Docker 镜像的相关操作中,我们或多或少的了解和学习了一些 Docker 容器的相关操作。

容器启动

docker run -it codermast/ubuntu:latest /bin/bash
  • -it 可以连写的,表示 -i -t
  • -t: 在新容器内指定一个伪终端或终端。
  • -i: 允许你对容器内的标准输入 (STDIN) 进行交互
  • codermast/ubuntu:latest:镜像名称

 

容器查看

docker ps -a
  • -a 表示 all,即查看所有容器

 

容器再启动

我们看到,刚才 codermast/ubuntu:latest 的实例d3a11e669e88 已经停止了Exited (0) 4 seconds ago,我们重启这个实例

docker start d3a11e669e88

 

容器停止和重启

  • 容器停止
docker stop d3a11e669e88
  • 容器重启
docker restart d3a11e669e88

 

后台模式与进入

在使用 -d 参数创建容器时,容器启动后会进入后台,那么此时我们怎么进入容器呢?

  • 使用 `docker attach [容器ID]
docker attach d3a11e669e88

 

  • docker exec -i -t [容器ID] /bin/bash
docker exec -i -t d3a11e669e88 /bin/bash

 

注意

  • docker attach 在退出容器终端后,容器会停止运行。

  • docker exec 在退出容器终端后,不会导致容器的停止。

✅ 推荐大家使用 docker exec

容器导出和导入

  1. 容器的导出
docker export 246b23d5d5a5 > redis-latest-codermast.tar
  • 246b23d5d5a5:容器 ID
  • redis-latest-codermast.tar:导出文件名

 

  1. 容器的导入
docker import redis-latest-codermast.tar codermast/redis:latest
  • redis-latest-codermast.tar:配置文件名
  • codermast/redis:latest:导入的镜像名称

 

要注意的是,这里是对 Docker 容器进行导出,但是导出的结果是镜像的配置文件,通过该配置文件导入的也是 Docker 镜像。

强制删除容器

我们知道,当容器在运行的时候是无法直接删除的,需要先将容器先停止运行,随后才能删除该容器,那么能不能直接删除正在运行中的容器呢?

答案是可以的,我们只需要在其中加上 -f 的选项即可,代表 force 强制的意思。

docker rm -f b234f112186d
  • b234f112186d:为 正在运行 Docker 容器的 ID

 

清理停止的容器

在容器停止运行后,并不会自动被删除,需要手动清除。该指令一次性清除所有的停止状态的容器。

docker container prune

 

容器别名及操作

上述对容器的操作都是针对容器 ID,这个 ID 是随机的,为了方便起见,我们可以设置一个自定义的 name 来进行操作。仅需在指令中设置 name 选项即可。

docker run -d --name codermast-redis-001 redis:latest
  • codermast-redis-001:自定义的名称
  • redis:latest:镜像名称

 

容器错误日志

docker logs ...
  • 实时查看docker容器名为user-uat的最后10行日志

docker logs -f -t --tail 10 user-uat

  • 查看指定时间后的日志,只显示最后100行:

docker logs -f -t --since="2024-01-14" --tail=100 user-uat

  • 查看最近30分钟的日志:

docker logs --since 30m user-uat

  • 查看某时间之后的日志:

docker logs -t --since="2024-01-14T21:00:00" user-uat

  • 查看某时间段日志:

docker logs -t --since="2024-01-14T21:00:00" --until "2018-02-09T12:23:37" user-uat

  • 将错误日志写入文件:

docker logs -f -t --since="2024-01-14" user-uat | grep error >> logs_error.txt

Docker仓库

Docker 仓库是集中存放 Docker 镜像的地方。默认使用的仓库为 Docker Hub,也可以更改为自己的想使用的仓库。类似于 Github 的仓库,只不过 Github 管理的是代码,Docker Hub 管理的是 Docker 镜像。

这里以 Docker Hub 为例进行说明。

  1. 登录仓库
docker login
  1. 将准备好的镜像推送至仓库
docker push codermast/redis:latest
  • codermast/redis:latest:Docker 镜像名
  • 23
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Docker Harbor是一个开源的企业级容器镜像仓库,它可以帮助用户管理和分发Docker镜像。通过搭建Docker Harbor仓库,用户可以自己创建和维护私有的镜像仓库,并使用https认证方式进行安全访问。 要搭建Docker Harbor仓库,首先需要下载和安装Docker Compose工具。可以使用以下命令下载和安装Docker Compose: ``` curl -L https://github.com/docker/compose/releases/download/1.21.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose chmod +x /usr/local/bin/docker-compose ``` 接着,可以使用以下命令检查Docker Compose是否安装成功: ``` docker-compose -v ``` 下载完Docker Compose后,需要维护和管理Harbor仓库。首先,需要下载registry镜像并创建本地私有仓库。可以使用以下命令下载registry镜像: ``` docker pull registry ``` 接着,在daemon.json文件中添加私有镜像仓库地址。可以使用以下命令编辑daemon.json文件: ``` vim /etc/docker/daemon.json ``` 并在文件中添加如下内容: ``` { "registry-mirrors": ["https://3c7tpzyf.mirror.aliyuncs.com"], "insecure-registries": ["192.168.122.10:5000"] } ``` 然后,重启Docker服务以使更改生效: ``` systemctl restart docker.service ``` 最后,使用以下命令运行registry容器来启动私有仓库: ``` docker run -itd -v /data/registry:/var/lib/registry -p 5000:5000 --restart=always --name registry registry:latest ``` 以上就是搭建Docker Harbor仓库的过程。通过这个仓库,您可以方便地管理和分发Docker镜像。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [docker-harbor2.4.2-https私有仓库-有验证和web](https://download.csdn.net/download/qq_34953582/87952076)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Docker私有仓库与Harbor](https://blog.csdn.net/weixin_48861962/article/details/121726836)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

友人和他的朋友们

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值