启动docker

docker run

查看版本

docker version

查看本地镜像

docker images

直接列出镜像结果,并且只包含镜像ID和仓库名:

image ls 就是 images

docker image ls --format "{{.ID}}: {{.Repository}}"

以表格等距显示,并且有标题行,和默认一样,不过自己定义列:

不要打错单词了

docker image ls --format "table {{.ID}}\t{{.Repository}}\t{{.Tag}}"

下载镜像

docker pull

例如: docker pull busybox

docker pull [选项] [Docker Registry 地址[:端口号]/] 仓库名[:标签]

具体的选项可以通过 docker pull --help 命令看到,这里我们说一下镜像名称的格式。

Docker 镜像仓库地址:地址的格式一般是 [:端口号]。默认地址是 Docker Hub。

仓库名:如之前所说,这里的仓库名是两段式名称,即 /。对于 Docker Hub,如果不给出用户名,则默认为 library,也就是官方镜像。

比如: docker pull ubuntu:16.04

进入shell命令

docker run -i -t $IMAGE /bin/bash

$IMAGE是镜像的名字,不能是容器的名字或者ID

-t:在新容器内指定一个伪终端或终端。

-i:允许你对容器内的标准输入 (STDIN) 进行交互。

docker run -it --rm ubuntu bash

-it:这是两个参数,一个是 -i:交互式操作,一个是 -t 终端。我们这里打算进入 bash 执行一些命令并查看返回结果,因此我们需要交互式终端。

--rm:这个参数是说容器退出后随之将其删除。默认情况下,为了排障需求,退出的容器并不会立即删除,除非手动 docker rm。我们这里只是随便执行个命令,看看结果,不需要排障和保留结果,因此使用 --rm 可以避免浪费空间。

ubuntu::这是指用 ubuntu 镜像为基础来启动容器。

bash:放在镜像名后的是命令,这里我们希望有个交互式 Shell,因此用的是 bash。

列出所有的容器

docker ps -a[-l]

如果只是docker ps则是列出当前运行的容器

列出容器的配置

docker inspect IMAGE_ID

IMAGE_ID可以通过docker ps -l命令查看到。

给容器重命名

docker run --name=container01-i -t ubuntu /bin/bash

ubutun是指的镜像,container01指的是重命名的名字

重命名后,使用docker ps -l列出所有容器时,在最后一列的NAMES中显示出来

重新启动停止的命令

docker start [-i] NAMES

NAMES是容器的名字,或者是容器的ID

每次使用镜像启动时都会创建一个容器,使用该命令时就相当于使用之前创建过的容器不会再次创建了。

如果需要打开交互终端,需要使用 -i ,但不需要加上 -t

注意的是,可能不会自动显示命令终端,所以还需要敲击回车键。

删除停止的容器

docker rm NAMES

只能用来删除停止的容器,正在运行的容器不可删除

NAMES可以是名字,也可以是ID

守护式容器进入方式

首先创建一个容器

docker run -i -t ubuntu /bin/bash

然后使用ctrl + p 和 ctrl + q的组合键,即按住ctrl键然后按P和Q,而不是直接使用exit命令来退出了

使用docker ps可以看到上面的容器还是运行着的

重新进入运行中的容器

docker attach NAMES

NAMES可以是容器的NAMES或者ID

启动守护式容器(重要方式)

docker run -d 镜像名

使用这种方式可以替代上面那段中提到的方式。

纠正:如果只是使用docker run -d 镜像名命令无法创建守护式容器,还是需要使用

docker run -it -d ubuntu /bin/bash才行,加上 -d

使用docker ps可以看到刚启动的容器在后台运行

查看容器日志

docker logs [-f] [-t] [--tail] 容器名

-f --follows=true | false 默认为false

-t --timestamp=true | false 默认为false

--tail="all"

-f: 一直跟踪日志的变化并返回结果

-t: 在返回的结果上加上时间戳

--tail: 在结尾上返回多少数量的日志,默认为all,返回所有的日志

例如使用该命令

docker run --name dc01 -d ubuntu /bin/sh -c "while true; do echo hello world; sleep 1; done"

--name表示将该容器命名为dc01

在该容器中,一直打印hello world

(1) docker logs dc01 会将所有日志打印出来,每一行只会显示 hello world,不会自动更新

(2) docker logs -t dc01 在(1)的基础上,在每一行前面加上时间戳

(3) docker logs -tf dc01 在(2)的基础上,会隔一秒自动多打印一句 hello world,自动更新

