容器技术Docker云计算实战 镜像操作大总结

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介:

Docker实战之镜像操作:

获取镜像:

docker pull NAME[:TAG]


root@doc-vm:~# docker pull hello-world

Using default tag: latest

latest: Pulling from library/hello-world

ca4f61b1923c: Pull complete

Digest: sha256:150f6d05b8898b79f55114991c01b89688a02dab6115e402b7855792a440caff

Status: Downloaded newer image for hello-world:latest


latest标签意味着这个镜像的内容会跟踪最新的非稳定版本而发步,内容是不稳定的。不要在生产环境中使用latest标签的镜像。


使用其他镜像源进行下载:

root@doc-vm:~# docker pull hub.c.163.com/public/ubuntu:14.04

14.04: Pulling from public/ubuntu

f4ab0b34ba6a: Pull complete

2f0787dc0bfe: Pull complete

54c427d77362: Pull complete

51e87d5424ff: Pull complete

5dfa314e7290: Pull complete

a3ed95caeb02: Pull complete

Digest: sha256:ffc2fc66f8e0bfa4b417b817054d3ebec130c8db44342b8fa394e25779633257

Status: Downloaded newer image for hub.c.163.com/public/ubuntu:14.04

pull命令支持的选项:

-a, --all-tags=true|false:是否获取仓库中的所有镜像,默认是否。


查看镜像信息:

docker images


root@doc-vm:~# docker images

REPOSITORY                    TAG                 IMAGE ID            CREATED             SIZE

nginx                         latest              9e7424e5dbae        5 days ago          108 MB

hello-world                   latest              f2a91732366c        7 days ago          1.85 kB

ubuntu                        latest              20c44cd7596f        10 days ago         123 MB

tomcat                        latest              11df4b40749f        13 days ago         558 MB

mysql                         latest              5709795eeffa        3 weeks ago         408 MB

busybox                       latest              6ad733544a63        3 weeks ago         1.13 MB

centos                        latest              d123f4e55e12        3 weeks ago         197 MB

hub.c.163.com/public/ubuntu   14.04               2fe5c4bba1f9        20 months ago       237 MB


images的子选项:

-a, --all=true|false:列出所有镜像文件,默认是否

--digest=true|false:列出镜像的数字摘要值,默认是否

-f,--filter=[]:过滤列出的镜像

--format="TEMPLATE":控制输出格式

--no-turnc=true|false:对输出结果中太长的部分是否进行截断,默认为是

-q,--quiet=true|false:仅仅输出ID信息,默认是否


使用tag命令添加镜像标签:

docker tag SOURCE_IMAGE[:TAG] TARGET_IMAGE[:TAG]

root@doc-vm:~# docker tag ubuntu:latest mysystem:latest

root@doc-vm:~# docker images

REPOSITORY                    TAG                 IMAGE ID            CREATED             SIZE

nginx                         latest              9e7424e5dbae        5 days ago          108 MB

hello-world                   latest              f2a91732366c        7 days ago          1.85 kB

mysystem                      latest              20c44cd7596f        10 days ago         123 MB

ubuntu                        latest              20c44cd7596f        10 days ago         123 MB

tomcat                        latest              11df4b40749f        13 days ago         558 MB

mysql                         latest              5709795eeffa        3 weeks ago         408 MB

busybox                       latest              6ad733544a63        3 weeks ago         1.13 MB

centos                        latest              d123f4e55e12        3 weeks ago         197 MB

hub.c.163.com/public/ubuntu   14.04               2fe5c4bba1f9        20 months ago       237 MB


实际上指向的是同一个文件,只是别名而已。


使用inspect命令查看详细信息:

docker inspect [OPTIONS] NAME|ID [NAME|ID...]


root@doc-vm:~# docker inspect ubuntu

