在Docker的容器之间设置网络设置网络通信的方法
发布时间:2022-05-15 23:41:43
这篇文章主要介绍了在Docker的容器之间设置网络设置网络通信的方法,Docker是当下最火热的虚拟机类技术,需要的朋友可以参考下
你也许已经知道了,Docker 容器技术是现有的成熟虚拟化技术的一个替代方案。它被企业应用在越来越多的领域中,比如快速部署环境、简化基础设施的配置流程、多客户环境间的互相隔离等等。当你开始在真实的生产环境使用 Docker 容器去部署应用沙箱时,你可能需要用到多个容器部署一套复杂的多层应用系统,其中每个容器负责一个特定的功能(例如负载均衡、LAMP 栈、数据库、UI 等)。
那么问题来了:有多台宿主机,我们事先不知道会在哪台宿主机上创建容器,如果保证在这些宿主机上创建的容器们可以互相联网?
联网技术哪家强?开源方案找 weave。这个工具可以为你省下不少烦恼。听我的准没错,谁用谁知道。
于是本教程的主题就变成了“如何使用 weave 在不同主机上的 Docker 容器之间设置网络”。
Weave 是如何工作的
让我们先来看看 weave 怎么工作:先创建一个由多个 peer 组成的对等网络,每个 peer 是一个虚拟路由器容器,叫做“weave 路由器”,它们分布在不同的宿主机上。这个对等网络的每个 peer 之间会维持一个 TCP 链接,用于互相交换拓扑信息,它们也会建立 UDP 链接用于容器间通信。一个 weave 路由器通过桥接技术连接到本宿主机上的其他容器。当处于不同宿主机上的两个容器想要通信,一台宿主机上的 weave 路由器通过网桥截获数据包,使用 UDP 协议封装后发给另一台宿主机上的 weave 路由器。
每个 weave 路由器会刷新整个对等网络的拓扑信息,可以称作容器的 MAC 地址(如同交换机的 MAC 地址学习一样获取其他容器的 MAC 地址),因此它可以决定数据包的下一跳是往哪个容器的。weave 能让两个处于不同宿主机的容器进行通信,只要这两台宿主机在 weave 拓扑结构内连到同一个 weave 路由器。另外,weave 路由器还能使用公钥加密技术将 TCP 和 UDP 数据包进行加密。
准备工作
在使用 weave 之前,你需要在所有宿主机上安装 Docker 环境,参考这些教程,在 Ubuntu 或 CentOS/Fedora 发行版中安装 Docker。
Docker 环境部署完成后,使用下面的命令安装 weave:
复制代码代码如下:
$ wget https://github.com/zettio/weave/releases/download/latest_release/weave
$ chmod a+x weave
$ sudo cp weave /usr/local/bin
注意你的 PATH 环境变量要包含 /usr/local/bin 这个路径,请在 /etc/profile 文件中加入一行(LCTT 译注:要使环境变量生效,你需要执行这个命令: source /etc/profile):
复制代码代码如下:
export PATH="$PATH:/usr/local/bin"
在每台宿主机上重复上面的操作。
Weave 在 TCP 和 UDP 上都使用 6783 端口,如果你的系统开启了防火墙,请确保这两个端口不会被防火墙挡住。
在每台宿主机上启动 Weave 路由器
当你想要让处于在不同宿主机上的容器能够互相通信,第一步要做的就是在每台宿主机上启动 weave 路由器。
第一台宿主机,运行下面的命令,就会创建并开启一个 weave 路由器容器(LCTT 译注:前面说过了,weave 路由器也是一个容器):
复制代码代码如下:
$ sudo weave launch
第一次运行这个命令的时候,它会下载一个 weave 镜像,这会花一些时间。下载完成后就会自动运行这个镜像。成功启动后,终端会输出这个 weave 路由器的 ID 号。
下面的命令用于查看路由器状态:
复制代码代码如下:
$ sudo weave status
第一个 weave 路由器就绪了,目前为止整个 peer 对等网络中只有一个 peer 成员。
你也可以使用 docker 的命令来查看 weave 路由器的状态:
复制代码代码如下:
第二台宿主机部署步骤稍微有点不同,我们需要为这台宿主机的 weave 路由器指定第一台宿主机的 IP 地址,命令如下:
复制代码代码如下:
$ sudo weave launch
当你查看路由器状态,你会看到两个 peer 成员:当前宿主机和第一个宿主机。
当你开启更多路由器,这个 peer 成员列表会更长。当你新开一个路由器时,要指定前一个宿主机的 IP 地址,请注意不是第一个宿主机的 IP 地址(LCTT 译注:链状结构)。
现在你已经有了一个 weave 网络了,它由位于不同宿主机的 weave 路由器组成。
把不同宿主机上的容器互联起来
接下来要做的就是在不同宿主机上开启 Docker 容器,并使用虚拟网络将它们互联起来。
假设我们创建一个私有网络 10.0.0.0/24 来互联 Docker 容器,并为这些容器随机分配 IP 地址。
如果你想新建一个能加入 weave 网络的容器,你就需要使用 weave 命令来创建,而不是 docker 命令。原因是 weave 命令内部会调用 docker 命令来新建容器然后为它设置网络。
下面的命令是在宿主机 hostA 上建立一个 Ubuntu 容器,然后将它放到 10.0.0.0/24 网络中,分配的 IP 地址为 10.0.0.1:
复制代码代码如下:
hostA:~$ sudo weave run 10.0.0.1/24 -t -i ubuntu
成功运行后,终端会显示出容器的 ID 号。你可以使用这个 ID 来访问这个容器:
复制代码代码如下:
hostA:~$ docker attach
在宿主机 hostB 上,也创建一个 Ubuntu 容器,IP 地址为 10.0.0.2:
复制代码代码如下:
hostB:~$ sudo weave run 10.0.0.2/24 -t -i ubuntu
访问下这个容器的控制台:
复制代码代码如下:
hostB:~$ docker attach
这两个容器能够互相 ping 通,你可以通过容器的控制台检查一下。
如果你检查一下每个容器的网络配置,你会发现有一块名为“ethwe”的网卡,你分配给容器的 IP 地址出现在它们那里(比如这里分别是 10.0.0.1 和 10.0.0.2)。
Weave 的其他高级用法
weave 提供了一些非常巧妙的特性,我在这里作下简单的介绍。
应用分离
使用 weave,你可以创建多个虚拟网络,并为每个网络设置不同的应用。比如你可以为一群容器创建 10.0.0.0/24 网络,为另一群容器创建 10.10.0.0/24 网络,weave 会自动帮你维护这些网络,并将这两个网络互相隔离。另外,你可以灵活地将一个容器从一个网络移到另一个网络而不需要重启容器。举个例子:
首先开启一个容器,运行在 10.0.0.0/24 网络上:
复制代码代码如下:
$ sudo weave run 10.0.0.2/24 -t -i ubuntu
然后让它脱离这个网络:
复制代码代码如下:
$ sudo weave detach 10.0.0.2/24
最后将它加入到 10.10.0.0/24 网络中:
复制代码代码如下:
$ sudo weave attach 10.10.0.2/24
现在这个容器可以与 10.10.0.0/24 网络上的其它容器进行通信了。这在当你创建一个容器而网络信息还不确定时就很有帮助了。
将 weave 网络与宿主机网络整合起来
有时候你想让虚拟网络中的容器能访问物理主机的网络。或者相反,宿主机需要访问容器。为满足这个功能,weave 允许虚拟网络与宿主机网络整合。
举个例子,在宿主机 hostA 上一个容器运行在 10.0.0.0/24 中,运行使用下面的命令:
复制代码代码如下:
hostA:~$ sudo weave expose 10.0.0.100/24
这个命令把 IP 地址 10.0.0.100 分配给宿主机 hostA,这样一来宿主机 hostA 也连到了 10.0.0.0/24 网络上了。显然,你在为宿主机选择 IP 地址的时候,需要选一个没有被其他容器使用的地址。
现在 hostA 就可以访问 10.0.0.0/24 上的所有容器了,不管这些容器是否位于 hostA 上。好巧妙的设定啊,32 个赞!
总结
如你所见,weave 是一个很有用的 docker 网络配置工具。这个教程只是它强悍功能的冰山一角。如果你想进一步玩玩,你可以试试它的以下功能:多跳路由功能,这个在 multi-cloud 环境(LCTT 译注:多云,企业使用多个不同的云服务提供商的产品,比如 IaaS 和 SaaS,来承载不同的业务)下还是很有用的;动态重路由功能是一个很巧妙的容错技术;或者它的分布式 DNS 服务,它允许你为你的容器命名。


