Docker 命令大全

47次阅读

共计 5514 个字符,预计需要花费 14 分钟才能阅读完成。

Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux 或 Windows 机器上,也可以实现虚拟化。随着容器化部署已变成趋势,熟练掌握 Docker 的命令已经变得更加重要了。本文介绍了如何安装 Docker,对 Docker 的常用镜像、容器和网络操作命令和 Dockerfile 进行了总结并提供了一些示例。

Docker 的安装

学习本教程前首先我们要安装 Docker。菜鸟教程上总结了 Docker 在各个平台和系统上的安装,大家可以参考。这里总结了下 Docker 在阿里云 Ubuntu 系统上的安装过程。步骤看似很多且复杂,但大家只需要一步一步 copy 和 paste 命令就行了,整个安装过程很流畅。

# 以 Ubuntu 为例
# Step 1: 移除之前 docker 版本并更新更新 apt 包索引
sudo apt-get remove docker docker-engine docker.io
sudo apt-get update

# Step 2: 安装 apt 依赖包,用于通过 HTTPS 来获取仓库
sudo apt-get install apt-transport-https ca-certificates curl software-properties-common

# Step 3: 添加 Docker 的官方 GPG 密钥
curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -

# Step 4: 设置 docker 稳定版仓库,这里使用了阿里云仓库
sudo add-apt-repository "deb [arch=amd64] https://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable"
sudo apt-get update

# Step 5: 安装免费的 docker Community 版本 docker-ce
sudo apt-get -y install docker-ce
# sudo apt-get install -y docker-ce=<VERSION> #该命令可以选择 docker-ce 版本

# Step 6: 查看 docker 版本及运行状态
sudo docker -v
sudo systemctl status docker

# Step 7:本步非必需。使用阿里云设置 Docker 镜像加速,注意下面链接请使用阿里云给自己的 URL
sudo mkdir -p /etc/docker 
sudo tee /etc/docker/daemon.json <<-'EOF' 
{"registry-mirrors": ["https://ua3456xxx.mirror.aliyuncs.com"] } 
EOF 
sudo systemctl daemon-reload 
sudo systemctl restart docker

接下来,我们来看下 Docker 的主要命令。

Docker 的镜像操作

# 搜索镜像:docker search + 镜像名字
docker search nginx

# 从 registry 拉取镜像:docker pull + 镜像名字: 版本号
docker pull nginx:latest

# 从 registry 仓库提交镜像:docker push + 仓库名: 标签
docker push repro1:v1.0

# 查看本地镜像: docker images
docker images

# 使用 Dockerfile 创建镜像: docker build + 目录,. 代表当前目录,- t 表示加标签
docker build -t mynginx:1.0 .

# 删除一个或多个镜像: docker rmi + 镜像 1 + 镜像 2
docker rmi mynginx:1.0 mynginx:2.0

# 删除未标记或未用过的镜像
docker image prune

# 删除未使用过的镜像
docker image prune -a

# 给镜像加标记:docker tag 镜像标签 新镜像标签名
docker tag mynginx:1.0 nginx1

# 把镜像保存为.tar 文件: docker save 镜像 > 文件
docker save mynginx:1.0 > mynginx_v1.tar

# 从.tar 文件载入镜像: docker load -i .tar 文件
docker load -i mynginx_v1.tar

# 根据容器创建镜像:docker commit 容器名 镜像名
docker commit 

Docker 的容器操作

# 创建容器: docker create + 选项(-i, -t, -d, -p, -v, -e) + 镜像
$ docker create --name mynginx_1 -it -p 8080:80 mynginx:1.0

# 各选项含义
# -i: 以交互模式运行容器,通常与 -t 同时使用;# -d: 后台运行容器,并返回容器 ID;# -p: 端口隐射, 宿主机在前,容器在后
# -P: 随机映射宿主机端口
# -t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;# -v: 目录挂载
# --entrypoint: 指定进入点
# --restart=always: 服务重启

# 启动容器:docker start + 容器名
docker start mynginx_1

# 创建 + 运行容器: docker run + 选项 + 镜像 + 命令
docker run --name mynginx_1 -it -p 8080:80 mynginx:1.0
docker run -it ubuntu /bin/bash

# 查看正在运行中的容器:docker ps
docker ps

# 查看所有容器,包括停止运行的容器: docker ps -a
docker ps -a

# 停止一个正在运行的容器: docker stop 容器
docker stop mynginx_1

# 重启容器:docker restart + 容器名
docker restart mynginx_1

# 容器重命名:docker rename 老名字 新名字
docker rename mynginx_1 mynginx_2

# 删除一个容器:docker rm 容器名
docker rm mynginx_1

# 强制删除一个正在运行的容器:docker rm -f 容器名
docker rm -f mynginx_1

# 删除已停止运行的所有容器: docker container prune
docker container prune

# 拷贝文件,从容器到宿主机:docker cp 容器名: 容器内路径 宿主机文件路径
docker cp myweb_1:/index.html index.html

# 拷贝文件,从宿主机到容器:docker cp 宿主机文件路径 容器名: 容器内路径
docker cp index.html myweb_1:/index.html 

# 进入运行的容器,执行命令: docker exec + 选项 + 容器名 + 命令 + 参数
# 推荐大家使用 docker exec 命令,使用此命令即使 exit 容器终端,也不会导致容器的停止
docker exec -it mynginx_1 /bin/bash
docker exec -it mynginx_1 /bin/bash start.sh

# 查看容器端口映射:docker port 容器名
docker port mynginx_1

