当前位置:   article > 正文

Docker系列三:镜像(image)介绍与常用命令汇总_docker rm image

docker rm image

目录

一:什么是镜像

1.1: 联合文件系统(UnionFS)

1.2:docker镜像加载原理

1.3:分层的镜像

1.4:docker采用分层结构原因

1.5:docker特点

二:镜像从哪里来?

三:镜像与容器的关系

四:存储驱动

五:镜像的常用指令


一:什么是镜像

        镜像是一种轻量级,可执行的独立软件包,用来打包软件运行环境和基于运行环境开发的软件,它包含运行某个软件所需要的所有内容,包括代码,运行时 库、环境变量和配置文件,镜像 不包含 任何动态数据,其内容在构建之后也不会被改变。

        简单说,Docker镜像是一个不包含Linux内核而又精简的Linux操作系统,当于是一个 root 文件系统。        

1.1: 联合文件系统(UnionFS)

 Union文件系统是一种分层、轻量级并且高可用的文件系统。它支持对文件系统的修改作为一次提交来一层层叠加,同时可以将不同目录挂载到同一个虚拟文件系统下,Union文件系统是Docker镜像的基础。镜像可以通过分层来进行集成,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。

特点:一次同时加载多个文件系统,但从外面看起来看,只能看到个文件系统,联合加载会把各层文件系统叠加起来,这样最终的文件系统会包含所有底层的文件和目录。

1.2:docker镜像加载原理

        docker的镜像实际上由一层一层的文件系统组成,这种层级的文件系统UnionFs。

        bootfs(boot file system)主要包含BootLoader和kernel, BootLoader主要是引导加载kernel,linux刚启动时会加载bootfs文件系统(Docker镜像的底层就是bootfs)。

        这一层与我们典型的Linux/Unix系统是一样的,包含boot加载器和内核,当boot加载完成之后整个内核就在内存中了,此时内存的使用权已由bootfs转交给内核,此时系统也会卸载bootfs。

        rootfs(root file system) 在bootfs之上,包含的就是典型Linux系统中的/dev, /proc, /bin,/etc等标准目录和文件,rootfs就是各种不同的操作系统发现版,比如ubuntu, centos....

         对于一个精简的OS,rootfs可以很小,只需要包括最基本的命令,工具和程序库就可以了, 因为底层直接使用Host和kernel,自己只需要提供rootfs就可以了,由此可见不同的linux发行版,bootfs基本是一致的,rootfs会有差别,因此不同的发行版可以共用bootfs。

1.3:分层的镜像

我们pull一个镜像的时候,可以看到docker的镜像是一层一层的在下载。

 

1.4:docker采用分层结构原因

最大的一个好处就是“共享资源”

比如:有多个镜像都是从相同的base镜像构建而来,那么宿主机只需要保存一份base镜像就可以了,同时内存也只加载一份base镜像,就可以为所有容器服务。而且镜像的每一层是可以被共享的。

1.5:docker特点

Docker镜像都是只读的,当容器启动时,一个新的可写层被加载到镜像的顶部。这一层通常被称为“容器层”,“容器层”之下的都叫“镜像层”。

二:镜像从哪里来?

Docker Hub是由Docker公司负责维护的公共注册中心,包含大量的容器镜像,Docker工具默认是从公共镜像库下载镜像。

默认是国外的源,下载会很慢,建议配置为国内的镜像 参考文章Docker系列二:Centos安装Docker_wester的博客-CSDN博客

三:镜像与容器的关系

镜像(Image)和容器(Container)的关系,就像是面向对象程序设计中的 类 和 实例 一样(people= new People()),镜像是静态的定义,容器是镜像运行时的实体。

容器其实是在镜像的最上面加了一层读写层,在容器内的任何修改都会写到这个读写层。

容器可以被创建、启动、停止、删除、暂停等。

举例:镜像可以抽象为centos7的系统环境, 容器相当于安装centos7环境的主机

镜像存储在:/var/lib/docker/overlay2   centos7

        

四:存储驱动

Docker 目前支持的联合文件系统包括 OverlayFS, AUFS, Btrfs, VFS, ZFS 和 Device Mapper。

 aufs:ubuntu

devicemapper: centos

overlay 与 overlay2

其中overlay2性能最好

五:镜像的常用指令

  1. # 搜索镜像
  2. docker search 镜像名称
  3. -> 输出
  4. NAME :镜像名称
  5. DESCRIPTION :镜像描述
  6. STARS :用户评价,反应一个镜像的受欢迎程度
  7. OFFICIAL :是否为官方构建
  8. AUTOMATED :自动构建,表示该镜像由 Docker Hub 自动构建流程创建的。
  9. # 拉取镜像
  10. docker pull [选项] [Docker Registry 地址[:端口号]/]仓库名[:标签]
  11. -> 例如:docker pull centos:7
  12. # 列出本地镜像
  13. docker image ls 或者 docker images
  14. # 根据仓库名列出镜像
  15. docker image ls ubuntu
  16. # 删除本地镜像
  17. docker image rm [选项] <镜像1> [<镜像2> ...]
  18. -f 强制
  19. # 查看镜像历史
  20. docker history 镜像名称:tag 或 镜像ID
  21. # 查看镜像明细
  22. docker inspect 镜像名称:tag 或 镜像ID
  23. # 其他操作 docker image --help
  24. Commands:
  25. build 构建镜像来自Dockerfile
  26. history 查看镜像历史 docker image history nginx
  27. import [容器]导入容器文件系统tar归档文件创建镜像
  28. docker export 容器id > ng_container.tar
  29. docker image import ng_container.tar 仓库名:tag
  30. inspect 显示一个或多个镜像详细信息docker image inspect nginx
  31. load 加载镜像来自tar归档或标准输入
  32. docker image load < nginx:1.11.tar
  33. ls 列出镜像
  34. prune 移除未使用的镜像,没有被标记或被任何容器引用的。
  35. pull 从镜像仓库拉去镜像 docker image pull nginx:1.11
  36. push 推送一个镜像到镜像仓库
  37. rm 移除一个或多个镜像 docker image rm image1 image2
  38. docker image rm $(docker image ls -q redis)
  39. save 保存一个或多个镜像到一个tar归档文件
  40. docker image save nginx:1.11 > nginx:1.11.tar
  41. tag 穿件一个引用源镜像标记目标镜像
  42. docker img tag nginx:1.11 nginx_v1

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/80510?site
推荐阅读
相关标签
  

闽ICP备14008679号