CloudMan6

2017年04月13日注册

没有个人说明

如何共享数据?- 每天5分钟玩转 Docker 容器技术(41)

 CloudMan6
 2019年05月9日

数据共享是 volume 的关键特性,本节我们详细讨论通过 volume 如何在容器与 host 之间,容器与容器之间共享数据。 容器与 host 共享数据 我们有两种类型的 data volume,它们均可实现在容器与 host 之间共享数据,但方式有所区别。 对于 bind mount 是非常明确的:直接将要共享的目录 mount 到容器。具体请参考前面 httpd 的例子,不再赘述。 doc

如何共享数据?- 每天5分钟玩转 Docker 容器技术(41)

docker managed volume – 每天5分钟玩转 Docker 容器技术(40)

 CloudMan6
 2019年04月17日

docker managed volume 与 bind mount 在使用上的最大区别是不需要指定 mount 源,指明 mount point 就行了。还是以 httpd 容器为例: 我们通过 -v 告诉 docker 需要一个 data volume,并将其 mount 到 /usr/local/apache2/htdocs。那么这个 data volume 具体在哪儿呢? 这个答案可以在容

docker managed volume – 每天5分钟玩转 Docker 容器技术(40)

Data Volume 之 bind mount – 每天5分钟玩转 Docker 容器技术(39)

 CloudMan6
 2019年04月17日

