当前位置: 首页 > 编程日记 > 正文

docker容器网络 - 同一个host下的容器间通信

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

对于复杂的应用,不可避免需要多个服务部署在多个容器中,并且服务间存在相互间通信的情况。比如服务A需要连接mysql的容器。本文将介绍docker的容器网络,并通过实践解决在同一个docker Host主机下的容器间通信的问题。

在安装好docker后,docker将创建一个linux网桥docker0,它在内核层连通了其他的物理或虚拟网卡,也就是所有容器和本地主机都放到同一个物理网络。我们可以通过 brctl 命令查看网桥的信息,brctl是需要自行安装的。

[root@localhost ~]# brctl show
bridge name	bridge id		STP enabled	interfaces
br-1a83283cbf04		8000.0242123432ad	no		
br-70590112bbda		8000.0242927ea6d9	no		
docker0		8000.024232ccc082	no	

另外,docker还会给我们创建三个网络:bridge/host/none。我们可以通过network ls命令查看当前宿主机中所有的docker网络。

[root@localhost ~]# docker network lsNETWORK ID          NAME                DRIVER              SCOPE
5a9ac72df73f        bridge              bridge              local
7d9eb4bd321c        host                host                local
4b740dab2aab        none                null                local

其中,网桥bridge模式是在实际项目中常用的。接下来,以交互模式启动两个busybox容器。在没有指定相关网络的情况下,容器都会连接到默认的bridge网络。我们可以通过 --network 参数指定容器连接的网络。

[root@localhost ~]# docker run -itd --name=busybox1 busybox
2813aba53acd688fa69807158830bef27b4ea8dc2ecfe13e7e357ce98a204f0b[root@localhost ~]# docker run -itd --name=busybox2 busybox
83fbeeb4e0527ece0602729415a57383b474284143a381e0a27561a69d75b1f5

启动容器后,检查当前默认bridge网络情况。busybox1和busybox2容器已经连接到了bridge网络,除此之外,还可以获取到两个容器的IP地址。

[root@localhost ~]# docker network inspect bridge[{"Name": "bridge","Id": "5a9ac72df73f19beaade92a28d705509fd24c350497dd90ecae224fdb18214bc","Created": "2018-12-25T16:30:26.58008782+08:00","Scope": "local","Driver": "bridge","EnableIPv6": false,"IPAM": {"Driver": "default","Options": null,"Config": [{"Subnet": "172.17.0.0/16","Gateway": "172.17.0.1"}]},"Internal": false,"Attachable": false,"Ingress": false,"ConfigFrom": {"Network": ""},"ConfigOnly": false,"Containers": {"2813aba53acd688fa69807158830bef27b4ea8dc2ecfe13e7e357ce98a204f0b": {"Name": "busybox1","EndpointID": "522f2b4b072098525939cc6b313f5673f82444d8ef6807bac0efcdce6a7c8418","MacAddress": "02:42:ac:11:00:02","IPv4Address": "172.17.0.2/16","IPv6Address": ""},"83fbeeb4e0527ece0602729415a57383b474284143a381e0a27561a69d75b1f5": {"Name": "busybox2","EndpointID": "e277940484662a341730766300149c2f63974d0b9e9cbd6c531bc7c8c37f31f9","MacAddress": "02:42:ac:11:00:03","IPv4Address": "172.17.0.3/16","IPv6Address": ""}},"Options": {"com.docker.network.bridge.default_bridge": "true","com.docker.network.bridge.enable_icc": "true","com.docker.network.bridge.enable_ip_masquerade": "true","com.docker.network.bridge.host_binding_ipv4": "0.0.0.0","com.docker.network.bridge.name": "docker0","com.docker.network.driver.mtu": "1500"},"Labels": {}}
]

接下来,我们测试下两个容器的互通情况。

进入busybox1容器,分别ping 容器busybox2的IP和容器名,可以发现可以通过IP地址ping通busybox2,但是不能通过容器ping通。其中,172.17.0.3是busybox2的IP地址。

[root@localhost ~]# docker attach  2813aba53acd/ # ping  172.17.0.3
PING 172.17.0.3 (172.17.0.3): 56 data bytes
64 bytes from 172.17.0.3: seq=0 ttl=64 time=0.090 ms
64 bytes from 172.17.0.3: seq=1 ttl=64 time=0.193 ms/ # ping busybox2

