美文网首页
Docker Container

Docker Container

作者: vickeex | 来源:发表于2018-11-01 18:01 被阅读0次

    上一篇讲了docker image,接下来讲讲container。感觉“container 是image的运行实例”的说法有偏差,因为container不一定处于running/stopped状态,初始创建后的状态为“created”,就把container理解为运行某个应用程序所依赖的环境及其他资源的封闭集合吧。

    create a container

    创建一个container,实际是在指定镜像的镜像层的最顶端添加一个可写层,也称为“container layer”。container所做的修改都会写入container layer,比如写/改/删新文件。这些镜像层和container层都由storage driver(存储驱动)负责管理。
    使用create命令进行container创建,完成后返回container id。create命令的部分常用参数如下表,完成参数选项的请用--help查看或参考CLI docs。docker还提供了run命令,创建一个container并立即启动该容器,用法相似。

    options usage description
    -a --attach value 关联至STDIN/STDOUT/STDERR
    -c --cpu-shares int 共享CPU
    -e --env value 设定环境变量
    --expose value 暴露一个或一组端口
    -h --hostname string container host name
    -i --interactive 如果没有attach则一直保持STDIN开放
    --ip/ip6 string ipv4/ipv6地址
    -l label value 为container设置元信息
    --link value 链接至另一个容器(依赖于其存在)
    -m --memory string 设置内存大小
    --mount value 挂载文件系统
    --name string 指定容器名
    --network string 网络连接方式:none / bridge / container / host / user-defined network
    -P --publish value 将容器的端口发布(映射)至主机
    -p --publish-all 将容器所有端口映射至主机上随机的端口
    --read-only 容器的根文件系统设为只读
    --rm 容器退出时立即删除
    -u --user string username or UID
    -v --volume value 绑定挂载数据卷
    -w --workdir string 指定工作路径

    注:本来相对--link选项参数拓展讲一下容器的链接(即容器间存在依赖关系,container A的运行依附于container B的已经运行),然后感觉不会怎么用上,就此吧。

    other operations

    command description options
    attach 将输入/输出/错误流关联至一个运行中的容器 --no-stdin 不关联输入
    exec 正在运行的容器中执行一个额外的命令 --env=[], --user, --workdir
    start 启动一个或多个停止状态的容器 --interactive
    pause 挂起容器中的所有进程,通过cgroups freezer实现
    stop 发送"SIGTERM"信号停止容器,超时则直接kill掉
    kill 发送"SIGKILL"(或其他信号)给一个或多个容器 --signal 指定发送的其他信号, 默认为KILL
    wait 等待容器退出时返回状态码
    export 以tar压缩包方式导出容器成镜像,对应的导入为import命令 --outputs 指定输出到文件而不是STDOUT
    update 更行容器的配置:CPU、内存、Block IO等
    rm 删除一个或一组容器 --force 强制删除(通过"SIGKILL") , --link 删除链接, --volumes 删除容器卷
    cp 在容器和本地文件系统间进行文件/文件夹的拷贝 --archive 拷贝所有的uid/gid信息, --follow-link 遵循源路径的符号链接
    rename 重命名
    restart 重启 --time 重启前等待kill的时间
    logs 获取容器的日志信息 --details, --since/until, --tail, --timestamps 显示时间戳
    top 显示容器内运行的进程
    port 列出容器的端口映射信息
    stats 显示容器资源使用情况统计信息的实时流数据 --all, --format
    diff 列出容器文件系统的文件/目录变化

    注:export命令将一个容器导出为镜像,而save命令则是将image导出,export会丢失history和layers等信息但save会保持这些信息,两个命令都通过“import”进行导入。

    network

    在创建container时提供了network的选项参数,网络连接正是容器最重要的配置之一。docker的网络系统可插拔,以网络驱动的形式进行管理,主要有以下几种方式:

    • bridge: 默认的网络驱动方式,常在单独工作模式下的(standalone)容器里的应用需要连接时使用。
      *default: 若容器间使用了link,则可以共享环境变量。
      *user-defined: 比默认桥接拥有更好的隔离性和互操作性,提供自动DNS服务。
    • host: 容器直接使用主机的网络,容器和主机间不再具有网络隔离性。
    • overlay: 多个docker daemons或swarm服务间能互相通信,
    • macvlan: 可以为container指定一个MAC地址以使其以物理设备的形式显示在网络上。
    • none: 哈哈哈不用网络也是一种网络连接的方式。
    • network plugins: 安装并使用第三方网络插件。

    网络部分的的CLI命令如下,用法都是 "$ docker network COMMAND"。

    command description
    connect Connect a container to a network
    create Create a network
    disconnect Disconnect a container from a network
    inspect Display detailed information on one or more networks
    ls List networks
    prune Remove all unused networks
    rm Remove one or more networks

    相关文章

      网友评论

          本文标题:Docker Container

          本文链接:https://www.haomeiwen.com/subject/onkxxqtx.html