猜你喜欢
- 很多使用笔记本的小伙伴都知道可以通过修改电源模式的方法,来降低的电池消耗,但在升级到Win11系统之后就找不到电源计划在哪,那么遇到这种情况
- 在制作水印时,我们有两种选择:文字水印和图片水印。下面我们先讲如何添加文字水印:一、添加文字水印在word 2007中打开需要添加水印的文档
- Excel是我们常见办公中不可缺少的重要组成部分,通常情况下我们统计数据、处理数据都无法离开Excel软件,不过有部分用户在使用Excel时
- 很多用户们表示长时间使用win10电脑,因为连续看着屏幕一天后导致眼睛疲劳,想要去设置win10显示的护眼色,但是又不知道怎么去设置,快来看
- 很多小伙伴的电脑用久了就会觉得卡,因为磁盘的东西太多太杂,今天小编教大家如何整理磁盘碎片,碎片整理是对于磁盘高效利用和维护的重要手段,是需要
- 在Word中制作表格时都希望在表格的第一列增加一个序号,其作用可以标识行或统计行数。例如从1开始,一直到80、100甚至更多。那么怎么添加呢
- 小编作为广大研一新生中的一员,最近正在为怎么看论文、如何写论文而发愁,不知你是否也有同感呢?下面就为大家介绍一位大牛对于写论文的经验之谈。撰
- 除了初级簿记,储蓄也是更好的投资和财务管理的重要部分。我教你自己制作存款单,它将应用于wps表单的一些基本功能,如格式刷、简单日期计算、公式
- 如何在excel中设计酷的折线图1.首先,启动excel2010,执行file-open命令,打开准备好的表数据内容。2.选择数据区域中的任
- Word软件提供的文档保护功能在一定程度上确保了文件的安全,但是如果有一天自己忘记了当初设置的保护文档密码,该怎么办呢?下面小编将给大家讲解
- 玩游戏的时候最怕跳出什么程序来干扰游戏,很多玩家在玩游戏过程中会遇到输入法弹出来,影响游戏体验,Win10玩游戏老跳出来输入法怎么办?按照以
- Word2007双击打不开提示向程序发送命令时出现问题,关于这个问题,下面是小编给大家整理的一些有关Word2007双击打不开的解决方法,希
- 我们经常在电脑上要创建新建文件,下载软件或者资料的时候要创建新建文件等等。虽然在桌面上操作简单,但是使用起来还是比较麻烦一点,那有没有什么快
- 小娜是Windows10操作系 * 有的特色,其功能强大,使用广泛。然而很多用户在使用Cortana时也会遇到各种各样的问题,比如最近一位用户
- 最近有winXP系统用户反映在设置访问共享的时候,XP系统提示指定的网络名不再可用怎么办?这该怎么办呢?本文将提供XP系统指定的网络名不再可
- 大家在使用office2010制作Excel表格的时候不知道office2010怎么设置Excel表格数据分区密码,其实方法很简单哦,只要在
- 大家在日常使用电脑的时候,习惯性都会点击右键进行刷新,但是有用户反映自己更新Win11系统之后,遇到开机桌面无限刷新的情况,这是怎么回事?下
- 怎样把wps表格中文件里的保存变成保存快捷键?下面小编为大家讲讲:WPS软件本身就有快捷保存按钮,在小工具栏上,也可以按CTRL+S保存文档
- 在网上冲浪的时候总会遇到网站弹出各种让人烦躁的广告的情况,怎样屏蔽烦人的广告,还浏览器一个清新的网页呢?小编接下来就教大家使用腾讯电脑管家内
- 6播直播出现无法观看怎么办?6播直播是一款非常好用的直播软件,有些用户在使用这款软件的过程中,会出现观看不了的情况,我们该怎么解决这个问题呢