Docker学习笔记

原文地址:LoveDev

Docker相对于传统意义上的虚拟机最大的区别就在于传统虚拟机是虚拟出一套硬件后,再在上面运行一个完整的操作系统,再把需要运行的应用装在操作系统中运行。Docker在宿主的内核中运行应用进程,没有自己的内核,没有虚拟硬件,比起传统虚拟机更加轻快。

Docker基本概念

  • 镜像:操作系统
  • 容器:容器是独立运行的一个或一组应用,以及它们的运行态环境,镜像和容器的关系就像是面向对象中的实例
  • 仓库:镜像需要存储和分发,仓库用来存储镜像

Docker Registry

一个Docker Registry中可以包含多个仓库

Docker Hub

最常使用的 Registry 公开服务是官方的 Docker Hub,这也是默认的 Registry。

Docker Registry 公开服务

国内访问Registry 公开服务会有些慢(原因你懂得),国内云服务商提供了针对 Docker Hub 的镜像服务(Registry Mirror),这些镜像服务被称为加速器,常见的有 阿里云加速器DaoCloud 加速器灵雀云加速器等。

配置如下:


国内也有一些云服务商提供类似于 Docker Hub 的公开服务。比如 时速云镜像仓库网易云镜像服务DaoCloud 镜像市场阿里云镜像库等。

镜像

获取镜像

$ docker pull [选项][Docker Registry地址]<仓库名>:<标签>
例如:$ docker pull ubuntu
  • Docker Registry地址:地址的格式一般是 <域名/IP>[:端口号]
    ,默认地址是 Docker Hub。
  • 仓库名:如之前所说,这里的仓库名是两段式名称,既 <用户名>/<软件名>
    。对于 Docker Hub,如果不给出用户名,则默认为 library
    ,也就是官方镜像。

运行镜像

有个镜像就可以以这个镜像运行一个容器,以上面ubuntu为例运行一个容器。

$ docker run -it --rm ubuntu bash
  • docker run :就是运行容器的命令
  • -it :其实是两个参数,-i:交互式操作,-t :终端
  • --rm :容器退出后随之将其删除
  • ubuntu :用 ubuntu 镜像为基础来启动容器
  • bash:放在镜像名后的是命令,这里我们希望有个交互式 Shell,因此用的是 bash
$ docker run -d -p 22 -p 80:8080 ubuntu/kevin /usr/sbin/sshd -D
  • -d :容器后台运行
  • -p :指定端口设置
  • -p 80:8080 :端口映射,省略80表示把容器端口8080映射到一个动态端口
  • /usr/sbin/sshd :启动 ssh 服务
  • -D :容器长时间运行

注:exit:退出容器

列出镜像

列出下载的镜像用docker images命令。

列表中的镜像体积综合并非实际硬盘消耗,由于 Docker 镜像是多层存储结构,并且可以继承、复用,因此不同镜像可能会因为使用相同的基础镜像,从而拥有共同的层。

虚悬镜像

镜像既没有仓库名,也没有标签,均为 <none>。此类镜像为虚悬镜像(dangling image) ,下面命令专门显示此类镜像

$ docker images -f dangling=true

这类镜像已经失去了存在的价值,可以随意删除,删除命令如下

$ docker rmi $(docker images -q -f dangling=true)

中间层镜像

为了加速镜像构建、重复利用资源,Docker 会利用 中间层镜像。所以在使用一段时间后,可能会看到一些依赖的中间层镜像。默认的 docker images 列表中只会显示顶层镜像,如果希望显示包括中间层镜像在内的所有镜像的话,需要加 -a 参数。

$ docker images -a

列出部分镜像

根据仓库名列出镜像

$ docker image ubuntu

根据仓库名和标签

$ docker images ubunut:16.04

除此以外,docker images 还支持强大的过滤器参数 --filter,或者简写 -f。希望看到在nginx之后建立的镜像,可以用下面的命令

$ docker images -f since=nginx

希望看到nginx之前建立的镜像,since换成before

保存镜像

可用下面命令保存镜像

$ docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]
例如:docker commit -m "commit message" CONTAINER kevinlovedev/tomcat
  • -m:保存commit信息

删除镜像

可用下面命令删除镜像

$ docker rmi [OPTIONS] IMAGE [IMAGE...]

容器

启动

所需主要命令为docker run

$ sudo docker run --name kevin -i -t ubuntu /bin/bash
  • --name:为容器指定名称
  • -i :保证容器中STDIN是开启的
  • -t :为创建的容器分配一个伪tty终端,这样容器才能提供一个交互式shell

docker start命令直接将一个已经终止的容器启动运行

后台运行

更多的时候,需要让 Docker在后台运行而不是直接把执行命令的结果输出在当前宿主机下。此时,可以通过添加 -d 参数来实现。

获取容器的输出信息,可以通过 docker logs 命令。

启动并进入

大多数情况,我们需要启动并且直接进入到容器里面。

$ docker run -it 容器名 bash

终止

可用 docker stop [OPTIONS] CONTAINER [CONTAINER...] 来终止一个运行中的容器。

注:此命令后面是CONTAINER ID或者NAME参数,可用docker ps查看

此外,当Docker容器中指定的应用终结时,容器也自动终止。 例如对于上一章节中只启动了一个终端的容器,用户通过 exit 命令或 Ctrl+d 来退出终端时,所创建的容器立刻终止。

终止状态的容器可以用 docker ps -a 命令看到。

$ docker rm $(docker ps -qa --no-trunc --filter "status=exited")    # 删除所有已退出容器

进入容器