(4) docker logs -tf --tail 10 dc01 会从底部开始,取出10条log,并且会自动更新log,如果--tail的值为0,就只会打印最新的日志

查看容器内的进程

docker top 容器名

在运行中的容器中启动新的进程

docker exec [-d] [-i] [-t] 容器名 [COMMAND][ARGS]

之前的dc01容器没有停止,在后台运行

执行这条命令

docker exec -i -t dc01 /bin/bash,使用ctrl+ p 和 ctr + q 让容器称为守护式容器

然后通过docker top dc01可以看到容器中多了一个进程

停止守护式容器

docker stop 容器名

docker kill 容器名

stop命令是发送一条命令给容器,等待容器的停止

kill命令直接停止容器

查看端口映射

docker post 容器名

查看镜像详细信息

docker inspect 镜像名

删除镜像

docker rmi [OPTIONS] 镜像名 [IMAGE...]

如果使用docker rmi ubuntu:14.04删除镜像的话,可能只是删除对应标签,可以使用

docker rmi 镜像ID来删除镜像

搜索镜像

docker search [OPTIONS] TERM

--automated=false # 只会显示自动化构建的镜像

--no-trunc=false # 如果为True,将会显示完整的信息

-s, --stars=0 # 限定最小星级

一次最多返回25个结果。

例如,docker search ubuntu -s 3

拉取镜像

docker pull [OPTIONS] NAME[:TAG]

-a, --all-tags=false # 是否下载所有搜索到的版本

设置使用国内的镜像加速网站

http://624869e7.m.daocloud.io

修改文件vim /etc/default/docker,加入语句

DOCKER_OPTS = "--registry-mirror=http://624869e7.m.daocloud.io"

重启docker

sudo service docker restart

推送镜像

docker push 镜像名

删除所有的image

docker rmi -f $(docker images -qa)

后台程序机制

docker run -d centos

问题,使用上面的命令后, 会发现启动后的容器已经退出了。

这个问题很需要,需要说明一下:Docker容器后台运行,就必须要有一个前台进程。

容器运行的命令如果不是那些一直挂起的命令,例如top,tail等,是会自动退出的。

这是docker的机制问题,比如web容器,已nginx为例,正常情况下,配置启动服务只需要响应的service即可,例如service nginx start。但是这样做的话,nginx为后台模式运行,就导致docker前台没有运行的应用,这样的容器后台启动后悔立即自杀,因为他觉得无事可做。

最佳的解决方案是,将要运行的程序以前台进程的形式运行。

进入正在运行的容器并以命令行交互

docker exec -it 容器ID /bin/bash

docker attach 容器ID

这两个命令的不同,attach是直接进入容器,不会启动新的进程;exec打开新的终端,并可以启动新的进程。

例如,使用exec可以执行这种命令:

docker exec -t mycentos ls -l /tmp

会在mycentos容器内部使用ls -l /tmp命令,并将结果返回到docker上,而不需要到容器内部去执行命令了。

docker启动容器几个重要的命令

docker run --name=mycentos centos会创建一个叫mycentos的centos容器,该命令只会创建容器不会运行

docker run -d --name=mycentos2 centos会创建一个在后台运行的容器,但由于docker机制(见上面解释),会立即杀死,所以当使用docker ps查看时,也没有在后台运行

docker run -it --name=mycentos3和docker run -it --name=mycentos4 /bin/bash都创建一个容器后,会打开容器的shell界面,可以使用ctrl + p和ctrl + q将容器放到后台进程去

docker run --name=mycentos5 /bin/bash跟docker run --name=mycentos centos命令效果一样,后面的/bin/bash不生效

进入运行中的容器

docker start mycentos3不会进入shell界面

docker start -i mycentos3会进入容器的shell界面

docker attach mycentos3会进入容器的shell界面

docker exec -it mycentos3 /bin/bash可以进入容器的shell界面,会创建一个新的进程(即打开一个新的shell终端)

docker exec -it mycentos3不会进入

启动已创建但未运行的容器

docker start mycentos,需要注意一个很让人困惑的问题,mycentos从来没有启动过后者进入后台进程过,无法使用该命令启动;但mycentos3已经启动过但使用exit退出后(或者使用stop,kill命令杀死容器进程),都是可以使用该命令正常启动的,很困惑的一个问题,待解。

从docker容器复制文件到linux系统

docker cp 容器名(容器ID):/tmp/yum.log(文件具体路径) /home/flynngod(目的路径)

从宿主机复制文件到docker容器

docker cp cp.txt(系统文件路径) 容器名(容器ID):/tmp(容器文件路径)

Logo

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

更多推荐