docker操作命令整理

1.镜像

pull:镜像仓库中下载镜像

docker pull ubuntu

search:搜索镜像

docker search httpd

rmi:删除镜像

docker rmi <镜像名>

build:通过 Dockerfile 从零开始来创建一个新的镜像

docker build t runoob/centos:6.7 .

-t :指定要创建的目标镜像名

Dockerfile 文件所在目录,可以指定Dockerfile 的绝对路径

tag:为镜像添加一个新的标签

docker tag 860c279d2fec runoob/centos:dev

2.容器

run:运行指定的镜像,Docker 首先从本地主机上查找镜像是否存在,如果不存在,Docker 就会从镜像仓库 Docker Hub 下载公共镜像。

docker run itd ubuntu:16.04 /bin/bash

docker run d p 5000:5000/udp training/webapp python app.py

docker run it rm h host_ubuntu dns=114.114.114.114 dnssearch=test.com ubuntu

-d:让容器在后台运行

-P:将容器内部使用的网络端口随机映射到我们使用的主机上

-p : 是容器内部端口绑定到指定的主机端口。

–rm:容器退出时自动清理容器内部的文件系统。

-h HOSTNAME 或者 –hostname=HOSTNAME: 设定容器的主机名,它会被写到容器内的 /etc/hostname 和 /etc/hosts。

–dns=IP_ADDRESS: 添加 DNS 服务器到容器的 /etc/resolv.conf 中,让容器用这个服务器来解析所有不在 /etc/hosts 中的主机名。

–dns-search=DOMAIN: 设定容器的搜索域,当设定搜索域为 .example.com 时,在搜索一个名为 host 的主机时,DNS 不仅搜索 host,还会搜索 host.example.com

stop:停止容器

docker stop <容器 ID>

rm:删除容器

docker rm -f <容器 ID>

container prune:清理掉所有处于终止状态的容器

docker container prune

ps:确认容器运行情况

docker ps

logs:查看容器内标准输出

docker logs <容器 ID>

-f: 让 docker logs 像使用 tail -f 一样来输出容器内部的标准输出。

restart:重启docker容器

docker restart <容器 ID>

attach:进入运行的容器,退出会导致容器停止

docker attach <容器 ID>

exec:进入运行的容器,退出不会导致容器停止

docker exec <容器 ID/bin/bash

export:将容器导出到本地

docker export <容器 ID> > ubuntu.tar

import:将文件导入为镜像

docker import 文件 镜像名

port:查看指定 (ID 或者名字)容器的某个确定端口映射到宿主机的端口号

docker port <容器 ID>

top:查看容器内部运行的进程

docker top <容器 ID>

commit:创建容器的新镜像

docker commit m=“has update” a=“runoob” e318edb10161 runoob/ubuntu:v2

-m: 提交的描述信息

-a: 指定镜像作者

e318edb10161:容器 ID

runoob/ubuntu:v2: 指定要创建的目标镜像名

port:查看端口的绑定情况

docker port adoring_stonebraker 5000 network:Docker网络

create:创建一个新的 Docker 网络

docker network create d bridge testnet

-d:参数指定 Docker 网络类型,有 bridge、overlay。

run:运行一个容器并连接到新建的 test-net 网络,使用iputilsping中ping检测,使用 Docker Compose 来连接多个容器。

docker run itd name test1 network testnet ubuntu /bin/bash
docker run itd name test2 network testnet ubuntu /bin/bash

exit:退出终端

3.仓库

login:登录 docker hub 的账号
docker login
logout:退出账号
docker logout

Docker Dockerfile

通过 Dockerfile 文件来定制镜像,每行开头需要大写。

FROM:定制的镜像都是基于 FROM 的镜像,这里的 nginx 就是定制需要的基础镜像。后续的操作都是基于 nginx。
RUN:用于执行后面跟着的命令行命令。Dockerfile 的指令每执行一次都会在 docker 上新建一层。以 && 符号连接命令。
COPY:复制指令,从上下文目录中复制文件或者目录到容器里指定路径。

COPY [--chown=<user>:<group>] <源路径1>...  <目标路径>

[–chown=<user>:<group>]:可选参数,用户改变复制到容器内文件的拥有者和属组。

<源路径>:源文件或者源目录,这里可以是通配符表达式,其通配符规则要满足 Go 的 filepath.Match 规则。

<目标路径>:容器内的指定路径,该路径不用事先建好,路径不存在的话,会自动创建。

COPY hom* /mydir/

