下面是自己的理解,可能不精准,但是非常有利于我自己理解和使用docker。这对于普通使用者来说足够了。

镜像和容器的区别类似于代码和进程。

镜像是我们写的代码,而容器则是运行这个代码发起的进程。

所以镜像以文件形式保存在硬盘中,可以独立存在。而容器是个进程,只能靠运行镜像而存在,没有能够脱离于镜像而存在的容器。

一份代码可以执行多次产生多个进程,而一个进程只能由确定的一份代码产生。同样的从一个镜像可以发起多个容器,而一个容器肯定只能从一个镜像产生。

有了这些基础的认知,我们再来看docker的一些命令就好理解了。

镜像命令

因为镜像就是文件(而且镜像是只读文件), 所以只有一些针对文件的操作:获取,列举,查找,删除,创建,

获取镜像: docker有官方的镜像库,很多著名的开源项目都把镜像放在这些官方镜像库中,这时候只需要写简单的镜像名称和tag就可以拉取下来,例如:

docker pull tensorflow/tensorflow:custom-op

docker pull 是从镜像库拉取镜像文件的命令,类似git pull 。 tensorflow是镜像名称,tensorflow:custom-op 是tag名称。tag可以理解成git中的分支。可以去docker官方库看tensorflow的镜像介绍:Docker Hub

当然也可以自己维护一个镜像库,这时候镜像的地址需要填写完整的地址。

列举镜像:

docker images

上面的命令可以列举电脑上所有的镜像,类似ls命令

 第一列是镜像名称,第二列是tag,第三列式镜像id,类似于git中的提交时的sha值,可以用于运行镜像生成容器。

查找镜像:

docker search xxxxx

 这个命令是从docker官方库中的查找镜像,不是在本地查找镜像。

删除镜像:

docker rmi xxxxx

删除镜像xxxxx

容器命令

容器的本质本质是一个进程,但如果只是使用,不去深究其中的原因,我们就把容器当成一个正在运行的虚拟机就好了。镜像就是这些虚拟机的操作系统镜像。

列举容器:

docker container ls [OPTIONS]

OPTIONS说明:

  • -a :显示所有的容器,包括未运行的。

  • -f :根据条件过滤显示的内容。

  • --format :指定返回值的模板文件。

  • -l :显示最近创建的容器。

  • -n :列出最近创建的n个容器。

  • --no-trunc :不截断输出。

  • -q :静默模式,只显示容器编号。

  • -s :显示总的文件大小。

因为容器是进程,该命令类似于linux的ps。运行的结果如下:

 containerid是容器号,类似于进程编码,image就是镜像名。command是运行容器时输入的命令。STATUS是容器的状态。name,运行容器时输入的容器名称。

还有一个类似的命令是

docker ps

 两个命令功能一模一样。

因为docker的命令越来越多,所以逐渐把container的命令统一成以 docker container 开始。

容器的运行与停止

docker container run 通过镜像生成一个新的容器

docker container run [OPTIONS] IMAGE [COMMAND] [ARG...]

option的参数无比的复杂,这里只介绍比较常用的用法

  • -a stdin: 指定标准输入输出内容类型,可选 STDIN/STDOUT/STDERR 三项;

  • -d: 后台运行容器,并返回容器ID;

  • -i: 以交互模式运行容器,通常与 -t 同时使用;

  • -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;

  • --name="name": 为容器指定一个名称;

command是对容器输入的命令(把容器看做一个虚拟机,这个是对虚拟机输入的命令)

例如:

docker run -it nginx:latest /bin/bash

这个是平时最常用的命令,通过镜像nginx:latest 生成一个新的容器,并且运行容器的终端。

docker container start :启动一个或多个已经被停止的容器

docker  container start container_id

 start和run的区别在于,run的时候都会新建一个容器,所以run后面只需要跟镜像名称,而不需要跟容器名。而start 的时候,是运行一个已经存在的容器,所以start后面跟一个container_id

docker  container restart :重启容器

docker container restart  container_id

查过很多资料,restart和start的区别在于文件系统的挂载,我没看懂,但是就使用来说,用start就行。

docker stop :停止一个运行中的容器

docker container stop container_id

docker container kill 

docker container kill container_id

杀死容器,和stop的区别直接看字面就能区分。stop,容器有序的结束,会有保存之类的操作。kill 直接杀死,暴力退出。所以建议用stop 而非kill。

容器的删除

docker container rm

docker container rm  container_id

删除已经存在的容器

容器的创建

docker container create [OPTIONS] IMAGE [COMMAND] [ARG...]

这个命令和run的区别是create创建容器,但是不会运行这个容器。run则创建后运行。

该命令的参数和run一致

在容器中运行命令

前面介绍了,我们通过run创建,运行一个容器并且进入其终端命令是

docker container run -it image /bin/bash。

那么对于一个已经存在容器我们想进入其终端的话就要用到exec命令了。

docker container exec [OPTIONS] CONTAINER COMMAND [ARG...]

OPTIONS说明:

  • -d :分离模式: 在后台运行

  • -i :即使没有附加也保持STDIN 打开

  • -t :分配一个伪终端

例如,对位于一个已经存在的容器,我们想进入其终端,则命令是

docker container exec -it container_id /bin/bash

连接正在运行的容器

docker container attach container_id

虽然官方讲解是可以共享一个容器,但是根据我的操作来看,单机情况下就是进入容器的终端。

容器的资源使用情况

docker stats [OPTIONS] [CONTAINER...]

退出容器终端

特别的,进入容器终端以后,如果通过ctrl + d ,或者exit退出终端,则会同时关闭容器。如果只想退出终端而不关闭容器则应该用ctrl + p + q

 docker的命令用一张图来总结:

其他 

当然,镜像和容器的关系肯定不是代码和进程那么简单,主要是容器并不是一个进程那么简单。否则一个容器就不能重复的启停。

对于同一个镜像的不同容器,我们创建,修改,删除文件和路径,都不会印象其他的容器的文件系统。

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