Docker Container

上一篇讲了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
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,284评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,115评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,614评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,671评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,699评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,562评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,309评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,223评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,668评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,859评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,981评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,705评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,310评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,904评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,023评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,146评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,933评论 2 355

推荐阅读更多精彩内容