ADD:同COPY

  • ADD 的优点:在执行 <源文件> 为 tar 压缩文件的话,压缩格式为 gzip, bzip2 以及 xz 的情况下,会自动复制并解压到 <目标路径>。
  • ADD 的缺点:在不解压的前提下,无法复制 tar 压缩文件。会令镜像构建缓存失效,从而可能会令镜像构建变得比较缓慢。具体是否使用,可以根据是否需要自动解压来决定。

CMD:类似RUN,用于运行程序,但二者运行的时间点不同:

  • CMD 在docker run 时运行。
  • RUN 是在 docker build。

作用:为启动的容器指定默认要运行的程序,程序运行结束,容器也就结束。CMD 指令指定的程序可被 docker run 命令行参数中指定要运行的程序所覆盖。

注意:如果 Dockerfile 中如果存在多个 CMD 指令,仅最后一个生效。

CMD <shell 命令>

CMD [“<可执行文件或命令>”,“<param1>”,“<param2>”,…]#推荐使用

CMD [“<param1>”,“<param2>”,…] # 该写法是为 ENTRYPOINT 指令指定的程序提供默认参数

ENTRYPOINT:类似于 CMD 指令,但其不会被 docker run 的命令行参数指定的指令所覆盖,而且这些命令行参数会被当作参数送给 ENTRYPOINT 指令指定的程序。如果运行 docker run 时使用了 –entrypoint 选项,此选项的参数可当作要运行的程序覆盖 ENTRYPOINT 指令指定的程序。

优点:在执行 docker run 的时候可以指定 ENTRYPOINT 运行所需的参数。

注意:如果 Dockerfile 中如果存在多个 ENTRYPOINT 指令,仅最后一个生效。

可以搭配 CMD 命令使用:一般是变参才会使用 CMD ,这里的 CMD 等于是在给 ENTRYPOINT 传参,以下示例会提到。

FROM nginx

ENTRYPOINT [“nginx”, “-c”] # 定参

CMD [“/etc/nginx/nginx.conf”] # 变参

ENV:设置环境变量

ENV <key> <value>

ENV <key1>=<value1> <key2>=<value2>…

ARG:构建参数,与 ENV 作用一至。不过作用域不一样。ARG 设置的环境变量仅对 Dockerfile 内有效,也就是说只有 docker build 的过程中有效,构建好的镜像内不存在此环境变量。构建命令 docker build 中可以用 –build-arg <参数名>=<值> 来覆盖。

ARG <参数名>[=<默认值>]

VOLUME:定义匿名数据卷。在启动容器时忘记挂载数据卷,会自动挂载到匿名卷。启动容器 docker run 的时候,可以通过 -v 参数修改挂载点。

  • 避免重要的数据,因容器重启而丢失,这是非常致命的。
  • 避免容器不断变大。

VOLUME [“<路径1>”, “<路径2>”…]

VOLUME <路径>

EXPOSE:仅仅只是声明端口。

  • 帮助镜像使用者理解这个镜像服务的守护端口,以方便配置映射。
  • 在运行时使用随机端口映射时,也就是 docker run -P 时,会自动随机映射 EXPOSE 的端口。

EXPOSE <端口1> [<端口2>…]

WORKDIR:指定工作目录。用 WORKDIR 指定的工作目录,会在构建镜像的每一层中都存在。(WORKDIR 指定的工作目录,必须是提前创建好的)。docker build 构建镜像过程中的,每一个 RUN 命令都是新建的一层。只有通过 WORKDIR 创建的目录才会一直存在。

WORKDIR <工作目录路径>

USER:用于指定执行后续命令的用户和用户组,这边只是切换后续命令执行的用户(用户和用户组必须提前已经存在)。

USER <用户名>[:<用户组>]

HEALTHCHECK:用于指定某个程序或者指令来监控 docker 容器服务的运行状态。

HEALTHCHECK [选项] CMD <命令>:设置检查容器健康状况的命令

HEALTHCHECK NONE:如果基础镜像有健康检查指令,使用这行可以屏蔽掉其健康检查指令

HEALTHCHECK [选项] CMD <命令> : 这边 CMD 后面跟随的命令使用,可以参考 CMD 的用法。

Docker Compose

Compose 是用于定义和运行多容器 Docker 应用程序的工具。通过 Compose,您可以使用 YML 文件来配置应用程序需要的所有服务。然后,使用一个命令,就可以从 YML 文件配置中创建并启动所有服务。

Compose 使用的三个步骤:

  • 使用 Dockerfile 定义应用程序的环境。
  • 使用 docker-compose.yml 定义构成应用程序的服务,这样它们可以在隔离环境中一起运行。
  • 最后,执行 docker-compose up 命令来启动并运行整个应用程序。

本文链接地址: docker操作命令整理

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注