Docker Network drivers

bridge

docker 默认网络,每个 container 通过 docker0 进行通信,docker0(虚拟交换机) 是指装 docker 的时候默认创建的,所以默认创建的容器会绑到 docker0

docker0.png

每当开启一个容器时,会生成一个对应的 veth* 的网络接口,用来连接 containerdocker0

演示:

ip addr
docker run -d <image-id>
docker container ls
ip addr
docker container kill <contanier-id>
ip addr

ip 是 linux 一个命令,显示路由,网络设备,网络接口和隧道。
ip addr 显示分配给所有网络接口的地址。

overlay

overlay network 一个分布式的网络,可以实现跨主机容器间的通信。
创建该网络有些必要条件:

  • 必须集群才能创建 overlay network
  • 开放需要的端口
    TCP port 2377 for cluster management communications
    TCP and UDP port 7946 for communication among nodes
    UDP port 4789 for overlay network traffic

尽管 docker 官网首推配合 swarmoverlay 一起使用,swarm 又不是最 NB 的解决方案,关于 overlay 官方文档上的 demo 全是基于 swarm 的(差评),所以宁愿用借助第三方存储配合 overlay 一起使用。

docker swarm 默认 ingress。docker swarm 初始化或加入一个集群时, 创建 docker_gwbridge, 连接不同主机间容器的桥梁。

Consul 集群搭建

资源准备
  • 两台云主机
  • 两个外网 IP
    host1 -> 139.198.6.23 host2 -> 139.198.6.56
    consul server -> host1 consul client -> host2
host1
consul agent -server \
  -bootstrap-expect 1 \
  -node=host1 \
  -bind=0.0.0.0 \
  -advertise=139.198.6.23 \
  -data-dir workspace/data/consul/ \
  -client=0.0.0.0 -ui

consul members wan
host2
sudo consul agent -bind=0.0.0.0 \
  -advertise=139.198.6.56 \
  -data-dir workspace/data/consul/ \
  -node=host2 \
  -client=0.0.0.0 -ui

sudo consul join 139.198.6.23

consul members wan

如果 127.0.0.1 绑定 IP 是访问不到的,需要改成 0.0.0.0

Docker 配置参数
ExecStart=/usr/bin/dockerd \
  -H tcp://127.0.0.1:2375 \
  -H unix:///var/run/docker.sock \
  --cluster-store consul://139.198.6.23:8500 \
  --cluster-advertise 139.198.6.23:2375

wKiom1khdu3iDnaiAAGbL6U-F9k709.png

http://blog.51cto.com/littledevil/1922922

host

由于容器和宿主机共享同一个网络命名空间,换言之,容器的IP地址即为宿主机的IP地址。所以容器可以和宿主机一样,使用宿主机的任意网卡,实现和外界的通信。
采用host模式的容器,可以直接使用宿主机的IP地址与外界进行通信,若宿主机具有公有IP,那么容器也拥有这个公有IP。同时容器内服务的端口也可以使用宿主机的端口,无需额外进行NAT转换,而且由于容器通信时,不再需要通过linuxbridge等方式转发或者数据包的拆封,性能上有很大优势。当然,这种模式有优势,也就有劣势,主要包括以下几个方面:
最明显的就是容器不再拥有隔离、独立的网络栈。容器会与宿主机竞争网络栈的使用,并且容器的崩溃就可能导致宿主机崩溃,在生产环境中,这种问题可能是不被允许的。
容器内部将不再拥有所有的端口资源,因为一些端口已经被宿主机服务、bridge模式的容器端口绑定等其他服务占用掉了。

  • 共享一个命名空间
  • 直连物理网桥
  • 端口

none

在这种模式下,容器有独立的网络栈,但不包含任何网络配置,只具有lo这个loopback网卡用于进程通信。也就是说,none模式为容器做了最少的网络设置,但是俗话说得好“少即是多”,在没有网络配置的情况下,通过第三方工具或者手工的方式,开发这任意定制容器的网络,提供了最高的灵活性。

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

推荐阅读更多精彩内容