Docker image 详解

docker images 是docker的三大组件之一

docker把下载的 images 存储到docker主机上,如果一个 image 不在主机上,docker会从一个镜像仓库下载,默认的仓库是  DOCKER HUB  公共仓库。

接下来将介绍更多关于docker images 的内容,包括:

使用和管理本地主机上的 images

创建一个基础的 images

上传 images 到docker hub (公共 images 仓库)

列出本地主机上已经存在的 images

1)使用docker images  显示本机上的 images

在列出信息中,

REPOSITORY:来自于哪个仓库,比如 docker.io/centos

TAG的标记,比如  latest

IMAGE ID:镜像它的 ID 号

CREATED:创建时间

SIZE:镜像的 SIZE

一个仓库可能有一个 images 的都个发行版,比如ubuntu,他们有 10.04 12.04 12.10 13.04 14.04,每个发行版的标记都不同,可以使用 tag 命令来指定 images

注:如果你不指定具体的发行版,比如仅使用ubuntu,那么docker会使用最新的发行版ubuntu:latest

提示:建议最好指定发行版,只有这样你才可以保证你真正使用的 image 是那个

2)获取 images

我们如何获取新的 images 呢?当我们启动容器使用的 image 不再本地主机上时,docker会自动下载他们。这很耗时,我们可以使用docker pull 命令来预先下载我们需要的 image 。下面的例子下载一个centos 镜像。


这样当我们使用这个 image 来启动容器的时候,它就可以马上启动了。

3)查找 images

docker的一个特点是很多人因为各种不同的用途创建了各种不同的 images 。它们都被上传到了docker hub 共有仓库上,我们可以在docker hub 的网站上来查找它们。使用docker search 命令。比如,当我们需要 ruby 和sinatra作为 web 应用程序的开发时,我们使用docker search  来pull搜索合适的image ,使用关键字sinatra

我们看到返回了很多包含sinatra的 images 。其中包括 image 名字、描述、星级(表示该 image 的受欢迎程度)、是否官方创建、是否自动创建。官方的 images 是stackbrew项目组创建和维护的,automated  资源允许你验证 image 的来源和内容。

到目前为止,我们看到了 2种 images  资源。比如ubuntu,被称为基础或则根镜像。这些基础镜像是docker公司创建、验证、支持、提供。他们往往使用一个单词作为他们的名字。还有一种类型,比如我们选择的 training/sinatra镜像。它是由docker的用户创建并维护的,你可以通过指定 image 名字的前缀来指定他们,比如 training 。

4)下载 images

现在我们指定了一个 image , training/sinatra,我们可以使用docker pull 命令来下载它

下载过程中,会输出获取镜像的每一层信息。

该命令实际上相当于#docker pull registry.hub.docker.com/ubuntu:12.04  命令,即从注册服

务器  registry.hub.docker.com  中的ubuntu仓库来下载标记为  12.04  的镜像。

有时候官方仓库注册服务器下载较慢,可以从其他仓库下载。从其它仓库下载时需要指定完整的仓库注册服务器地址。例如

#docker pull dl.dockerpool.com:5000/ubuntu:12.04

查看镜像文件docker images

看完整信息

当镜像下载成功后,你可以看到 12 位的 hash 值像 05188b417f30,这是下载完整的镜像的精简 ID,这些短的镜像 ID 是完整镜像 ID 的前 12 个字符--可以使用docker inspect 或者docker images  --no-trunc来获得完整的镜像 ID

5)创建我们自己的 images

别人的镜像虽然好,但不一定适合我们。我们可以对他们做一些改变,有 2 个方法:

1.第一个方法:使用docker commit  来扩展一个 image

先使用 image 启动容器,更新后提交结果到新的 image 。

注意:记住容器的 ID  ,稍后我们还会用到

在容器中添加mariadb-server应用。

当结束后,我们使用 exit 来退出,现在我们的容器已经被我们改变了

使用dockercommint命令来提交相应的副本。

其中, -m  来指定提交的说明信息,跟我们使用的版本控制工具一样; -a  可以指定更新的用户信息;之后是用来创建镜像的容器的 ID;最后指定目标镜像的仓库名和 tag 信息。创建成功后会返回这个镜像的 ID信息。

使用docker images  来查看新创建的镜像。

之后,可以使用新的镜像来启动容器

附件:通常直接使用网络yum下载应用都比较慢,有一个比较快的方法如下:

搭建一个yum环境

#yum环境
yum -y install httpd
sed ‘s/DocumentRoot "\/var\/www\/html"/DocumentRoot "\/mnt\/centos"/‘ -i /etc/httpd/conf/httpd.conf
sed ‘s/<Directory "\/var\/www\/html">/<Directory "\/mnt\/centos">/‘ -i /etc/httpd/conf/httpd.conf
mv  /etc/httpd/conf.d/autoindex.conf  /etc/httpd/conf.d/welcome.conf  /mnt/
#docker环境
mv  /etc/yum.repos.d/ * /mnt
vi  /etc/yum.repos.d/local.repo
[local]
name=local
baseurl=http://192.168.131.96(指向yum服务器ip)
enable=1
gpgcheck=0
#yum环境
Service httpd start
#docker环境
Exit
Docker ps -a

结果如下

2.第二个办法:从dockerfile来创建 image

使用docker commit  来扩展一个 image 比较简单,但它不容易在一个团队中分享它。我们使用docker build  来创建一个新的 image 。为此,我们需要创建一个dockerfile,包含一些如何创建我们的image 的指令。现在,我们来创建一个目录和一个dockerfile

内容如下:

Dockerfile基本的语法是

使用#来注释

FROM指令告诉 Docker 使用哪个镜像作为基础(docker使用哪个 image 源)

MAINTAINER是维护者的信息

RUN开头的指令会在创建中运行,比如安装一个软件包,在这里使用 yum来安装了一些软件

编写完成Dockerfile后可以使用docker build  来生成镜像。

其中  -t  标记来添加 tag,指定新的镜像的用户信息。“.”是Dockerfile所在的路径(当前目录),也可以替换为一个具体的Dockerfile的路径。

可以看到 build 进程在执行操作。它要做的第一件事情就是上传这个Dockerfile内容,因为所有的操作都要依据Dockerfile来进行。然后,Dockfile中的指令被一条一条的执行。每一步都创建了一个新的容器,在容器中执行指令并提交修改(就跟之前介绍过的docker commit  一样)。当所有的指令都执行完毕之后,返回了最终的镜像 id。所有的中间步骤所产生的容器都被删除和清理了。

*注意一个镜像不能超过 127 层

查看生成的镜像

从我们新建的 images 开启容器

还可以用docker tag  命令来修改镜像的标签。

3.第三个办法:从本地文件系统导入

要从本地文件系统导入一个镜像,可以使用openvz(容器虚拟化的先锋技术)的模板来创建:openvz的模板下载地址为http://openvz.org/Download/template/precreated

先下载了一个centos-6-x86_64.tar.gz的镜像,之后使用以下命令导入:

2.通过命令行

你可以通过使用命令行输入 docker login 命令来创建一个 Docker Hub 账号

#docker login

邮箱确认

一旦你填写完毕表格,请查看你的电子邮件,通过点击欢迎信息中的链接来激活您的账户。

基本思路:

首先注册docker的账户,然后使用docker login登录。
使用docker push可以将自己的镜像上传上去了

如果有其他的仓库,例如:

# docker push docker.sina.com.cn:5000/commit

6)用dcokerrmi移除本地 images

dockerrmi镜像名或镜像id

注意:在删除 images 之前要先用dockerrm删掉依赖于这个 images 的容器

7)存出和载入镜像

当需要把一台机器上的镜像迁移到另一台机器的时候,需要存出镜像与载入镜像。

存出镜像

如果要导出镜像到本地文件,可以使用docker save  命令。

载入镜像

可以使用docker load  从导出的本地文件中再导入到本地镜像库,例如

这将导入镜像以及其相关的元数据信息(包括标签等)

时间: 2024-10-06 00:46:06

Docker image 详解的相关文章

Docker网络详解

Docker网络详解 转载请注明来自:http://blog.csdn.net/wsscy2004 网络基础 Docker使用linux桥接,在主机虚拟一个docker0网络接口,在主机中运行命令查看: # List host bridges $ sudo brctl showbridge name bridge id STP enabled interfacesdocker0 8000.000000000000 no # Show docker0 IP address $ sudo ifcon

docker 命令详解

