Docker镜像与容器命令 专题

docker的工作流程图:

至少需要配备三样东西去使用docker容器:

Docker 主机:Docker容器将会在上面运行的Linux虚拟主机。.
Docker 镜像: 类似于运行在vm虚拟机上的iso镜像,但它们是高度精简的版本。所有已经存在于docker主机上的多余的包或库都会被移除掉。
Docker 容器:Docker镜像的快照,你可以启动、停止、修改它们,或者将它们作为另一个镜像来发布。

Docker是一个开源的引擎,可以轻松的为任何应用创建一个轻量级的、可移植的、自给自足的容器。开发者在笔记本上编译测试通过的容器可以批量地在生产环境中部署,包括VMs(虚拟机)、bare metal、OpenStack 集群和其他的基础应用平台。 
Docker通常用于如下场景:
web应用的自动化打包和发布;
自动化测试和持续集成、发布;
在服务型环境中部署和调整数据库或其他的后台应用;

从头编译或者扩展现有的OpenShift或Cloud Foundry平台来搭建自己的PaaS环境。

一、镜像相关命令

1、获取镜像

 

[plain] view plain copy

 

 

  1. sudo docker pull ubuntu:12.04  

 

 

2、列出本地镜像

 

[plain] view plain copy

 

 

  1. sudo docker images  

 

 

在列出信息中,可以看到几个字段信息

来自于哪个仓库,比如 ubuntu
镜像的标记,比如 14.04
它的 ID 号(唯一)
创建时间
镜像大小
其中镜像的 ID 唯一标识了镜像,注意到 ubuntu:14.04 和 ubuntu:trusty 具有相同的镜像 ID,说明它们实际上是同一镜像。
TAG 信息用来标记来自同一个仓库的不同镜像。例如 ubuntu 仓库中有多个镜像,通过 TAG 信息来区分发行版本,例如 10.04、12.04、12.10、13.04、14.04 等。例如下面的命令指定使用镜像 ubuntu:14.04 来启动一个容器。

3、创建镜像

 

方法一:

 

[plain] view plain copy

 

 

  1. docker commit  

方法二:

 

[plain] view plain copy

 

 

  1. dockerFile  

 

4、移除本地镜像

[plain] view plain copy

 

 

  1. 可以使用 docker rmi 命令。注意 docker rm 命令是移除容器。  

*注意:在删除镜像之前要先用 docker rm 删掉依赖于这个镜像的所有容器。

5、存出和载入镜像
存出镜像
如果要导出镜像到本地文件,可以使用 docker save 命令。

6、载入镜像

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

[plain] view plain copy

 

 

  1. sudo docker load --input ubuntu_14.04.tar  

[plain] view plain copy

 

 

  1. $ sudo docker load < ubuntu_14.04.tar  

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

 

 

二、容器相关命令

1、启动容器

启动容器有两种方式,一种是基于镜像新建一个容器并启动,另外一个是将在终止状态(stopped)的容器重新启动。

因为 Docker 的容器实在太轻量级了,很多时候用户都是随时删除和新创建容器。所需要的命令主要为 docker run。
(1)新建并启动

下面的命令则启动一个 bash 终端,允许用户进行交互。

 

[plain] view plain copy

 

 

  1. sudo docker run -t -i training/sinatra /bin/bash  

 

其中,-t 选项让Docker分配一个伪终端(pseudo-tty)并绑定到容器的标准输入上, -i 则让容器的标准输入保持打开。也可以合并起来写

 

[plain] view plain copy

 

 

  1. sudo docker run -ti ubuntu:14.04 /bin/bash  

 

可见,容器中仅运行了指定的 bash 应用。这种特点使得 Docker 对资源的利用率极高,是货真价实的轻量级虚拟化。不加-t -i的话,执行完就退出容器例如,下面的命令输出一个 “Hello World”,之后终止容器。

[plain] view plain copy

 

 

  1. sudo docker run ubuntu:14.04 /bin/echo 'Hello world'  

这跟在本地直接执行 /bin/echo 'hello world' 几乎感觉不出任何区别。

[plain] view plain copy

 

 

  1.   

 

在交互模式下,用户可以通过所创建的终端来输入命令,例如

如果,只想让容器在后台运行呢?那就看下面的吧!