在容器中,可以查看容器的hosts文件,里面没有任何关于busybox2容器的信息。

/ # cat /etc/hosts127.0.0.1	localhost
::1	localhost ip6-localhost ip6-loopback
fe00::0	ip6-localnet
ff00::0	ip6-mcastprefix
ff02::1	ip6-allnodes
ff02::2	ip6-allrouters
172.17.0.2	2813aba53acd

在计算机网络中,想通过域名ping通其它网站,有两种方法:一种是本地的hosts文件,里面配置的是路由规则;另一种是DNS服务,通过DNS服务器返回正确的IP地址。那么docker是否也可以通过容器名访问其它容器的方式呢?

(1)link连接

默认的桥接网络支持使用端口映射和 docker run --link 命令,实现容器间互相通信。该方法已经在官方文档中标识为不推荐使用

https://docs.docker.com/network/links/

7d2e34d5c5a5b03c3d07113935d7817f3df.jpg

下面,继续介绍通过 --link 参数时间容器间通信。我们将创建busybox3和busybox4两个容器,其中busybox4可以通过busybox3容器名与busybox3容器进行通信。

新建busybox3和busybox4,其中busybox4通过 --link 参数指定连接到 busybox3容器。

[root@localhost ~]# docker run -itd --name=busybox3 busybox
a539a74a9ecad6782f88944604bbdd045f4a1fd6965a3484e04d1dbbec1e511d[root@localhost ~]# docker run -itd --link busybox3  --name=busybox4 busybox
f6c470354b55300106a3a8960c4c935dcdd0cb0f7ad6c941c8f040fdb0cd0a04

重新进入容器busybox4,查看hosts文件,可以看到host文件中已经出现busybox3容器,并配置了路由规则。

/ # cat /etc/hosts127.0.0.1	localhost
::1	localhost ip6-localhost ip6-loopback
fe00::0	ip6-localnet
ff00::0	ip6-mcastprefix
ff02::1	ip6-allnodes
ff02::2	ip6-allrouters
172.17.0.4	busybox3 a539a74a9eca
172.17.0.5	f6c470354b55

测试busybox4连接容器busybox3

/ # ping busybox3
PING busybox3 (172.17.0.4): 56 data bytes
64 bytes from 172.17.0.4: seq=0 ttl=64 time=0.077 ms
64 bytes from 172.17.0.4: seq=1 ttl=64 time=0.125 ms
^C
--- busybox3 ping statistics ---
2 packets transmitted, 2 packets received, 0% packet loss

(2)自定义bridge网络,实现容器间通信

从 Docker 1.10 版本开始,docker daemon 实现了一个内嵌的 DNS server,使容器可以直接通过“容器名”通信。使用默认的bridge网络,不能通过DNS server实现通过容器名通信,但是使用自定义bridge网络可以做到通过容器名互相通信。

通过 docker network create 命令创建一个自定义的bridge网络

[root@localhost ~]# docker network create --driver bridge busybox_bridge
1a83283cbf047fea14231daef7edb67e8a11383f61c176e5c4983e961e757a1e[root@localhost ~]# docker network ls
NETWORK ID          NAME                DRIVER              SCOPE
53c7e86fc3ec        bridge              bridge              local
1a83283cbf04        busybox_bridge      bridge              local
7d9eb4bd321c        host                host                local
4b740dab2aab        none                null                local

分别创建busybox5/busybox6容器,在run命令里加入--network参数使两个容器绑定到前面自定义的网络中。

[root@localhost ~]# docker run -itd --network busybox_bridge --name busybox5 busybox
ccd81a357cf48af2c01c64cd1ef7a4c463b415bd477d965f19a3b47be3760208[root@localhost ~]# docker run -itd --network busybox_bridge --name busybox6 busybox
d3e5af0eeb86a480fe868bb9ea7cea2cb29b7f12b7f680cbd5b48288c15b10e9

查看busybox_bridge网络情况,可以看到,busybox5/busybox6容器已经绑定到该网络中。