[

    {

        "Id": "sha256:20c44cd7596ff4807aef84273c99588d22749e2a7e15a7545ac96347baa65eda",

        "RepoTags": [

            "mysystem:latest",

            "ubuntu:latest"

        ],

        "RepoDigests": [

            "ubuntu@sha256:cb67b69a3b83dc209418cf15dace1a2fe336e37ef6a972a00fb9e02a608a8184"

        ],

        "Parent": "",

        "Comment": "",

        "Created": "2017-11-17T21:59:25.014645802Z",

        "Container": "e5f1a9df75b86a5d803eaf6f3fed6a0f8ef5fbf15a6c5039df087e4348ed8171",

        "ContainerConfig": {

            "Hostname": "e5f1a9df75b8",

            "Domainname": "",

            "User": "",

            "AttachStdin": false,

            "AttachStdout": false,

            "AttachStderr": false,

            "Tty": false,

            "OpenStdin": false,

            "StdinOnce": false,

            "Env": [

                "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"

            ],

            "Cmd": [

                "/bin/sh",

                "-c",

                "#(nop) ",

                "CMD [\"/bin/bash\"]"

            ],

            "ArgsEscaped": true,

            "Image": "sha256:b5771e7d8dcc594b886dbdd6a9c3de60d45252ca657dfdff6e1d996728dfa2cd",

            "Volumes": null,

            "WorkingDir": "",

            "Entrypoint": null,

            "OnBuild": null,

            "Labels": {}

        },

        "DockerVersion": "17.06.2-ce",

        "Author": "",

        "Config": {

            "Hostname": "",

            "Domainname": "",

            "User": "",

            "AttachStdin": false,

            "AttachStdout": false,

            "AttachStderr": false,

            "Tty": false,

            "OpenStdin": false,

            "StdinOnce": false,

            "Env": [

                "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"

            ],

            "Cmd": [

                "/bin/bash"

            ],

            "ArgsEscaped": true,

            "Image": "sha256:b5771e7d8dcc594b886dbdd6a9c3de60d45252ca657dfdff6e1d996728dfa2cd",

            "Volumes": null,

            "WorkingDir": "",

            "Entrypoint": null,

            "OnBuild": null,

            "Labels": null

        },

        "Architecture": "amd64",

        "Os": "linux",

        "Size": 122792927,

        "VirtualSize": 122792927,

        "GraphDriver": {

            "Name": "aufs",

            "Data": null

        },

        "RootFS": {

            "Type": "layers",

            "Layers": [

                "sha256:788ce2310e2fdbbf81fe21cbcc8a44da4cf648b0339b09c221abacb4cd5fd136",

                "sha256:aa4e47c4511638484cd5d95eadd7a8e4da307375ba31ff50d47aa9065dce01e0",

                "sha256:b3968bc26fbd527f214f895aeef940a6930c62d853fe8b12bd479f0b53518150",

                "sha256:c9748fbf541d3e043521e165b015d45825de33c00a8acb037443cfbd0cb5e677",

                "sha256:2f5b0990636a87f1557d64ba39808dcd64031328b2a159c5805115b8e725bbbc"

            ]

        }

    }

]

返回的是Josn格式的信息,指定其中一项可以是:

root@doc-vm:~# docker inspect -f {{".Os"}} ubuntu

linux


搜索镜像:

docker search [OPTIONS] TERM

--automated-true|false:仅仅显示自动创建的镜像,默认是否

--no-trunc=true|false:输出信息不截断显示,默认是否

-s,--stare=X:仅仅显示评价为指定星级以上的镜像,默认是0,也就是输出所有的镜像。


root@doc-vm:~# docker search ubuntu

NAME                                                   DESCRIPTION                                     STARS     OFFICIAL   AUTOMATED

ubuntu                                                 Ubuntu is a Debian-based Linux operating s...   6868      [OK]

dorowu/ubuntu-desktop-lxde-vnc                         Ubuntu with openssh-server and NoVNC            146                  [OK]

rastasheep/ubuntu-sshd                                 Dockerized SSH service, built on top of of...   117                  [OK]

ansible/ubuntu14.04-ansible                            Ubuntu 14.04 LTS with ansible                   89                   [OK]

ubuntu-upstart                                         Upstart is an event-based replacement for ...   80        [OK]

neurodebian                                            NeuroDebian provides neuroscience research...   40        [OK]

ubuntu-debootstrap                                     debootstrap --variant=minbase --components...   32        [OK]

nuagebec/ubuntu                                        Simple always updated Ubuntu docker images...   22                   [OK]

tutum/ubuntu                                           Simple Ubuntu docker images with SSH access     19

1and1internet/ubuntu-16-nginx-php-phpmyadmin-mysql-5   ubuntu-16-nginx-php-phpmyadmin-mysql-5          18                   [OK]

... ...


使用docker history查看镜像历史:

镜像是由多个层组成的,查看每个层的具体内容。