(2)守护态运行更多的时候,需要让 Docker 容器在后台以守护态(Daemonized)形式运行。此时,可以通过添加 -d 参数来实现。例如下面的命令会在后台运行容器。

 

容器启动后会返回一个唯一的 id,也可以通过 docker ps 命令来查看容器信息。

 

然后使用

 

[plain] view plain copy

 

 

  1. docker attach 容器name  

就可以进入容器交互界面
容器name可以通过以下获得

 

 

[plain] view plain copy

 

 

  1. docker ps -a   

如进入上面的:

 

然后进入:

 

 

当利用 docker run 来创建容器时,Docker 在后台运行的标准操作包括:
检查本地是否存在指定的镜像,不存在就从公有仓库下载
利用镜像创建并启动一个容器
分配一个文件系统,并在只读的镜像层外面挂载一层可读写层
从宿主主机配置的网桥接口中桥接一个虚拟接口到容器中去
从地址池配置一个 ip 地址给容器
执行用户指定的应用程序
执行完毕后容器被终止

(3)启动终止的容器

可以利用 docker start + 容器ID,命令,直接将一个已经终止的容器启动运行。

先找到要启动容器的id

 

[plain] view plain copy

 

 

  1. docker ps -a  

 

Exited表示的就是终止的。然后使用

 

[plain] view plain copy

 

 

  1. docker start b3f9d3239bed   

 

上面我以后台运行的方式启动了两个新的容器

这是以后台运行的方式来执行的,那怎样才能再进入容器呢?可以用docker attact +容器name

先通过docker ps -a 取得正在运行的容器名字,然后

 

[plain] view plain copy

 

 

  1. docker attach goofy_mclean  

 

如下:

容器的核心为所执行的应用程序,所需要的资源都是应用程序运行所必需的。除此之外,并没有其它的资源。可以在伪终端中利用 ps 或 top 来查看进程信息。

(4)退出container但是保持运行

默认情况下,如果使用ctrl-d退出container,那么container也会stop,按ctrl-p ctrl-q可以退出到宿主机,而保持container仍然在运行.然后要进入再使用docker attach

 

2、停止容器

输入exit或ctrl+d

3、获取容器信息

要获取容器的输出信息,可以通过 docker logs 命令。

 

[plain] view plain copy

 

 

  1. docker logs 容器name  

 

4、在容器中安装新的程序

下一步我们要做的事情是在容器里面安装一个简单的程序(ping)。我们之前下载的tutorial镜像是基于ubuntu的,所以你可以使用ubuntu的apt-get命令来安装ping程序:apt-get install -y ping。
备注:apt-get 命令执行完毕之后,容器就会停止,但对容器的改动不会丢失。

5、保存对容器的修改
当你对某一个容器做了修改之后(通过在容器中运行某一个命令),可以把对容器的修改保存下来,这样下次可以从保存后的最新状态运行该容器。docker中保存状态的过程称之为committing,它保存的新旧状态之间的区别,从而产生一个新的版本。或者当结束后,我们使用 exit 来退出,现在我们的容器已经被我们改变了,使用 docker commit 命令来提交更新后的副本。

先取得修改后的容器ID

保存容器,实际上就是保存成了一个新的镜像

 

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

 

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

 

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

 

6、删除容器

可以使用 docker rm 来删除一个处于终止状态的容器。 例如

 

如果要删除一个运行中的容器,可以添加 -f 参数。Docker 会发送 SIGKILL 信号给容器。

 

7、检查运行中的容器

使用docker ps命令可以查看所有正在运行中的容器列表,使用docker inspect命令我们可以查看更详细的关于某一个容器的信息。查找某一个运行中容器的id,然后使用docker inspect命令查看容器的信息。可以使用镜像id的前面部分,不需要完整的id。

备注:

删除命令汇总

 

docker images往往不知不觉就占满了硬盘空间,为了清理冗余的image,可采用以下方法:

1.进入root权限

sudo su

2.停止所有的container,这样才能够删除其中的images:

docker stop $(docker ps -a -q)

如果想要删除所有container的话再加一个指令:

docker rm $(docker ps -a -q)

3.查看当前有些什么images

docker images

4.删除images,通过image的id来指定删除谁

docker rmi <image id>

想要删除untagged images,也就是那些id为<None>的image的话可以用

docker rmi $(docker images | grep "^<none>" | awk "{print $3}")

要删除全部image的话