[root@localhost ~]# docker network inspect busybox_bridge[{"Name": "busybox_bridge","Id": "1a83283cbf047fea14231daef7edb67e8a11383f61c176e5c4983e961e757a1e","Created": "2018-12-25T22:17:10.981291803+08:00","Scope": "local","Driver": "bridge","EnableIPv6": false,"IPAM": {"Driver": "default","Options": {},"Config": [{"Subnet": "172.18.0.0/16","Gateway": "172.18.0.1"}]},"Internal": false,"Attachable": false,"Ingress": false,"ConfigFrom": {"Network": ""},"ConfigOnly": false,"Containers": {"ccd81a357cf48af2c01c64cd1ef7a4c463b415bd477d965f19a3b47be3760208": {"Name": "busybox5","EndpointID": "4da57d779c14bdee415eee69a92dd802250bf6e89cd744f8543c4498e32aebdc","MacAddress": "02:42:ac:12:00:02","IPv4Address": "172.18.0.2/16","IPv6Address": ""},"d3e5af0eeb86a480fe868bb9ea7cea2cb29b7f12b7f680cbd5b48288c15b10e9": {"Name": "busybox6","EndpointID": "6f130cc2055399c051cd556e20835793332605f9ee636885c602f2b257f9db80","MacAddress": "02:42:ac:12:00:03","IPv4Address": "172.18.0.3/16","IPv6Address": ""}},"Options": {},"Labels": {}}
]

接下来进入busybox5容器,测试是否可以通过容器名ping通busybox6

[root@localhost ~]# docker attach busybox5/ # ping busybox6
PING busybox6 (172.18.0.3): 56 data bytes
64 bytes from 172.18.0.3: seq=0 ttl=64 time=0.107 ms
64 bytes from 172.18.0.3: seq=1 ttl=64 time=0.149 ms

看下容器的hosts文件,文件里是没有busybox6的映射配置的。那么它是怎么通过容器名访问到另一个容器的呢?答案就是内嵌的dns服务器。

/ # cat /etc/hosts
127.0.0.1	localhost
::1	localhost ip6-localhost ip6-loopback
fe00::0	ip6-localnet
ff00::0	ip6-mcastprefix
ff02::1	ip6-allnodes
ff02::2	ip6-allrouters
172.18.0.2	ccd81a357cf4

查看DNS服务,可以看到指定了DNS解析服务地址:nameserver 127.0.0.11 。如果是连接到默认bridge网络的容器,在resolv.conf文件是没有127.0.0.11这个DNS服务器配置的

/ # cat /etc/resolv.conf 
nameserver 127.0.0.11
options ndots:0

容器中的DNS名称解析优先级顺序为:

  • ​ 内置DNS服务器127.0.0.11。
  • ​ 通过--dns等参数为容器配置的DNS服务器。
  • ​ docker守护进程的--dns服务配置(默认为8.8.8.8和8.8.4.4)
  • ​ 宿主机上的DNS设置。

文章收录于:

容器技术系列汇总

转载于:https://my.oschina.net/thinwonton/blog/2993309

相关文章:

登高自卑 | 我的PyTorch入门与实践笔记

1 函数名后带下划线会修改函数本身。如y.add_(x)会改变张量y。 2 PyTorch的Tensor和NumPy中的ndarray是可以互相转换的,转换后的对象共享内存(一个变另一个也跟着变)。

234. Palindrome Linked List - Easy

Given a singly linked list, determine if it is a palindrome. Example 1: Input: 1->2 Output: false Example 2: Input: 1->2->2->1 Output: true Follow up:Could you do it in O(n) time and O(1) space? 找中点,反转后半部分,再一一…

Hibernate 获取某个表全部记录时 奇怪现象 (重复出现某个记录)

我用Hibernate连接access的mdb 列出某个表全部记录的时候,发现有一个记录重复了。而直接用jdbc连接,就可以正确列出来。 本来还以为mdb不稳定,还吓了我一跳。毕竟打算用它作为长久数据库嘛~~ 分析了一下,发现正好重复的数据的主键…

iOS7导航栏和状态栏的定制

http://www.cocoachina.com/applenews/devnews/2013/1104/7287.html 转载于:https://www.cnblogs.com/luningning0901/p/4437190.html

2021年浙软夏令营预推免面经

