xsw222 发表于 2019-2-21 09:22:41

Docker images


[*]  Docker 码头工人
  Docker中镜像可理解为:应用程序的集装箱
[*]  Docker Images
    Docker镜像含有启动容器所需要的文件系统及其内容,因此,其用于创建并启动docker容器

      采用分层构建机制,最底层为bootfs,其之为rootfs

            bootfs:用于系统引导的文件系统,包括bootloader和kernel,容器启动完成后会被卸载以节约内存资源

            rootfs:位于bootfs之上,表现为docker容器的根文件系统;

                传统模式中,系统启动之时,内核挂载rootfs时会首先将其挂载为“只读”模式,完整性自检完成后将其重新挂载为读写模式;

                docker中,rootfs由内核挂载为“只读”模式,而后通过“联合挂载”技术额外挂载一个“可写”层;

    注意:当删除容器时,这个容器自有的“可写”层会一起被删除
    http://s1.运维网.com/images/20180804/1533361130192018.png
    镜像层级
      位于下层的镜像称为父镜像(parent image),最底层的称为基础镜像(base image)

      最上层为“可读写层”,其下的均为“只读”层;

    https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTme76-IhXka4BP63RccP_RaKJAKodk_Arp9mw9Y-GERZw7sQuY
    Aufs
      Advanced multi-layered unification filessystem:高级多层统一文件系统

      用于为Linux文件系统实现“联合挂载”;aufs是之前的UnionFS的重新实现,2006年由Junjiro Okajima开发;
      Docker最初使用aufs作为容器文件系统层,它目前仍作为存储后端之一来支持;aufs竞争产品是overlayfs,后者自从3.18版本开始被合并到Linux内核;

      Docker分层的镜像,除了aufs,docker还支持btrfs,devicemapper和vfs等

            在ubuntu系统下:docker默认使用Ubuntu的aufs;而在CentOS7上,使用的是devicemapper;


[*]  Docker Registry
    启动容器时,docker daemon会试图从本地获取相关的镜像;本地镜像不存在时,其将从Registry中下载该镜像并保存到本地;

    注意:Registry如果没有指定,只给了仓库名和tag,则默认使用的是Docker hub;如果指向别的Registry需要修改配置给明服务器地址
      除了Docker Hub还有其他镜像仓库,如:https://quay.io/
            http://s1.运维网.com/images/20180804/1533352855699170.png
    Registry用于保存docker镜像,包括镜像的层次结构和元数据
      用户可自建Registry,也可使用官方的Docker Hub

    Docker Registry分类

      Sponsor Registry:第三方的registry,供客户和Docker社区使用

      Mirror Registry:第三方的registry,只让客户使用

      Vendor Registry:由发布Dcoker镜像的供应商提供的registry

      Private Registry:通过设有防火墙和额外的安全层的私有实体提供的registry

    Registry

      由某特定的docker镜像的所有迭代版本组成的镜像仓库

      一个Registry中可以存在多个Repository

            Repository可分为“顶层仓库”和“用户仓库”

            用户仓库名称格式为“用户名/仓库名”

      每个仓库可以包含多个Tag(标签),每个标签对应一个镜像

    Index

      维护用户账户、镜像的检验以及公共命名空间的信息

      相当于为Registry提供了一个完成用户认证等功能的检索接口

    Docker Registry中的镜像通常由开发人员制作,而后推送至“公共”或“私有”Registry上保存,供其他人员使用,例如“部署”到生产环境

    http://s1.运维网.com/images/20180804/1533362082967354.png

[*]  Docker Hub

      功能:
            镜像仓库

            自动构建;web构子
            组织

            GitHub和Bitbucket
    http://s1.运维网.com/images/20180804/1533361750744164.png

[*]  制作镜像
    Dockerfile
    基于容器制作

    Docker Hub automated builds

    https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQxHqXtihJtZlZYjLIDFXIa7PA9_pBZatMX411kh0Rsa3XrJj0
基于容器制作容器
docker commit
docker commit CONTAINER ]
    --author, -a
    --pause, -p
    --message, -m
    --change, -c    简单示例1:让Busybox容器启动时就有index.html网页文件;

            使用docker commit命令

#docker run --name b1 -it busybox
WARNING: IPv4 forwarding is disabled. Networking will not work.
/ #
/ # mkdir -p /data/html
/ # echo "Busybox httpd server." > /data/html/index.html          注意:制作容器时让容器处理运行状态所以在另外一个终端执行:

#docker commit -p b1
sha256:db1dfc89367ed1899e85665d6c069e778d66a2cd590d969e761bed77b67cfa23
#docker image ls
REPOSITORY          TAG               IMAGE ID            CREATED             SIZE
                            db1dfc89367e      7 seconds ago       1.16MB    制作好的容器
nginx               alpine            36f3464a2197      10 days ago         18.6MB
busybox             latest            22c2dd5ee85d      2 weeks ago         1.16MB
redis               4.0-alpine          80581db8c700      3 weeks ago         28.6MB
centos            latest            49f7960eb7e4      2 months ago      200MB            可使用docker tag命令来给镜像打标签;一个镜像可打多个标签