docker rmi $(docker images -q)

http://blog.csdn.net/evankaka/article/details/49866265

當以Dockerfile掛在主機上的目錄是出現oci runtime error

或在Docker Share Drive分享主機磁碟機出現Firewall Detected. A firewall is blocking file Sharing between Windows and the containers.

出現這個現象在Docker for Windows上可以怎樣做?

這個問題在不同的Docker for Windows版本都有可能出現, 而我當前版本是1.13.0 (9861)

問題出現後第二天已經又有1.13.0-Beta38可以更新了

在我的一台Windows 10裡一直都有分享主機磁碟機來做Share Drive給Docker Container使用

有一天當我在測試Dockerfile時意外出現一個oci runtime error錯誤

這時在docker-compose.yml只要不用Volume把host和container的儲存位置對映就能繼續下去

找了一下原因, 重新檢查Share Drive 設定時, 正當想要重新設計Share Drive時

出現了一個有關防火牆阻礙分享磁碟機的錯誤訊息

錯誤訊息明顯地指出是防火牆的問題

Github上有不少關於這個錯誤訊息的討論, 而這應該是Docker for Windows獨有的

但在不同的版本上雖然錯誤訊息是一樣的但原因和解決的辦法卻不同

https://github.com/docker/for-win/issues/114

https://github.com/docker/for-win/issues/355

而我最後也能解決問題, 這裡列舉一些動作樣同樣出現問題的人可以試試

1. 關閉防火牆

如同錯誤訊息所示, 我們應該先排除是防火牆阻擋了些甚麼

如果你關閉了防火牆後就正常運作了, 請重新檢查DockerSmbMount這個Docker安裝時設定的防火牆規則有沒有存在

但Github上通常都說如果真的關閉防火牆就能解決的話, 就只能繼續關閉防火牆才能繼續等待更新文件.

 

2. 重新分享磁碟機

Docker Setting裡沒有清除分享的功能, 那個分享的勾勾可以使使消掉再Apply

但我的情況是反勾了都沒有反應, 如果你鍵入net share, 你仍然會見到C$在表列當中

你要以Administrator身份開啟Powershell , 鍵入Net share c$ /delete  (假設你是分享了C:\ )

之後再試試在Docker裡分享一次磁碟機看看有沒有成功.

 

3. 重設Docker使用的分享用帳號

Docker Shared Drive版面上有"Reset Credentials"的功能

我最後是用這個方式解決問題的, 但我們要先建立一個帳號來使用

開啟Computer Management, 在User選擇New User

建立一個普通使用者帳號, 如dockershare

回到Shared Drives, 按Reset credentials
輸入你剛剛建立的帳號密碼

再到Reset頁選擇Restart Docker, 等待Docker重啟後, 我到這裡就解決問題了


這個問題從2016年中就間斷地出現在某些Docker for Windows版本上

希望這篇文章可以幫助到其他遇到問題的朋友

https://dotblogs.com.tw/swater111/2017/01/26/101009
时间: 2024-09-16 22:07:08

Docker镜像与容器命令 专题的相关文章

深入了解docker(docker镜像、容器、仓库的基本概念)_docker

本文重点给大家介绍docker镜像.容器.仓库的基本概念的知识. Docker概念 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化.容器是完全使用沙箱机制,相互之间不会有任何接口. 镜像 Docker 镜像就是一个只读的模板. 例如:一个镜像可以包含一个完整的 CentOS 操作系统环境,里面仅安装了 httpd或用户需要的其它应用程序. 镜像可以用来创建 Docker 容器. Dock

docker 镜像与容器存储目录结构精讲

docker 镜像与容器存储目录结构精讲 很多朋友在初学 docker 的时候非常迷茫,不清楚 docker 是怎样的一种存储方式,并且也不清楚 docker 到底存储在什么地方.其实 docker 的镜像与容器都存储在 /var/lib/docker 下面,那么基于不同的系统又有不同的存储方式,在 ubuntu 下面存储方式为 AUFS:在 Centos 下面存储方式又是 device mapper,下面我们先来看一下 /var/lib/docker 目录,分别有三个阶段,看看在不同阶段都新增

Docker 镜像、容器、仓库的概念及应用详解_docker

