docker 命令

dockerfile构建镜像的命令:

docker run :创建一个新的容器并运行一个命令:
docker run [OPTIONS] IMAGE [COMMAND] [ARG…]
-d: 后台运行容器,并返回容器ID;
-p: 指定端口映射,格式为:主机(宿主)端口:容器端口
-P: 随机端口映射,容器内部端口随机映射到主机的端口
–name=“nginx-lb”: 为容器指定一个名称;
-t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;
-i: 以交互模式运行容器,通常与 -t 同时使用;
–volume , -v: 绑定一个卷

使用docker镜像nginx:latest以后台模式启动一个容器,并将容器命名为mynginx:
docker run --name mynginx -d nginx:latest
使用镜像nginx:latest以后台模式启动一个容器,并将容器的80端口映射到主机随机端口。
docker run -P -d nginx:latest
使用镜像 nginx:latest,以后台模式启动一个容器,将容器的 80 端口映射到主机的 80 端口,主机的目录 /data 映射到容器的 /data。
docker run -p 80:80 -v /data:/data -d nginx:latest
绑定容器的 8080 端口,并将其映射到本地主机 127.0.0.1 的 80 端口上。
docker run -p 127.0.0.1:80:8080/tcp ubuntu bash
使用镜像nginx:latest以交互模式启动一个容器,在容器内执行/bin/bash命令。
docker run -it nginx:latest /bin/bash

执行 docker run --rm命令选项,等价于在容器退出后,执行 docker rm -v,这样在容器退出时就能够自动清理容器内部的文件系统。

docker rm :删除一个或多个容器。
-f :通过 SIGKILL 信号强制删除一个运行中的容器。
-l :移除容器间的网络连接,而非容器本身。
-v :删除与容器关联的卷。
删除xxx容器:docker rm xxx
强制删除容器 db01、db02:docker rm -f db01 db02
删除容器 nginx01, 并删除容器挂载的数据卷: docker rm -v nginx01

docker info : 显示 Docker 系统信息,包括镜像和容器数。。
docker version :显示 Docker 版本信息。

docker rmi : 删除本地一个或多少镜像。
-f :强制删除;
强制删除本地镜像 runoob/ubuntu:v4:docker rmi -f runoob/ubuntu:v4

docker create :创建一个新的容器但不启动它
用法同 docker run
使用docker镜像nginx:latest创建一个容器,并将容器命名为myrunoob
docker create --name myrunoob nginx:latest

docker pause :暂停容器中所有的进程
docker unpause :恢复容器中所有的进程。

docker kill :杀掉一个运行中的容器。
docker start :启动一个或多个已经被停止的容器
docker stop :停止一个运行中的容器
docker restart :重启容器

docker exec :在运行的容器中执行命令
-i :即使没有附加也保持STDIN 打开
-t :分配一个伪终端
在容器 mynginx 中以交互模式执行容器内 /root/runoob.sh 脚本:
docker exec -it mynginx /bin/sh /root/runoob.s

docker login : 登陆到一个Docker镜像仓库,如果未指定镜像仓库地址,默认为官方仓库 Docker Hub
docker logout : 登出一个Docker镜像仓库,如果未指定镜像仓库地址,默认为官方仓库 Docker Hub

登陆到Docker Hub:docker login -u 用户名 -p 密码
登出Docker Hub:docker logout

docker pull : 从镜像仓库中拉取或者更新指定镜像
-a :拉取所有 tagged 镜像
从Docker Hub下载java最新版镜像:docker pull java

docker push : 将本地的镜像上传到镜像仓库,要先登陆到镜像仓库
上传本地镜像myapache:v1到镜像仓库中:docker push myapache:v1

docker search : 从Docker Hub查找镜像
–no-trunc :显示完整的镜像描述;
-f <过滤条件>:列出收藏数不小于指定值的镜像。
从 Docker Hub 查找所有镜像名包含 java,并且收藏数大于 10 的镜像:
docker search -f stars=10 java

docker commit :从容器创建一个新的镜像。
docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]
-a :提交的镜像作者;
-c :使用Dockerfile指令来创建镜像;
-m :提交时的说明文字;
-p :在commit时,将容器暂停。
将容器a404c6c174a2 保存为新的镜像,并添加提交人信息和说明信息:
docker commit -a “runoob.com” -m “my apache” a404c6c174a2 mymysql:v1

docker cp :用于容器与主机之间的数据拷贝。

docker build 命令用于使用 Dockerfile 创建镜像。
-f :指定要使用的Dockerfile路径
–force-rm :设置镜像过程中删除中间容器;
–tag, -t: 镜像的名字及标签,通常 name:tag 或者 name 格式;可以在一次构建中为一个镜像设置多个标签。
–network: 默认 default。在构建期间设置RUN指令的网络模式
–cpuset-mems :指定使用的内存 id;
使用当前目录的 Dockerfile 创建镜像,标签为 runoob/ubuntu:v1:docker build -t runoob/ubuntu:v1 .
使用URL github.com/creack/docker-firefox 的 Dockerfile 创建镜像:
docker build github.com/creack/docker-firefox
也可以通过 -f Dockerfile 文件的位置:docker build -f /path/to/a/Dockerfile