在使用 -d 参数时,容器启动后会进入后台。 某些时候需要进入容器进行操作

可用docker attach [OPTIONS] CONTAINER命令进入

导出容器

可用 docker export 命令。

$ docker export ubuntu:kevin > latest.tar

导入容器

可用 docker improt 命令。

注:用户既可以使用 docker load 来导入镜像存储文件到本地镜像库,也可以使用 docker import 来导入一个容器快照到本地镜像库。这两者的区别在于容器快照文件将丢弃所有的历史记录和元数据信息(即仅保存容器当时的快照状态),而镜像存储文件将保存完整记录,体积也要大。此外,从容器快照文件导入时可以重新指定标签等元数据信息。

删除容器

可用 docker rm 来删除一个处于终止状态的容器

docker ps -a 命令可以查看所有已经创建的包括终止状态的容器,如果数量太多要一个个删除可能会很麻烦,用 docker rm $(docker ps -a -q) 可以全部清理掉。

仓库

仓库(Repository)是集中存放镜像的地方。

搜索

用户无需登录即可通过 docker search 命令来查找官方仓库中的镜像,并利用 docker pull 命令来将它下载到本地。

另外,查找的时候通过 -s N 参数可以指定仅显示评价为 N 星以上的镜像(已经过时,不推荐使用),最新版本使用

--filter过滤查找。

利用下面命令下载到本地

$ sudo docker pull centos

数据管理

容器中管理数据主要有两种方式:

  • 数据卷(Data volumes)
  • 数据卷容器(Data volume containers)

数据卷

数据卷是一个可供一个或多个容器使用的特殊目录,它绕过 UFS,可以提供很多有用的特性:

  • 数据卷可以在容器之间共享和重用
  • 对数据卷的修改会立马生效
  • 对数据卷的更新,不会影响镜像
  • 数据卷默认会一直存在,即使容器被删除

注意:数据卷的使用,类似于 Linux 下对目录或文件进行 mount,镜像中的被指定为挂载点的目录中的文件会隐藏掉,能显示看的是挂载的数据卷。

容器和主机之间拷贝数据

拷贝容器文件到主机

$ docker cp [OPTIONS] CONTAINER:SRC_PATH DEST_PATH

例如:docker cp CONTAINER:/usr/local/tomcat/webapps/ROOT/index.html index.html

拷贝主机文件到容器

$ docker cp [OPTIONS] SRC_PATH|- CONTAINER:DEST_PATH

例如:docker cp index.html CONTAINER:/usr/local/tomcat/webapps/ROOT/index.html

Docker Machine

Docker Machine 是一个 docker 管理工具,主要解决两个问题:

  • docker 只能运行在 Linux 上
  • docker 只能管理运行本机的 docker 镜像

由于之前配置了 使用Docker Machine管理阿里云ECS ,Docker Machine使用一直不成功,报错信息如下:

Error setting machine configuration from flags provided: --engine-install-url cannot be used with the virtualbox driver, use --virtualbox-boot2docker-url instead

原因在于配置了阿里的一些参数,其中包括了MACHINE_DOCKER_INSTALL_URL,这个是报错的主要原因,查了半天的资料终于爬出坑了

Push本地镜像到DockerHub

首先镜像名称格式需要是DockerHubName/RepositoryName,例如kevinlovedev/tomcat,可用docker commit命令保存镜像,/前面是DockerHub昵称,/后面是DockerHub仓库名。

保存镜像成功之后,需要用docker login命令登陆到DockerHub。

最后用docker push命令提交本地镜像到DockerHub仓库。

Dockerfile

MAINTAINER:设置该镜像的作者。语法如下:

MAINTAINER kevin "kevinlovemail@gmail.com"

build

使用了 docker build 命令进行镜像构建。其格式为:

$ docker build -t ubuntu:kevin .

-t 指定了最终镜像的名称 ubuntu:kevin

常见问题

无法删除一

Error response from daemon: conflict: unable to delete e4b9e4f71238 (must be forced) - image is being used by stopped container 1e359ad4363d

该容器是终止状态,需要将此容器从终止状态删除,然后再删除镜像

$ docker rm 1e359ad4363d    # 删除终止容器
$ docker rmi e4b9e4f71238   # 删除镜像

无法删除二

Error response from daemon: conflict: unable to delete 1dc4f730b414 (cannot be forced) - image has dependent child images

先删除依赖,如果 IMAGE ID 相同的话,根据 TAG 删除

$ docker rm REPOSITORY:TAG    # 根据TAG删除容器

语法错误

Error response from daemon: Unknown instruction: RUNCMD

can't initialize iptables

can't initialize iptables table `filter': Permission denied (you must be root)

启动容器时加入参数 --privileged=true

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

推荐阅读更多精彩内容

  • 转载自 http://blog.opskumu.com/docker.html 一、Docker 简介 Docke...
    极客圈阅读 10,487评论 0 120
  • Docker — 云时代的程序分发方式 要说最近一年云计算业界有什么大事件?Google Compute Engi...
    ahohoho阅读 15,518评论 15 147
  • 简介 容器与管理程序虚拟化有所不同,管理程序虚拟化通过中间层将一台或多台独立的机器虚拟运行于物理硬件之上,而容器则...
    Gundy_阅读 353评论 0 4
  • 刘旭和刘枍
    老四肆阅读 243评论 0 0
  • * 阳春三月,天庭上别有一番盛景。 五六位仙婢成群地飘进蟠桃园,轻薄的纱裙在微风的带动下与脚下袅袅升起的云雾混为一...
    一盎司糖浆不太甜阅读 888评论 1 8