zoukankan      html  css  js  c++  java
  • Docker

    1 - Docker命令分布示意图

    Docker命令分布

    2 - 帮助信息

    查看docker基本信息:docker info
    查看docker版本信息:docker version
    
    查看docker的所有命令及选项:docker --help
    查看docker具体命令的详细用法:docker COMMAND --help
    
    查看docker daemon的用法:docker daemon --help
    查看docker run的用法:docker run --help 或者 man docker-run
    

    3 - 镜像操作

    常用命令

    根据镜像名称或关键字查找仓库中镜像: docker search IMAGE_NAME/KEYWORD
    拉取仓库中镜像到本地:docker pull IMAGE_NAME
    
    显示已经下载的镜像信息: docker images
    显示已经下载的镜像摘要信息: docker images --digests
    显示包括中间层镜像在内的所有镜像:`docker images -a`
    
    显示镜像细节信息:docker inspect IMAGE_NAME
    显示镜像历史: docker history IMAGE_NAME
    
    删除本地镜像:docker rmi IMAGE_NAME
    构建镜像:docker build
    

    示例:docker images

    [root@CentOS-7 ~]# docker images
    REPOSITORY                     TAG                 IMAGE ID            CREATED             SIZE
    docker.io/eboraas/apache-php   latest              e95d111f807f        41 hours ago        283.9 MB
    docker.io/python               2.7                 acf0d719f268        3 weeks ago         676.1 MB
    docker.io/centos               latest              67591570dd29        4 weeks ago         191.8 MB
    docker.io/redis                latest              d59dc9e6d0bf        4 weeks ago         182.9 MB
    docker.io/ubuntu               15.10               9b9cb95443b5        5 months ago        137.2 MB
    docker.io/hello-world          latest              c54a2cc56cbb        6 months ago        1.848 kB
    [root@CentOS-7 ~]# 
    
    ####
    # REPOSITORY --- 镜像名称
    # TAG --- 镜像版本,默认如果docker run不带版本就会拉取最新的版本latest
    # MAGE ID --- 镜像短ID
    # CREATED --- 镜像在仓库的创建时间
    # VIRTUAL SIZE --- 镜像所占空间大小
    # 不加任何参数的情况下, docker images 会列出所有顶级镜像。
    # 可以根据仓库名、指定仓库名和标签等方式列出部分镜像,也可以通过--filter、--format、-q等参数显示特定内容。
    

    示例:docker rmi IMAGE_NAME

    [root@CentOS-7 ~]# docker images ubuntu 
    REPOSITORY              TAG                 IMAGE ID            CREATED             SIZE
    docker.io/ubuntu        16.04               6a2f32de169d        12 days ago         117.2 MB
    docker.io/ubuntu        latest              6a2f32de169d        12 days ago         117.2 MB
    docker.io/ubuntu        14.04               302fa07d8117        12 days ago         188 MB
    [root@CentOS-7 ~]# 
    [root@CentOS-7 ~]# docker rmi ubuntu:14.04
    Untagged: ubuntu:14.04
    Untagged: docker.io/ubuntu@sha256:edf05697d8ea17028a69726b4b450ad48da8b29884cd640fec950c904bfb50ce
    Deleted: sha256:302fa07d8117297adb599cc4ed7400348de5fe0f7950291e4bc32938324371b2
    Deleted: sha256:58ee5e1ccda6163bca1c6d26e0d9a9ca954131ddbcadb1dfea39f33bc4d8587e
    Deleted: sha256:e4bab9dc9558a6a82a7370c9018459b44a01fbf44224bf4a497007318ed587c8
    Deleted: sha256:85124bfb4ca4773e3b6e84f403f53511a6a27a783d5178e2ca45bc9b02e6591f
    Deleted: sha256:e421effca6fd5a1c5f1e36c006e1751e5fa163a110b763295a86116adcc6d4f3
    Deleted: sha256:638903ee85790805193e2709746d311a0224178933e6ad4083fc0eda81e9dfcd
    [root@CentOS-7 ~]# 
    [root@CentOS-7 ~]# docker images ubuntu 
    REPOSITORY              TAG                 IMAGE ID            CREATED             SIZE
    docker.io/ubuntu        16.04               6a2f32de169d        12 days ago         117.2 MB
    docker.io/ubuntu        latest              6a2f32de169d        12 days ago         117.2 MB
    [root@CentOS-7 ~]# 
    
    ####
    # 删除行为分为两类,一类是 Untagged ,另一类是 Deleted 。
    # 镜像的唯一标识是其ID 和摘要,而一个镜像可以有多个标签
    # 
    # docker rmi命令删除镜像的时候,实际上是取消镜像标签。标签被取消,显示Untagged信息。
    # 当镜像所有的标签都被取消,失去了存在的意义,才会触发删除行为,显示Deleted信息。
    # 如果仍然有其它标签指向了这个镜像,那么Delete行为就不会发生。
    # 所以并非所有的 docker rmi 都会产生删除镜像的行为,有可能仅仅是取消了某个标签而已。
    # 
    # 镜像是多层存储结构,因此在删除的时候也是从上层向基础层方向依次进行判断删除。
    # 如果其它镜像正依赖于当前镜像的某一层,则不会触发删除该层的行为。直到没有任何层依赖当前层时,才会真实的删除当前层。
    # 这可以解释,某些无标签镜像仍然存在和删除镜像的层数和pull层数不一致的现象。
    # 
    # 容器依赖于镜像,因此删除镜像之前,必须先删除这个镜像启动的容器(即使容器没有运行)。
    #
    # 删除所有ubuntu镜像:docker rmi $(docker images -q ubuntu)
    

    3.1 镜像体积

    Docker Hub 中显示的体积是压缩后的体积。
    docker images显示的是镜像下载到本地后,展开后的各层所占空间的总和。
    由于相同的层只需要保存一份,因此实际镜像硬盘占用空间可能比docker images 显示的镜像体积总和要小。

    3.2 虚悬镜像

    无标签镜像(既没有仓库名,也没有标签,显示为none)被称为虚悬镜像(dangling image)。一般来说,虚悬镜像没有存在价值,可以删除。

    显示虚悬镜像:docker images -f dangling=true
    删除虚悬镜像:docker rmi $(docker images -q -f dangling=true)
    

    3.3 中间层镜像

    显示包括中间层镜像在内的所有镜像:docker images -a
    中间层镜像是其它镜像所依赖的镜像。无论中间层镜像是否有标签,都不应该删除,否则会导致上层镜像因为依赖丢失而出错。

    4 - 容器操作

    容器是独立运行的一个或一组应用,以及它们的运行态环境。

    查看运行状态的容器:docker ps
    查看所有容器(包含exited状态):docker ps -a
    
    查看容器细节信息:docker inspect <Name/ID>
    查看容器日志: docker logs <Name/ID>
    实时查看容器日志: docker logs -f -t <Name/ID>
    查看容器里的进程: docker top <Name/ID>
    
    创建容器: docker create
    启动已停止的容器:docker start <Name/ID>
    停止容器: docker stop <Name/ID>
    重启容器: docker restart <Name/ID>
    强制结束容器: docker kill <Name/ID>
    删除终止状态的容器:docker rm <Name/ID>
    删除运行中的容器:docker rm -f <Name/ID>
    
    创建并启动容器:docker run
    在运行的容器中执行命令:docker exec
    进入容器:docker exec -it <Name/ID> /bin/bash
    退出容器:exit
    

    创建并启动容器:docker run

    当利用 docker run 来创建容器时,Docker 在后台运行的标准操作包括:
    1. 检查本地是否存在指定的镜像,不存在就从公有仓库下载
    2. 利用镜像创建并启动一个容器
    3. 分配一个文件系统,并在只读的镜像层外面挂载一层可读写层
    4. 从宿主主机配置的网桥接口中桥接一个虚拟接口到容器中去
    5. 从地址池配置一个 ip 地址给容器
    6. 执行用户指定的应用程序
    7. 执行完毕后容器被终止
    
    [root@CentOS-7 ~]# docker run -it --rm ubuntu:16.04 bash
    root@7f8001fb78da:/# cat /etc/os-release 
    NAME="Ubuntu"
    VERSION="16.04.2 LTS (Xenial Xerus)"
    ID=ubuntu
    ID_LIKE=debian
    PRETTY_NAME="Ubuntu 16.04.2 LTS"
    VERSION_ID="16.04"
    HOME_URL="http://www.ubuntu.com/"
    SUPPORT_URL="http://help.ubuntu.com/"
    BUG_REPORT_URL="http://bugs.launchpad.net/ubuntu/"
    VERSION_CODENAME=xenial
    UBUNTU_CODENAME=xenial
    root@7f8001fb78da:/# 
    root@7f8001fb78da:/# exit
    exit
    [root@CentOS-7 ~]# 
    
    ####
    # -i :打开并保持容器的标准输入
    # -t :分配pseudo-TTY终端并绑定到容器的标准输入上
    # -it 实际就是启动了一个可交互的容器,关联了终端和容器的stdin和stdout
    # -d :后台运行
    # --rm :容器退出后,自动删除容器
    # ubuntu:14.04 :使用ubuntu:14.04镜像为基础启动容器
    # bash :交互式bash Shell
    # --name  指定容器名字,否则会自动分配一个字符串名称
    # -P  随机端口映射
    # -p  指定内外端口映射关系
    # -net  网络模式
    # --pid  如果--pid=host,那么将在容器里面共享主机的 pid namespace
    # --device  指定容器可使用的主机设备
    

    示例:docker exec(在运行的容器中执行命令)

    [root@localhost ~]# docker ps
    CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES
    c37a36e56859        docker.io/centos    "/bin/bash"         4 minutes ago       Up 4 minutes                            demo
    [root@localhost ~]# 
    [root@localhost ~]# docker exec demo cat /etc/redhat-release
    CentOS Linux release 8.0.1905 (Core) 
    [root@localhost ~]# 
    [root@localhost ~]# docker exec -it demo /bin/bash    # 通过docker exec命令执行/bin/bash来进入容器
    [root@c37a36e56859 /]# cat /etc/redhat-release 
    CentOS Linux release 8.0.1905 (Core) 
    [root@c37a36e56859 /]# 
    [root@c37a36e56859 /]# exit
    exit
    [root@localhost ~]# 
    
    ####
    # -i :打开并保持容器的标准输入
    # -t :为容器分配伪终端pseudo-TTY
    
    

    5 - 网络

    • 查看网络信息:docker network ls
    • 查看网络详细信息:docker network inspect NET_NAME
  • 相关阅读:
    JS在火狐浏览器下如何关闭标签?
    .NET3.5项目转.NET2.0项目技巧
    GCHandler的使用
    多类选择器
    线程的Abort方法有感
    多线程死锁
    mysql 查看数据库、表的基本命令
    PHP往mysql数据库中写入中文失败
    TLS / SSL密码强化的建议
    MongoDB在Linux下常用优化设置
  • 原文地址:https://www.cnblogs.com/anliven/p/6217297.html
Copyright © 2011-2022 走看看