[#docker tag db1dfc89367e liuyutang/httpd:v0.1-1
#docker image ls
REPOSITORY          TAG               IMAGE ID            CREATED             SIZE
liuyutang/httpd   v0.1-1            db1dfc89367e      3 minutes ago       1.16MB
nginx               alpine            36f3464a2197      10 days ago         18.6MB
busybox             latest            22c2dd5ee85d      2 weeks ago         1.16MB
redis               4.0-alpine          80581db8c700      3 weeks ago         28.6MB
centos            latest            49f7960eb7e4      2 months ago      200MB
#docker tag liuyutang/httpd:v0.1-1 liuyutang/httpd:latest
#docker image ls
REPOSITORY          TAG               IMAGE ID            CREATED             SIZE
liuyutang/httpd   latest            db1dfc89367e      5 minutes ago       1.16MB
liuyutang/httpd   v0.1-1            db1dfc89367e      5 minutes ago       1.16MB
nginx               alpine            36f3464a2197      10 days ago         18.6MB
busybox             latest            22c2dd5ee85d      2 weeks ago         1.16MB
redis               4.0-alpine          80581db8c700      3 weeks ago         28.6MB
centos            latest            49f7960eb7e4      2 months ago      200MB          删除标签

#docker image rm liuyutang/httpd:latest
Untagged: liuyutang/httpd:latest          启动制作好的容器;可以看到我们刚才写的页面文件存在;容器制作成功
#docker run --name t1 -it liuyutang/httpd:v0.1-1
WARNING: IPv4 forwarding is disabled. Networking will not work.
/ # ls /data/
html
/ # ls /data/html/
index.html
/ # cat /data/html/index.html
Busybox httpd server.
/ #      示例2:使用Busybox做为基础镜像,实现容器启动时默认运行httpd,并且在制作镜像时一起打标签;
      制作镜像:

#docker commit -a "liuyutang " -c 'CMD ["/bin/httpd","-f","-h","/data/html"]' -p b1 liuyutang/httpd:v0.2
sha256:f394f28026ff01f0bbdceb665b8e18a26c9a43a9c12cc57e4f895808f52e5f36
#docker image ls
REPOSITORY          TAG               IMAGE ID            CREATED             SIZE
liuyutang/httpd   v0.2                f394f28026ff      4 seconds ago       1.16MB
liuyutang/httpd   latest            db1dfc89367e      21 minutes ago      1.16MB
liuyutang/httpd   v0.1-1            db1dfc89367e      21 minutes ago      1.16MB
nginx               alpine            36f3464a2197      10 days ago         18.6MB
busybox             latest            22c2dd5ee85d      2 weeks ago         1.16MB
redis               4.0-alpine          80581db8c700      3 weeks ago         28.6MB
centos            latest            49f7960eb7e4      2 months ago      200MB      运行容器

#docker run --name t2 liuyutang/httpd:v0.2      查看容器

#docker container ls
CONTAINER ID      IMAGE                  COMMAND                  CREATED             STATUS            PORTS               NAMES
044d7516f77b      liuyutang/httpd:v0.2   "/bin/httpd -f -h /d…"   37 seconds ago      Up 36 seconds                           t2      我们可使用docker inspect命令来查看容器信息

#docker inspect t2      看到ip为172.17.0.2;可直接用curl命令来访问容器里的httpd服务;可以看到是我们自己做的页面

#curl 172.17.0.2
Busybox httpd server.      制作好的镜像可以共享到Docker Hub之上,前提是必须得有DockerHub账号,且镜像标签格式为

            “$DOCKER_USER_ID/IMAGE"   使用docker login命令登录成功后,即可使用docker push命令进行推送

            示例
#docker login
Login with your Docker ID to push and pull images from Docker Hub. If you don't have a Docker ID, head over to https://hub.docker.com to create one.
Username: liuyutang
Password:
WARNING! Your password will be stored unencrypted in /root/.docker/config.json.
Configure a credential helper to remove this warning. See
https://docs.docker.com/engine/reference/commandline/login/#credentials-store
Login Succeeded
#docker image push liuyutang/httpd
The push refers to repository
e1b0032bd40b: Pushed
8e9a7d50b12c: Mounted from library/busybox
latest: digest: sha256:2ba592789010f1349b8594c97015e10c49c7d75f1aeb36c7132b2525b1c64f82 size: 734
e1b0032bd40b: Layer already exists
8e9a7d50b12c: Layer already exists
v0.1-1: digest: sha256:2ba592789010f1349b8594c97015e10c49c7d75f1aeb36c7132b2525b1c64f82 size: 734
c0a38dc06799: Pushed
8e9a7d50b12c: Layer already exists
v0.2: digest: sha256:77fbb7f07a896404b232e879ef6b061d69a233d7388f37a39ba0ab4ea14ad722 size: 734


[*]  镜像的导入和导出
  将镜像文件导出为tar文件:
  
    docker save
Save one or more images to a tar archive (streamed to STDOUT by default)
docker save IMAGE     导出示例

#docker save -o myimages.gz liuyutang/httpd:v0.1-1 liuyutang/httpd:v0.2
#ls
192.168.30.27    elasticsearch-5.5.1.rpm    kibana-5.5.1-x86_64.rpmmyimages.gz
anaconda-ks.cfgfilebeat-5.5.1-x86_64.rpmlogstash-5.5.1.rpm 从tar文件导入镜像 :
docker load
Load an image from a tar archive or STDIN
docker load
--input, -i Read from tar archive file, instead of STDIN
--quiet, -qfalseSuppress the load output    导入示例

#docker load -i myimages.gz
8e9a7d50b12c: Loading layer1.378MB/1.378MB
c0a38dc06799: Loading layer   5.12kB/5.12kB
Loaded image: liuyutang/httpd:v0.2
e1b0032bd40b: Loading layer   5.12kB/5.12kB
Loaded image: liuyutang/httpd:v0.1-1
#docker images
REPOSITORY          TAG               IMAGE ID            CREATED             SIZE
liuyutang/httpd   v0.2                f394f28026ff      2 hours ago         1.16MB
liuyutang/httpd   v0.1-1            db1dfc89367e      2 hours ago         1.16MB    这种方式适用于测试环境



页: [1]
查看完整版本: Docker images