storage driver 和 data volume 是容器存放数据的两种方式,上一节我们学习了 storage driver,本节开始讨论 Data Volume。 Data Volume 本质上是 Docker Host 文件系统中的目录或文件,能够直接被 mount 到容器的文件系统中。Data Volume 有以下特点: Data Volume 是目录或文件,而非没有格式化的磁盘(块设

Data Volume 之 bind mount – 每天5分钟玩转 Docker 容器技术(39)

Docker 的两类存储资源 – 每天5分钟玩转 Docker 容器技术(38)

 CloudMan6
 2019年04月8日

我们从本章开始讨论 Docker 存储。 Docker 为容器提供了两种存放数据的资源: 由 storage driver 管理的镜像层和容器层。 Data Volume。 我们会详细讨论它们的原理和特性。 storage driver 在前面镜像章节我们学习到 Docker 镜像的分层结构,简单回顾一下。 容器由最上面一个可写的容器层,以及若干只读的镜像层组成,容器的数据就存放在这些层中。这样的

Docker 的两类存储资源 – 每天5分钟玩转 Docker 容器技术(38)

外部世界如何访问容器? – 每天5分钟玩转 Docker 容器技术(37)

 CloudMan6
 2019年04月8日

上节我们学习了容器如何访问外部网络,今天讨论另一个方向:外部网络如何访问到容器? 答案是:端口映射。 docker 可将容器对外提供服务的端口映射到 host 的某个端口,外网通过该端口访问容器。容器启动时通过-p参数映射端口: 容器启动后,可通过 docker ps 或者 docker port 查看到 host 映射的端口。在上面的例子中,httpd 容器的 80 端口被映射到 host 32

外部世界如何访问容器? – 每天5分钟玩转 Docker 容器技术(37)

容器如何访问外部世界?- 每天5分钟玩转 Docker 容器技术(36)

 CloudMan6
 2019年04月8日

前面我们已经解决了容器间通信的问题,接下来讨论容器如何与外部世界通信。这里涉及两个方向: 容器访问外部世界 外部世界访问容器 容器访问外部世界 在我们当前的实验环境下,docker host 是可以访问外网的。 我们看一下容器是否也能访问外网呢? 可见,容器默认就能访问外网。 请注意:这里外网指的是容器网络以外的网络环境,并非特指 internet。 现象很简单,但更重要的:我们应该理解现象下的本

容器如何访问外部世界?- 每天5分钟玩转 Docker 容器技术(36)

容器间通信的三种方式 – 每天5分钟玩转 Docker 容器技术(35)

 CloudMan6
 2019年04月8日

容器之间可通过 IP,Docker DNS Server 或 joined 容器三种方式通信。 IP 通信 从上一节的例子可以得出这样一个结论:两个容器要能通信,必须要有属于同一个网络的网卡。 满足这个条件后,容器就可以通过 IP 交互了。具体做法是在容器创建时通过 –network 指定相应的网络,或者通过 docker network connect 将现有容器加入到指定网络。可参考上一节

容器间通信的三种方式 – 每天5分钟玩转 Docker 容器技术(35)

理解容器之间的连通性 – 每天5分钟玩转 Docker 容器技术(34)

 CloudMan6
 2019年04月4日

通过前面小节的实践,当前 docker host 的网络拓扑结构如下图所示,今天我们将讨论这几个容器之间的连通性。 两个 busybox 容器都挂在 my_net2 上,应该能够互通,我们验证一下: 可见同一网络中的容器、网关之间都是可以通信的。 my_net2 与默认 bridge 网络能通信吗? 从拓扑图可知,两个网络属于不同的网桥,应该不能通信,我们通过实验验证一下,让 busybox 容器

理解容器之间的连通性 – 每天5分钟玩转 Docker 容器技术(34)

如何自定义容器网络?- 每天5分钟玩转 Docker 容器技术(33)

 CloudMan6
 2019年04月4日

除了 none, host, bridge 这三个自动创建的网络,用户也可以根据业务需要创建 user-defined 网络。 Docker 提供三种 user-defined 网络驱动:bridge, overlay 和 macvlan。overlay 和 macvlan 用于创建跨主机的网络,我们后面有章节单独讨论。 我们可通过 bridge 驱动创建类似前面默认的 bridge 网络,例如:

如何自定义容器网络?- 每天5分钟玩转 Docker 容器技术(33)

学容器必须懂 bridge 网络 – 每天5分钟玩转 Docker 容器技术(32)

 CloudMan6
 2019年04月4日

上一节我们讨论了 none 和 host 类型的容器网络,本节学习应用最广泛也是默认的 bridge 网络。 Docker 安装时会创建一个 命名为 docker0 的 linux bridge。如果不指定–network,创建的容器默认都会挂到 docker0 上。 当前 docker0 上没有任何其他网络设备,我们创建一个容器看看有什么变化。 一个新的网络接口 veth28c57df 被挂到

学容器必须懂 bridge 网络 – 每天5分钟玩转 Docker 容器技术(32)

none 和 host 网络的适用场景 – 每天5分钟玩转 Docker 容器技术(31)

 CloudMan6
 2019年03月21日

本章开始讨论 Docker 网络。 我们会首先学习 Docker 提供的几种原生网络,以及如何创建自定义网络。然后探讨容器之间如何通信,以及容器与外界如何交互。 Docker 网络从覆盖范围可分为单个 host 上的容器网络和跨多个 host 的网络,本章重点讨论前一种。对于更为复杂的多 host 容器网络,我们会在后面进阶技术章节单独讨论。 Docker 安装时会自动在 host 上创建三个网络

none 和 host 网络的适用场景 – 每天5分钟玩转 Docker 容器技术(31)

实现容器的底层技术 – 每天5分钟玩转 Docker 容器技术(30)

 CloudMan6
 2019年03月21日

为了更好地理解容器的特性,本节我们将讨论容器的底层实现技术。 cgroup 和 namespace 是最重要的两种技术。cgroup 实现资源限额, namespace 实现资源隔离。 cgroup cgroup 全称 Control Group。Linux 操作系统通过 cgroup 可以设置进程使用 CPU、内存 和 IO 资源的限额。相信你已经猜到了:前面我们看到的–cpu-shares、

实现容器的底层技术 – 每天5分钟玩转 Docker 容器技术(30)
切换注册

登录

忘记密码 ?

您也可以使用第三方帐号快捷登录

切换登录

注册

扫一扫二维码分享