夏令营 时间:七月中旬 参加人工智能分营,为期两周,评分标准:简历上课参与情况项目完成情况(具体占比不明)。 项目是完成三个深度学习模型,系统根据测试用例的通过情况评分。 预推免 时间:九月下旬 评…

ext前后台数据传输的标准化

一、标准化的数据传输是什么 这里所说的标准化主要是指,使用代理提交数据时,格式必须统一化、标准化,而服务器返回的数据格式也必须是标准化的数据。 简言之,使用代理提交数据时,前台--->后台,后台---&g…

对称加密解密类c#

namespace EncryptDLL{ #region 对称加密类 /// <summary> /// 对称加密解密类 /// </summary> public static class SymmetricEncryptClass { #region 对称加密代码 /// <summary> /// 对称加密方法 /// <…

java代码完全手写模仿qq登录界面

这是我模仿QQ2015版界面&#xff0c;实现的基本功能有登陆验证&#xff0c;重置等&#xff0c;当然直接复制代码运行是不一样的&#xff0c;还要注意自己插入自己的图片。 结果截图如下所示&#xff1a; import java.awt.BorderLayout;import java.awt.Color;import java.awt.F…

Vue3 计算属性的特性

computed:里面的方法 仅当依赖的值发生变动时&#xff0c;才会重新进行计算 这样一来解决的是性能问题 而methods里面的方法&#xff0c;哪怕无关值发生变动&#xff0c;也会重新进行计算 下面是两组对比 1-通过distance()计算属性来计算路程 2-通过getDis()方法计算路程…

解读源码中的问题

1.HashMap 构建中如何保证容量为 2 的幂次方 static final int tableSizeFor(int cap) {int n cap - 1;n | n >>> 1;n | n >>> 2;n | n >>> 4;n | n >>> 8;n | n >>> 16;return (n < 0) ? 1 : (n > MAXIMUM_CAPACITY) ?…

User Profile Data Web Part 读取属性字段

User Profile Data Web Part Property NameDisplay NameUserProfile_GUIDIdSIDSIDADGuidActive Directory IDAccountName帐户名FirstName名字SPS-PhoneticFirstName拼音名LastName姓氏SPS-PhoneticLastName拼音姓PreferredName名称SPS-PhoneticDisplayName拼音显示姓名WorkPho…

Linux 环境变量配置

linux 环境&#xff0c;用户通过shell 操作时&#xff0c;系统会为用户初使化环境变量&#xff0c; 比如系统公共资源路径: path , include , bin 等目录。 shell 模式下&#xff0c;执行 export &#xff0c; 查看用户环境变量 , echo $key 查询某个环境变量。设置环境变量&am…

Android 自定义View之3D骰子旋转

你可以指定立方体中每一面骰子的点数&#xff0c;颜色和背景&#xff0c;同时也可以指定执行的动画时间和动画插值器 更多有趣的view 使用 在根目录的build.gradle添加这一句代码&#xff1a; allprojects {repositories {//...maven { url https://jitpack.io }} } 复制代码在…

职业生涯的考虑

职业核心价值&#xff1a;活的有价值&#xff0c;有意义 第一阶段&#xff1a;技术&#xff08;27:2012&#xff5e;30:2015&#xff09;&#xff1a;移动互联网 第二阶段&#xff1a;销售或者管理&#xff08;30:2015&#xff5e;35:2020&#xff09;&#xff1a;成熟公司 第三…

算法的sound和complete

stackoverflow的答案 Soundness and Completeness of a algorithm stackexchange的答案 What does it mean to say an algorithm is Sound and Complete?

ArcGIS API for Silverlight 入门学习笔记(三):基础地图实例

该实例主要是包含六部分&#xff1a;地图范围、坐标、动画效果、全屏、比例尺、进度条。 前期准备工作 前台代码0 <UserControl x:Class"APIforSilverlightSamp.s2" xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x"ht…

BZOJ 4009 接水果

Description 风见幽香非常喜欢玩一个叫做osu!的游戏&#xff0c;其中她最喜欢玩的模式就是接水果。 由于她已经DT FC了The big black, 她觉得这个游戏太简单了&#xff0c;于是发明了一个更加难的版本。首先有一个地图&#xff0c;是一棵由\(n\)个顶点、\(n-1\)条边组成的树。这…

GitBook本地的安装与查看

1.安装nodejs 2.cnpm install -g gitbook-cli 查看版本&#xff1a;gitbook -V 3.gitbook init 注意npm加了代理&#xff0c;查看npm代理配置&#xff0c;将其注释即可 执行完后&#xff0c;你会看到多了两个文件 —— README.md 和 SUMMARY.md&#xff0c;它们的作用如下&…

用C++的random_shuffle()函数打乱int数组顺序

程序背景&#xff1a; 开组会&#xff0c;汇报人已确定&#xff0c;出一个随机的汇报顺序。 #include<bits/stdc.h> using namespace std;const int NUM 12;//汇报人数 int main() {string names[] {"SpongeBob","Patrick","Squidward"…

ios 绘制不规则 图形

最近才知道有一个软件 paintcode 它可以根据画出的图形自动的生成对应的 OC 代码 不用UI切图 我们也可以用代码实现自己想要的图形效果 使用教程可以百度&#xff1a;paintcode教程 http://blog.csdn.net/lujunelong/article/details/18899925 下载地址&#xff1a;http://www…

[转]Windows与VC命名规则

转自&#xff1a;http://hi.baidu.com/11158512/blog/item/0fbd5535cbfb5d1c91ef3970.html 匈牙利命名法是一种编程时的命名规范。基本原则是&#xff1a;变量名&#xff1d;属性&#xff0b;类型&#xff0b;对象描述。其中每一对象的名称都要求有明确含义&#xff0c;可以取对…

恢复误删的进程在使用的文件【转】

转自&#xff1a;https://www.cnblogs.com/276815076/p/5473185.html 原理&#xff1a;在Linux系统的/proc 分区下保存着进程的目录和名字&#xff0c;包含fd(文件描述符)和其下的子目录&#xff08;进程打开文件的链接&#xff09;&#xff0c;那么如果删除了一个文件&#xf…

编解码器架构中的桥(bridge)指什么

https://opennmt.net/OpenNMT-py/examples/Summarization.html?highlightbridge​​​​​​对于bridge做出如下解释 bridge: This is an additional layer that uses the final hidden state of the encoder as input and computes an initial hidden state for the decoder.…

控件包含代码块,因此无法修改控件集合

文章转载至: http://www.olnote.com/itlife/note/100000003.aspx控件包含代码块(即<% ... %>)&#xff0c;因此无法修改控件集合。 说明: 执行当前 Web 请求期间&#xff0c;出现未处理的异常。请检查堆栈跟踪信息&#xff0c;以了解有关该错误以及代码中导致错误的出处…

驰骋工作流引擎JFlow与activiti的对比之4种包含多实例的模式

为什么80%的码农都做不了架构师&#xff1f;>>> 4种包含多实例的模式 无同步的多实例&#xff08;MIwithout&#xff09;在流程中&#xff0c;一个活动可以激活多个实例&#xff0c;每个实例相互独立&#xff0c;并不需要在后面进行同步。 例子&#xff1a;比如用户…

Embarcadero Dev C++ 中文输出乱码

解决方式&#xff1a;保证编译器和文件的编码方式一样。 1. 编译器的编码方式 Embarcadero Dev C 界面 2. cpp文件编码方式 Notepad界面

关于登录记住密码使用cookie的详解

下面是我看的一篇文章引用过来&#xff0c;很易懂 设置cookie每个cookie都是一个名/值对&#xff0c;可以把下面这样一个字符串赋值给document.cookie&#xff1a;document.cookie"userId828";如果要一次存储多个名/值对&#xff0c;可以使用分号加空格&#xff08;;…

Linux服务器---安装tftp-server

安装tftp-server1、安装tftp-server[rootlocalhost weijie]# yum install -y tftp-serverLoaded plugins: fastestmirror, refresh-packagekit, securityRunning TransactionInstalling : tftp-server-0.49-8.el6.i686 1/1 Verifying : tftp…

linux指令 2>1 到底是个啥

训练好深度学习模型之后对其进行测试&#xff0c;测试的脚本如上图。 我对第11行感到不解&#xff0c;经过检索Linux重定向和文件描述符相关知识后&#xff0c;明白了 2代表着标准错误 1代表者标准输出(默认是屏幕) >代表流向 那么第11行代码的含义也就是&#xff0c;将…