docker笔记(一)指令

126 阅读6分钟

docker

docker常用命令

docker启动以及版本相关命令

快速安装命令

yum install docker-io -y

启动、停止、重启

systemctl start docker      #启动docker
systemctl stop docker       #停止docker
systemctl restart docker    #重启docker
systemctl enable docker     #设置开机启动docker

查看docker系统信息

docker info

查看docker版本

docker version
docker镜像相关命令

查看镜像

docker search
docker search [OPTIONS] TERM
列表参数
name            :镜像仓库名称
description     :镜像描述
official        :是否docker官方发布
stars           :点赞数量
automated       :自动构建
指令参数
-f  --filter filter :列出收藏数不小于指定值的镜像
    --limit int     :展示多少条数据(默认25条)
    --no-trunc      :显示完整的镜像描述;
    --automated     :只列出 automated build类型的镜像(已经                     弃用)
示例
docker search redis #展示所有redis镜像
docker search -f stars redis

下载镜像

docker pull 
docker pull [OPTIONS] NAME[:TAG|@DIGEST]
指令参数
-a  --all-tags              :拉取所有镜像
    --disable-content-trust :忽略镜像校验,默认开启
注意:
docker pull java    #拉取最新的java镜像
docker pull -a java #拉取所有java镜像

登录、登出镜像仓库

docker login                    #登录
docker login [OPTIONS] [SERVER]
docker logout                   #登出
docker logout [OPTIONS] [SERVER]
指令参数
-u  登录用户名
-p  登录密码
示例
docker login -u 用户名 -p 密码

上传到镜像仓库

docker push [OPTIONS] NAME[:TAG]
示例:
docker push java:8

查看本地镜像

docker images
docker images [OPTIONS] [REPOSITORY[:TAG]]
REPOSITORY:表示镜像的仓库源          
TAG:镜像标签                
IMAGE ID:镜像ID          
CREATED:创建镜像时间    
SIZE:镜像大小
指令参数
-a  --all           :列出本地所有的镜像;
    --digests       :显示镜像的摘要信息;
-f  --filter filter :显示满足条件的镜像;
    --format        :指定返回值的模板文件;
    --no-trunc      :显示完整的镜像信息;
-q  --quiet         :只显示镜像ID。

删除镜像

docker rmi
docker rmi [OPTIONS] IMAGE [IMAGE...]
指令参数
-f  --force     :强制删除
    --no-prune  :不移除该镜像的过程镜像,默认移除。
注意:
docker rmi `docker images -q`可以删除所有镜像
docker rmi这个指令后面是可以跟着docker images -q这个指令的这个指令的意思是查询所有的镜像,只展示id
docker容器常用指令
docker run #docker创建一个新的容器并运行一个命令
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
常用指令参数
-a stdin: 指定标准输入输出内容类型,可选 STDIN/STDOUT/STDERR 三项;
-d: 后台运行容器,并返回容器ID;
-i: 以交互模式运行容器,通常与 -t 同时使用;
-P: 随机端口映射,容器内部端口随机映射到主机的端口
-p: 指定端口映射,格式为:主机(宿主)端口:容器端口
-t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;
--name="nginx-lb": 为容器指定一个名称;
--dns 8.8.8.8: 指定容器使用的DNS服务器,默认和宿主一致;
--dns-search example.com: 指定容器DNS搜索域名,默认和宿主一致;
-h "mars": 指定容器的hostname;
-e username="ritchie": 设置环境变量;
--env-file=[]: 从指定文件读入环境变量;
--cpuset="0-2" or --cpuset="0,1,2": 绑定容器到指定CPU运行;
-m :设置容器使用内存最大值;
--net="bridge": 指定容器的网络连接类型,支持 bridge/host/none/container: 四种类型;
--link=[]: 添加链接到另一个容器;
--expose=[]: 开放一个端口或一组端口;
--volume , -v: 绑定一个卷
​
docker create #创建容器但是不启动他
docker create [OPTIONS] IMAGE [COMMAND] [ARG...]

启动、停止、重启容器

docker start    #启动一个或多个已经被停止的容器
docker stop     #停止一个运行中的容器
docker restart  #重启容器
docker kill     #杀掉一个运行中的容器
注意:
stop和kill都是停止容器,只不过stop是走停止流程,kill是强制停止

删除容器

docker rm
docker rm [OPTIONS] CONTAINER [CONTAINER...]
-f :通过 SIGKILL 信号强制删除一个运行中的容器
-l :移除容器间的网络连接,而非容器本身
-v :删除与容器关联的卷

暂停、恢复容器进程

docker pause
docker unpause

在容器中执行命令,或者说是进入容器执行操作

docker exec
docker exec [OPTIONS] CONTAINER COMMAND [ARG...]
-d :分离模式: 在后台运行
-i :即使没有附加也保持STDIN 打开
-t :分配一个伪终端
示例:以交互模式执行容器中的mysql的/bin/bash脚本
docker exec -it mysql(容器名/id) /bin/bash
​

列出容器

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

获取容器、镜像的元数据

docker inspect #获取容器/镜像的元数据
docker inspect [OPTIONS] NAME|ID [NAME|ID...]

查看容器进程

docker top
docker top [OPTIONS] CONTAINER [ps OPTIONS]

获取容器日志

docker logs
docker logs [OPTIONS] CONTAINER
-f : 跟踪日志输出
--since :显示某个开始时间的所有日志
-t : 显示时间戳
--tail :仅列出最新N条容器日志

容器映射端口

docker port
docker port [OPTIONS] CONTAINER [PRIVATE_PORT[/PROTO]]

容器资源使用情况

docker stats
docker stats [OPTIONS] [CONTAINER...]
列表参数
CONTAINER ID  NAME: 容器 ID 与名称。
CPU %  MEM %: 容器使用的 CPU 和内存的百分比。
MEM USAGE / LIMIT: 容器正在使用的总内存,以及允许使用的内存总量。
NET I/O: 容器通过其网络接口发送和接收的数据量。
BLOCK I/O: 容器从主机上的块设备读取和写入的数据量。
PIDs: 容器创建的进程或线程数。
--all , -a :显示所有的容器,包括未运行的。
--format :指定返回值的模板文件。
--no-stream :展示当前状态就直接退出了,不再实时更新。
--no-trunc :不截断输出。

从容器创建镜像

docker commit 
docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]
-a :提交的镜像作者;
-c :使用Dockerfile指令来创建镜像;
-m :提交时的说明文字;
-p :在commit时,将容器暂停

容器与主机之间的数据拷贝

docker commit
docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]
-a :提交的镜像作者;
-c :使用Dockerfile指令来创建镜像;
-m :提交时的说明文字;
-p :在commit时,将容器暂停。