Docker是一个用了一种新颖方式实现的超轻量虚拟机,在实现的原理和应用上还是和VM有巨大差别,专业的叫法是应用容器(Application Container).(我个人还是喜欢称虚拟机) Docker应用容器相对于 VM 有以下几个优点: 启动速度快,容器通常在一秒内可以启动,而 VM 通常要更久 资源利用率高,一台普通PC 可以跑上千个容器,你跑上千个 VM 试试 性能开销小, VM 通常需要额外的 CPU 和内存来完成 OS 的功能,这一部分占据了额外的资源 因为VM 的 Hypervi

docker 操作命令详解

docker attach命令-登录一个已经在执行的容器 docker build 命令-建立一个新的image docker commit命令-提交一个新的image docker cp命令-将容器中的文件拷贝到主机上 docker daemon命令-docker运行可指定项详解 docker diff命令-较一个容器不同版本提交的文件差异 docker events命令-获取sever中的实时事件 docker export命令-导出一个容器 docker history命令-显示一个ima

Docker Dockerfile详解

dockerfike快速创建自定义的Docker镜像 一.目录 1.docker典型结构 2.指令介绍 3.创建docker镜像 二.结构 DockerFile分为四部分组成:基础镜像信.维护者信息.镜像操作指令和容器启动时执行指令.例如: #第一行必须指令基于的基础镜像 From ubutu #维护者信息 MAINTAINER docker_user [email protected] #镜像的操作指令 apt/sourcelist.list RUN apt-get update &&

docker命令详解

docker [OPTIONS] command Usage: docker [OPTIONS] COMMAND [arg...] docker daemon [ --help | ... ] docker [ -h | --help | -v | --version ] A self-sufficient runtime for containers. Options: --config=~/.docker             Location of client config files

搭建部署Docker容器详解实操

Docker 容器 :    容器是Docker又一核心的概念,简单来说,容器是独立运行的一个或一组应用,以及它们的运行态环境.对应的,虚拟机可以理解为模拟运行的一整套操作系统(提供了运行态环境和其他系统环境)和跑在上面的应用. 接下来具体介绍如何管理一个容器,包括创建.启动和停止等. 启动容器有两种方式:          (1.) 第一种是基于镜像新建一个容器并启动.   所需要的命令主要为docker run    实例:            -t:让docker分配一个为终端(pase

Docker入门详解

目录: Docker介绍 传统虚拟化与容器虚拟化的区别 Container的核心技术及相关概念 安装docker Docker镜像管理 Docker容器管理 Docker网络之端口映射 Docker存储之挂载目录 手动构建一个docker镜像 未完待续... 正文: 一.Docker介绍:   什么是docker?Docker是一个开源项目,诞生于2013年初,最初是dotCloud公司内部的一个业余项目.它基于Google公司推出的Go语言实现.项目后来加入了Linux基金会,遵从了Apach

Docker 容器详解

容器是 Docker 又一核心概念,简单的说,容器是独立运行的一个或一组应用,以及它们的运行态环境.对应的,虚拟机可以理解为模拟运行的一整套操作系统(提供了运行态环境和其他系统环境)和跑在上面的应用. 本章将具体介绍如何来管理一个容器,包括创建.启动和停止等. 启动容器有两种方式,一种是基于镜像新建一个容器并启动,另外一个是将在终止状态(stopped)的容器重新启动. 新建并启动 所需要的命令主要为docker run 下面的命令则启动一个 bash 终端,允许用户进行交互. -t 选项让 D

Docker Machine 详解

笔者在<Docker Machine 简介>一文中简单介绍了 Docker Machine 及其基本用法,但是忽略的细节实在是太多了.比如 Docker 与 Docker Machine 的区别?又如当我们执行 docker-machine create 命令时,Docker Machine 都做了哪些重要的事情使得我们可以远程操作 Docker daemon?这样的远程操作安全吗?本文将试图解读这些问题.注:本文的演示环境为 Ubuntu16.04. Docker 与 Docker Mach

Docker网络详解及pipework源码解读与实践

Docker作为目前最火的轻量级容器技术,有很多令人称道的功能,如Docker的镜像管理.然而,Docker同样有着很多不完善的地方,网络方面就是Docker比较薄弱的部分.因此,我们有必要深入了解Docker的网络知识,以满足更高的网络需求.本文首先介绍了Docker自身的4种网络工作方式,然后通过3个样例 -- 将Docker容器配置到本地网络环境中.单主机Docker容器的VLAN划分.多主机Docker容器的VLAN划分,演示了如何使用pipework帮助我们进行复杂的网络设置,以及pi