# 查看容器内已修改文件:docker diff 容器名
docker diff mynginx_1

# 查看容器日志:docker logs + 容器名
docker logs web

# 查看容器内运行进程:docker top + 容器名
docker top web

# 查看容器的底层信息:docker inspect + 容器名
docker inspect web

# 利用 inspect 命令查看容器的 IP 地址
docker inspect web | grep "IPAddress"

# 查看运行容器的统计数据:docker stats
docker stats

Dockerfile 详解

使用 docker build 命令构建镜像时需要用到 Dockerfile,它通常会包含如下命令:

命令 描述 示例
FROM 指定基础镜像 FROM python:3.8.3-alpine
MAINTAINER 镜像创建者 MAINTAINER 大江狗
COPY 添加宿主机文件到容器,复制 COPY . /html/myapp
ADD 添加宿主机文件到容器,复制 + 解压 ADD myfile.tar /html/myapp
RUN 创建镜像时要执行的命令 RUN pip install -r requirements.txt
USER 切换执行后续命令的用户和用户组, 但这个用户必需首先已使用 RUN 的命令进行创建好了。 RUN groupadd -r redis && useradd -r -g redis redis; USER redis(切换用户)
WORKDIR 指定工作目录 WORKDIR /html/myapp
CMD 容器启动时默认要运行的程序。如果执行 docker run 后面跟启动命令会被覆盖掉。 CMD [“/bin/bash”]
ENV 设置环境变量 ENV APP_HOME /html/myapp
ENTRYPOINT 同 CMD,但其不会被覆盖,可以和 docker run 命令传递的参数进行拼接执行。 如果设置:ENTRYPOINT [“nginx”,“-c”],运行 $ docker run mynginx_1 -c /etc/nginx/myweb.conf 将默认执行命令:nginx -c /etc/nginx/myweb.conf
VOLUME 定义匿名数据卷。在启动容器时忘记挂载数据卷,会自动挂载到匿名卷。 VOLUME /tmp
EXPOSE 容器暴露端口,供 link 到当前容器或通过 docker network 的容器,不会和宿主机端口映射关系。 EXPOSE 8080

Docker 网络操作

Docker network 是主要是用做容器之间的通信,即组建容器之间的局域网,然后加入这个网络的容器可以使用别名 (network-alias, 比如 web, db) 或者 IP 地址进行通信,就如同局域网中主机之间的相互访问。

备注:使用 -link 也可以实现容器之间简单的网络,但是容器较多而且通信关系较为复杂时,使用 network 就更有条理。除此以外,官方也已经很早不建议使用 -link 方式进行容器互联,-link 未来可能会被删除。

网络驱动程序

Docker 的网络驱动程序默认情况下有四个:bridgehostoverlaymacvlan,还有一个特殊的网络驱动 none 用于禁止容器访问网络。

  • bridge:默认的网络驱动程序。如果在创建的时候没有指定网络驱动,则默认使用 bridge,也就是桥接网络。跟虚拟机的网络地址转换差不多,通过一个内部的子网向容器提供 IP 和网络。
  • host:容器会直接与宿主系统共享 IP 地址和网络,但是其它(例如存储,进程命名空间和用户命名空间)相对宿主机隔离的。
  • overlay:覆盖网络模式可以将不同的 Dockerd 守护进程连接在一起,该网络模式支持集群容器之间相互通信,以及集群和某个单机版独立容器直接相互通信。该网络模式使用场景比较广泛,通常集群部署时会使用该模式。
  • macvlan:这个网络驱动有点像虚拟机的桥接模式,它可以让你的容器直接连接到你的物理网络,比如连接到你的路由器,让物理网络来提供 IP 地址和网络。
  • none: 禁用容器所有网络。通常与自定义网络驱动程序一起使用。

创建一个 Network

# mysite1-network 是局域网的名字,可以自定义。默认 bridge 模式。docker network create mysite1-network 

# 利用 --driver 或 - d 指定使用 bridge 驱动,创建 mysite2-network 网络
docker network create –-driver bridge mysite2-network

# 查看已创建的 network 列表
docker network ls  

# 查看网络详情
docker network inspect mysite1-network

将容器连接到 Network

# 运行新的容器,并加入到 mysite1-network 网络中
# --network 表示这个容器要连接到的网络
# --network-alias 表示这个容器在此网络中的名称,也可以使用 --ip 来指定容器的 ip
docker run --name=docker-web -d --network=mysite1-network 
--network-alias=web docker-web-image

# 将已经在运行的容器加入网络使用以下命令, 容器名为 docker-web,别名为 web
docker network connect --alias=web --network=mysite1-network docker-web

# 连接网络时为 docker-web 容器指定 ip 地址
docker network connect --ip=127.0.0.1 multi-host-network docker-web

# 断开 docker-web 容器与 mysite1-network 的连接
docker network disconnet mysite1-network docker-web

删除 Network

# 删除 mysite1-network 网络
docker network rm mysite1-network

Docker 的数据卷操作

# 列出所有数据卷
docker volume ls
# 使用过滤,列出所有未使用的数据卷
docker volume ls --filter dangling=true
# 删除一个数据卷
# 容器正在使用的数据卷不能删除,绑定挂载的无法删除。docker volume rm <volume_name>

以上。

全文完
 
西西
📝创作说明:本文由 西西 于2023-07-06发表,共计5514字。
🉑转载说明:本作品采用 “知识共享署名-非商业性使用 4.0 国际许可协议” 进行许可。除特殊说明外,您可以自由的转载和修改,但请务必注明来源且不可用于商业目的。