Docker 镜像.容器.仓库的概念 Docker镜像 Docker镜像(Image)类似于虚拟机的镜像,可以将他理解为一个面向Docker引擎的只读模板,包含了文件系统. 例如:一个镜像可以完全包含了Ubuntu操作系统环境,可以把它称作一个Ubuntu镜像.镜像也可以安装了Apache应用程序(或其他软件),可以把它称为一个Apache镜像. 镜像是创建Docker容器的基础,通过版本管理和增量的文件系统,Docker提供了一套十分简单的机制来创建和更新现有的镜像.用户可以从网上下载一个已经

Docker 镜像和容器的区别详解_docker

 最近学习Docker,被Docker 的镜像和容器搞的晕头转向,索性上网查找相关资料并整理下彻底的理解这块内容,有需要的小伙伴可以看下,少走点弯路. Docker的镜像和容器的区别         一.Docker镜像 要理解Docker镜像和Docker容器之间的区别,确实不容易. 假设Linux内核是第0层,那么无论怎么运行Docker,它都是运行于内核层之上的.这个Docker镜像,是一个只读的镜像,位于第1层,它不能被修改或不能保存状态. 一个Docker镜像可以构建于另一个Docke

docker 深入了解镜像、容器、仓库等概念_docker

docker镜像.容器.仓库的基本概念 镜像 1.Docker 镜像就是一个只读的模板. 例如:一个镜像可以包含一个完整的 CentOS 操作系统环境,里面仅安装了 httpd或用户需要的其它应用程序. 2.镜像可以用来创建 Docker 容器. 3.Docker 提供了一个很简单的机制来创建镜像或者更新现有的镜像,用户甚至可以直接从其他人那里下载一个已经做好的镜像来直接使用. 容器 Docker 利用容器来运行应用. 容器是从镜像创建的运行实例.它可以被启动.开始.停止.删除.每个容器都是相互

两种方式创建docker镜像的启动容器时区别介绍(总结篇)_docker

Docker是建立在Linux内核基础上的,在目前的主流Linux系统中,都已经原生支持了Docker且使用体验也最好,当然,在Windows平台和MacOS系统中也支持Docker,只是需要使用类似Boot2Docker等虚拟化工具来提供Linux支持. 下面重点给大家介绍基于两种创建docker镜像的启动容器时区别,感兴趣的朋友可以跟着小编一起学习! 1.凡是用docker commit生成的镜像启动的时候可以加载一个启动自己应用的脚本,例如: docker run -d -P tomcat

理解Docker(2):Docker 镜像详细介绍_docker

本系列文章将介绍Docker的有关知识: (1)Docker 安装及基本用法 (2)Docker 镜像 (3)Docker 容器的隔离性 - 使用 Linux namespace 隔离容器的运行环境 (4)Docker 容器的隔离性 - 使用 cgroups 限制容器使用的资源 (5)Docker 网络 对于每个软件,除了它自身的代码以外,它的运行还需要有一个运行环境和依赖.不管这个软件是象往常一样运行在物理机或者虚机之中,还是运行在现在的容器之中,这些都是不变的.在传统环境中,软件在运行之前也

使用阿里云容器服务Jenkins实现持续集成和Docker镜像构建(updated on 2017.3.3)

持续集成作为敏捷开发重要的一步,其目的在于让产品快速迭代的同时,尽可能保持高质量.每一次代码更新,都要通过自动化测试来检测代码和功能的正确性,只有通过自动测试的代码才能进行后续的交付和部署.本文主要介绍如何将时下最流行的持续集成工具之一的Jenkins结合阿里云容器服务,实现自动测试和镜像构建推送. 接下来的演示是如何通过阿里云容器服务Jenkins实现自动测试和Docker镜像构建,实现高质量的持续集成.具体场景:每次代码提交到GitHub上的nodejs的项目中,阿里云容器服务Jenkins

容器镜像服务 Docker镜像的基本使用

容器镜像服务 Docker镜像的基本使用 快速开始!前往:容器镜像服务控制台 前言 Docker的使用条件和基础不再复述 Docker安装和Docker镜像下载的加速器文档在下方的"相关链接"中已经给出 Docker的镜像存储中心通常被称为Registry. 当您需要获取Docker镜像的时候,首先需要登录Registry,然后拉取镜像.在您修改过镜像之后,您可以再次将镜像推送到Registry中去. Docker的镜像地址是什么?我们来看一个完整的例子.(以容器服务的公共镜像为例)r