root@doc-vm:~# docker history ubuntu

IMAGE               CREATED             CREATED BY                                      SIZE                COMMENT

20c44cd7596f        10 days ago         /bin/sh -c #(nop)  CMD ["/bin/bash"]            0 B

<missing>           10 days ago         /bin/sh -c mkdir -p /run/systemd && echo '...   7 B

<missing>           10 days ago         /bin/sh -c sed -i 's/^#\s*\(deb.*universe\...   2.76 kB

<missing>           10 days ago         /bin/sh -c rm -rf /var/lib/apt/lists/*          0 B

<missing>           10 days ago         /bin/sh -c set -xe   && echo '#!/bin/sh' >...   745 B

<missing>           10 days ago         /bin/sh -c #(nop) ADD file:280a445783f309c...   123 MB


删除镜像:

使用docker rmi删除镜像,命令格式:docker rmi IMAGE [IMAGE...]

如果镜像有多个标签,docker rmi命令只会删除该镜像的指定标签,并不会影响镜像文件,当只剩下一个标签的时候才会删除真正的镜像。


docker rmi ID [ID...]

首先会尝试删除所有指向该镜像的标签,然后删除该镜像的文件本身。

当基于该镜像的容器正在运行的时候,默认是无法删除的,可以使用-f参数强制删除。


创建镜像:

基于已经有的镜像创建镜像:

docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]

-a,--author="":作者信息

-c,--change=[]:提交的时候执行Dockerfile命令

-m,--message="":提交信息

-p,--pause=true:提交时暂停容器的运行

root@doc-vm:~# docker run -it ubuntu bash

root@6ea8cd52c3eb:/# touch test

root@6ea8cd52c3eb:/# exit

exit

root@doc-vm:~# docker ps -a

CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS                      PORTS               NAMES

6ea8cd52c3eb        ubuntu              "bash"              52 seconds ago      Exited (0) 30 seconds ago                       nervous_hoover

root@doc-vm:~# docker commit -m "Added a Docker image" -a "deepking" 6ea8cd52c3eb ubuntutest:1.0

sha256:4ef2ad9d1aea15766c612d3c0090ad6128f803ebb8f4a4b75005d90001dbc893

root@doc-vm:~# docker images

REPOSITORY                    TAG                 IMAGE ID            CREATED             SIZE

ubuntutest                    1.0                 4ef2ad9d1aea        7 seconds ago       123 MB

基于本地模板导入:

主要使用docker import [OPTIONS] file|url|-[REPOSITORY[:TAG]]

使用OpenVZ提供的模板;来创建,下载地址是:https://openvz.org/Download/template/precreated

root@doc-vm:~# cd Downloads/

root@doc-vm:~/Downloads# ll

total 705496

drwxr-xr-x  2 doc doc      4096 11月 29 12:33 ./

drwxr-xr-x 16 doc doc      4096 11月 29 12:13 ../

-rw-rw-r--  1 doc doc 111337720 11月 29 12:14 centos-6-x86-20170709.tar.xz

-rw-rw-r--  1 doc doc  67229480 11月 29 12:13 centos-6-x86-minimal-20170709.tar.xz

-rw-rw-r--  1 doc doc  69329732 11月 29 12:13 centos-7-x86_64-minimal-20170709.tar.xz

-rw-rw-r--  1 doc doc  81103335 11月 29 12:13 debian-6.0-x86-minimal.tar.gz

-rw-rw-r--  1 doc doc 155356791 11月 29 12:16 debian-6.0-x86.tar.gz

-rw-rw-r--  1 doc doc 181654531 11月 29 12:18 ubuntu-15.10-x86_64.tar.gz

-rw-rw-r--  1 doc doc  56375699 9月  14 17:13 VMwareTools-10.1.15-6627299.tar.gz

root@doc-vm:~# cat debian-6.0-x86-minimal.tar.gz | docker import - debian:6.0


存储和载入镜像:

root@doc-vm:~# docker save -o tomcat_latest.tar tomcat   # 存储镜像

root@doc-vm:~# ll

drwxr-xr-x 16 doc  doc       4096 11月 29 13:52 ./

drwxr-xr-x  3 root root      4096 11月 27 21:52 ../

-rw-------  1 root root 576676352 11月 29 13:52 tomcat_latest.tar

root@doc-vm:~# docker load --input tomcat_latest.tar     # 载入镜像

Loaded image: tomcat:latest 

上传镜像:

docker push NAME[:TAG] | [REGISTRY_HOST[:REGISTRY_PORT]/]NAME[:TAG]

第一次上传会提示登录。


 本文转自 棋帅小七 51CTO博客,原文链接:http://blog.51cto.com/xvjunjie/2045609

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
18天前
|
运维 持续交付 Docker
深入理解Docker容器化技术
深入理解Docker容器化技术
|
1天前
|
负载均衡 网络协议 算法
Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式
本文探讨了Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式,以及软件负载均衡器、云服务负载均衡、容器编排工具等实现手段,强调两者结合的重要性及面临挑战的应对措施。
13 3
|
1天前
|
开发框架 安全 开发者
Docker 是一种容器化技术,支持开发者将应用及其依赖打包成容器,在不同平台运行而无需修改。
Docker 是一种容器化技术,支持开发者将应用及其依赖打包成容器,在不同平台运行而无需修改。本文探讨了 Docker 在多平台应用构建与部署中的作用,包括环境一致性、依赖管理、快速构建等优势,以及部署流程和注意事项,展示了 Docker 如何简化开发与部署过程,提高效率和可移植性。
15 3
|
5天前
|
持续交付 开发者 Docker
探索容器化技术Docker及其在现代软件开发中的应用
探索容器化技术Docker及其在现代软件开发中的应用
|
10天前
|
监控 安全 网络安全
云计算与网络安全:探索云服务中的信息安全技术
【10月更文挑战第43天】本文将深入探讨云计算与网络安全的交汇点,重点分析云服务中的信息安全技术和策略。我们将从云计算的基础架构出发,逐步剖析网络安全的重要性,并介绍如何通过实施有效的安全措施来保护数据和应用程序。文章还将提供实用的代码示例,帮助读者更好地理解和应用这些安全技术。
26 4
|
10天前
|
运维 Kubernetes Cloud Native
云原生技术入门:Kubernetes和Docker的协同工作
【10月更文挑战第43天】在云计算时代,云原生技术成为推动现代软件部署和运行的关键力量。本篇文章将带你了解云原生的基本概念,重点探讨Kubernetes和Docker如何协同工作以支持容器化应用的生命周期管理。通过实际代码示例,我们将展示如何在Kubernetes集群中部署和管理Docker容器,从而为初学者提供一条清晰的学习路径。
|
13天前
|
存储 安全 网络安全
云计算与网络安全:云服务、网络安全、信息安全等技术领域
【10月更文挑战第40天】随着互联网技术的不断发展,云计算已经成为了现代社会中不可或缺的一部分。然而,云计算的普及也带来了一系列的安全问题。本文将探讨云计算与网络安全之间的关系,包括云服务、网络安全、信息安全等领域。我们将通过代码示例来展示如何保护云计算环境中的敏感信息和数据。最后,我们将总结云计算与网络安全之间的紧密联系,并展望未来的发展趋势。
|
14天前
|
云安全 安全 网络安全
云计算与网络安全:技术挑战与解决策略
【10月更文挑战第39天】随着云计算技术的飞速发展,网络安全问题也日益凸显。本文将探讨云计算环境下的网络安全挑战,并提出相应的解决策略。通过分析云服务模型、网络安全威胁以及信息安全技术的应用,我们将揭示如何构建一个安全的云计算环境。
|
15天前
|
云安全 安全 网络安全
云计算与网络安全:技术融合的未来之路
【10月更文挑战第38天】 在数字化浪潮中,云计算和网络安全成为支撑现代企业和个人数据安全的两大基石。本文将深入探讨云计算服务如何与网络安全技术相结合,保障信息安全,并分析面临的挑战及未来发展趋势。我们将通过实际案例,揭示云安全的最佳实践,为读者提供一条清晰的技术融合路径。
|
16天前
|
安全 网络安全 数据库
云计算与网络安全:技术融合的未来之路
【10月更文挑战第37天】本文将探讨云计算与网络安全的交汇点,揭示它们如何共同塑造信息安全的未来。我们将深入了解云服务的核心组件、网络安全的关键策略以及两者如何相互增强。通过分析当前的挑战和未来的趋势,本文旨在为读者提供一条清晰的路径,以理解并应对这一不断发展的技术领域。