docker import : 从归档文件中创建镜像。
docker import [OPTIONS] file|URL|- [REPOSITORY[:TAG]]
-c :应用docker 指令创建镜像;
-m :提交时的说明文字
从镜像归档文件my_ubuntu_v3.tar创建镜像,命名为runoob/ubuntu:v4:
docker import my_ubuntu_v3.tar runoob/ubuntu:v4

docker save : 将指定镜像保存成 tar 归档文件。
docker save [OPTIONS] IMAGE [IMAGE…]
-o :输出到的文件
将镜像 runoob/ubuntu:v3 生成 my_ubuntu_v3.tar 文档:
docker save -o my_ubuntu_v3.tar runoob/ubuntu:v3

docker export :将文件系统作为一个tar归档文件导出到STDOUT。
docker export [OPTIONS] CONTAINER
-o :将输入内容写到文件
将id为a404c6c174a2的容器按日期保存为tar文件:
docker export -o mysql-date +%Y%m%d.tar a404c6c174a2

docker tag : 标记本地镜像,将其归入某一仓库。
将镜像ubuntu:15.10标记为 runoob/ubuntu:v3 镜像:docker tag ubuntu:15.10 runoob/ubuntu:v3

docker images : 列出本地镜像。
docker diff : 检查容器里文件结构的更改。

docker history : 查看指定镜像的创建历史。
docker history [OPTIONS] IMAGE
docker history runoob/ubuntu:v3

docker load : 导入使用 docker save 命令导出的镜像。
–input , -i : 指定导入的文件,代替 STDIN。
–quiet , -q : 精简输出信息。
docker load --input fedora.tar

docker port :列出指定的容器的端口映射,或者查找将PRIVATE_PORT NAT到面向公众的端口
docker port [OPTIONS] CONTAINER [PRIVATE_PORT[/PROTO]]
查看容器mynginx的端口映射情况:
runoob@runoob:~$ docker port mymysql
3306/tcp -> 0.0.0.0:3306

docker wait : 阻塞运行直到容器停止,然后打印出它的退出代码。

docker logs : 获取容器的日志
-f : 跟踪日志输出
–since :显示某个开始时间的所有日志
-t : 显示时间戳
–tail :仅列出最新N条容器日志
跟踪查看容器mynginx的日志输出:docker logs -f mynginx
查看容器mynginx从2016年7月1日后的最新10条日志:
docker logs --since=“2016-07-01” --tail=10 mynginx

docker events : 从服务器获取实时事件
-f :根据条件过滤事件;
–since :从指定的时间戳后显示所有事件;
–until :流水时间显示到指定的时间为止;
显示docker 2016年7月1日后的所有事件: docker events --since=“1467302400”

docker attach :连接到正在运行中的容器。
以带上–sig-proxy=false来确保CTRL-D或CTRL-C不会关闭容器

docker top :查看容器中运行的进程信息,支持 ps 命令参数。
查看容器mymysql的进程信息:docker top mymysql

docker inspect : 获取容器/镜像的元数据。
docker inspect [OPTIONS] NAME|ID [NAME|ID…]
-f :指定返回值的模板文件。
-s :显示总的文件大小。
–type :为指定类型返回JSON。
获取镜像mysql:5.6的元信息: docker inspect mysql:5.6

docker ps : 列出容器
-a :显示所有的容器,包括未运行的。
-f :根据条件过滤显示的内容。
–format :指定返回值的模板文件。
-l :显示最近创建的容器。
-n :列出最近创建的n个容器。
–no-trunc :不截断输出。
-q :静默模式,只显示容器编号。
-s :显示总的文件大小
列出最近创建的5个容器信息: docker ps -n 5
列出所有创建的容器ID: docker ps -a -q
输出详情介绍:
CONTAINER ID: 容器 ID。
IMAGE: 使用的镜像。
COMMAND: 启动容器时运行的命令。
CREATED: 容器的创建时间。
STATUS: 容器状态。
状态有7种:
created(已创建)
restarting(重启中)
running(运行中)
removing(迁移中)
paused(暂停)
exited(停止)
dead(死亡)
PORTS: 容器的端口信息和使用的连接类型(tcp\udp)。
NAMES: 自动分配的容器名称。

注意:
docker save保存的是镜像(image),docker export保存的是容器(container);

docker load用来载入镜像包,必须是一个分层文件系统,必须是是save的包;
docker import用来载入容器包,但两者都会恢复为镜像;

docker load不能对载入的镜像重命名,而docker import可以为镜像指定新名称。

docker export的包会比save的包要小,原因是save的是一个分层的文件系统,export导出的只是一个linux系统的文件目录

docker export container_id:将一个容器导出为文件,再使用docker import命令将容器文件导入成为一个新的镜像,但是相比docker save命令,容器文件会丢失所有元数据和历史记录,仅保存容器当时的状态,相当于虚拟机快照。

显示镜像的所有层(layer)
sudo docker images --tree

导出后再导入(exported-imported)的镜像会丢失所有的历史。

而保存后再加载(saveed-loaded)的镜像没有丢失历史和层(layer)。
这意味着使用导出后再导入的方式,你将无法回滚到之前的层(layer),同时,使用保存后再加载的方式持久化整个镜像,就可以做到层回滚(可以执行docker tag 来回滚之前的层)。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值