启动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 <$images>
例如: docker pull busybox
docker pull [选项] [Docker Registry 地址[:端口号]/] 仓库名[:标签]
具体的选项可以通过 docker pull --help 命令看到,这里我们说一下镜像名称的格式。
- Docker 镜像仓库地址:地址的格式一般是 <域名/IP>[:端口号]。默认地址是 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
才行,加上 <strong>-d</strong>
使用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(容器文件路径)