欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

Docker 多主机网络通信详细介绍

程序员文章站 2022-10-14 09:18:24
最近做项目是关于docker 的网络通信,需要多个主机进行链接通信,这里记录下,以后便于项目开发,大家需要的话也可以看下,少走些弯路。 docker多主机网络通信详解&n...

最近做项目是关于docker 的网络通信,需要多个主机进行链接通信,这里记录下,以后便于项目开发,大家需要的话也可以看下,少走些弯路。

docker多主机网络通信详解             

docker支持多主机网络通信功能,可以通过命令行建立多主机通信网络。本文使用docker machine和consul服务发现工具来讲解这一点。

前提是需要先安装docker工具箱。

1、docker multi-host networking

作为一个示例,我们会在virtualbox虚拟机上使用docker machine创建3个docker主机。其中一个docker主机运行consul服务发现工具,另外两个docker主机则通过第一台主机的consul服务发现容器共享网络信息。

docker容器网络部分的相信信息可查看:

consul的详细信息见: 

consul的特性:

1)服务发现

consul使得服务注册和服务发现变得很简单

2)故障检测

支持对服务的健康检查,防止请求被路由到服务不可用的主机上

3)支持多数据中心

consul支持多数据中心,无需复杂的配置

4)键值存储

consul使用了键值存储来支持动态配置等

2、设置多主机网络

1)创建名为“host1-consul”的docker主机

docker-machine create -d virtualbox host1-consul

2)在“host1-consul”主机上运行consul容器

docker $(docker-machine config host1-consul) run -d -p "8500:8500" -h"consul" progrium/consul -server -bootstrap

3)验证上述容器的运行状态

docker $(docker-machine config host1-consul) ps

4)运行第二个docker主机,并注册到前面的consul容器

docker-machine create -d virtualbox  --engine-opt="cluster-store=consul://$(docker-machine ip host1-consul):8500" --engine-opt="cluster-advertise=eth1:0" host2

5)运行第三个docker主机

docker-machine create -d virtualbox  --engine-opt="cluster-store=consul://$(docker-machine ip host1-consul):8500" --engine-opt="cluster-advertise=eth1:0" host3

现在,后面两个docker主机都有默认的网络配置,且只能用于单个主机的通信。

6)要实现多主机网络通信,还需要在主机2上创建一个覆盖网络

docker $(docker-machine config host2) network create -d overlay myapp

7)ok,此时如果在主机3上检查网络,就可以看到主机2上创建的覆盖网络。这是因为主机2和3都注册到consul,网络信息在所有已注册的主机之间实现了共享。

docker $(docker-machine config host2) network ls
docker $(docker-machine config host3) network ls

如果是在不同的主机上运行容器,可能就需要使用容器名来连接它们。我们可以这样做个测试。
在主机2上运行一个nginx容器,在主机3上运行一个busybox容器,通过busybox容器下载nginx容器默认页面来测试连接是否正常。

8)在主机2上运行nginx容器,并指定创建的“myapp”网络

docker $(docker-machine config host2) run -itd --name=webfront --net=myapp nginx

9)验证nginx容器的运行

docker $(docker-machine config host2) ps

10)在主机3上运行一个busybox容器,使用参数下载主机2的nginx容器的默认主页。

docker $(docker-machine config host3) run -it --rm --net=myapp busybox wget -qo- http://webfront

如果结果返回的是html内容的输出,意味着容器能够使用之前创建的覆盖网络连接到主机。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!