006.Docker网络管理
一 docker网络模式
1.1 四种模式
- host模式
- container模式
- none模式
- bridge模式
root@docker:~# docker network ls #默认已经创建好三种模式,且无法删除
NETWORK ID NAME DRIVER SCOPE
4237839afd99 bridge bridge local
c7a14aafc3b5 host host local
3cc2eba3eb5f none null local
1.2 host模式
- host模式下的容器没有隔离的 network namespace;
- 容器的 IP 地址同 Docker host 的 IP 地址;
- 需要注意容器中服务的端口号不能与 Docker host 上已经使用的端口号相冲突;
- host 模式能够和其它模式共存。

root@docker:~# docker run -d --name docker_host1 --network host training/webapp python app.py
root@docker:~# docker exec -it docker_host1 /bin/bash
root@docker:/opt/webapp# ifconfig -a

1.3 container模式

root@docker:~# docker run -dit --name docker_host2 centos7-xhy /bin/bash
root@docker:~# docker run -dit --name docker_host3 --network container:docker_host2 centos7-xhy /bin/bash
root@docker:~# docker exec -it docker_host2 /bin/bash
[root@c9b51e88f75a /]# ifconfig -a

root@docker:~# docker exec -it docker_host3 /bin/bash
[root@c9b51e88f75a /]# ifconfig -a

1.4 none模式
root@docker:~# docker run -dit --name docker_host4 --network none centos7-xhy /bin/bash
root@docker:~# docker exec -it docker_host4 /bin/bash

1.5 bridge模式
二 bridge模式
2.1 bridge模式简介
root@docker:~# iptables -t nat -vnL


2.2 bridge模式特点
- 使用一个 linux bridge,默认为 docker0;
- 使用 veth 对,一端在容器的网络 namespace 中,另一端在 docker0 上;
- 该模式下Docker Container不具有一个公有IP,因为宿主机的IP地址与veth pair的 IP地址不在同一个网段内;
- Docker采用 NAT 方式,将容器内部的服务监听的端口与宿主机的某一个端口port 进行“绑定”,使得宿主机以外的网络可以主动将网络报文发送至容器内部;
- 外界访问容器内的服务时,需要访问宿主机的 IP 以及宿主机的端口 port;
- NAT 模式基于三层网络上的实现方式,故肯定会影响网络的传输效率;
- 容器拥有独立、隔离的网络栈,以便于使得容器和宿主机以外的网络通过NAT建立通信;

root@docker:~# docker run -dit --name docker_host5 -p 5005:80 training/webapp python app.py
root@docker:~# docker exec -it docker_host5 /bin/bash
root@951e6cd51cd0:/opt/webapp# ifconfig -a

root@docker:~# iptables -t nat -vnL #查看端口映射

root@docker:~# iptables-save
……
-A POSTROUTING -s 172.17.0.3/32 -d 172.17.0.3/32 -p tcp -m tcp --dport 80 -j MASQUERADE
……
-A DOCKER ! -i docker0 -p tcp -m tcp --dport 5005 -j DNAT --to-destination 172.17.0.3:80
三 docker容器的DNS和主机名
3.1 DNS和主机名配置文件
root@docker:~# docker run -dit --name docker_host6 centos7-xhy /bin/bash
root@docker:~# docker exec -it docker_host6 /bin/bash
[root@12ac200c6a4c /]# mount
...
/dev/sda4 on /etc/resolv.conf type ext4 (rw,relatime,data=ordered)
/dev/sda4 on /etc/hostname type ext4 (rw,relatime,data=ordered)
/dev/sda4 on /etc/hosts type ext4 (rw,relatime,data=ordered)
...
3.2 修改dns和主机名
- -h HOSTNAME 或 --hostname=HOSTNAME:设置容器的主机名,此名称会写入/etc/hostname和/etc/hosts文件中,也会在容器的bash提示符看到。但是在外部,容器的主机名是无法查看的,不会出现在其他容器的hosts文件中,即使使用docker ps命令也无法查看。此参数是docker run命令的参数,而非docker daemon的启动参数。
- --dns=IP_ADDRESS...:为容器配置DNS,写入/etc/resolv.conf中。该参数可以在docker daemon 启动的时候设置,也可以在docker run时设置,默认为8.8.8.8或8.8.4.4。
四 多节点docker网络
- 直接路由方式;
- 桥接方式(如pipework);
- Overlay隧道方式(如flannel、ovs+gre)等。
- 一类是基于 VxLAN ,对跨节点网络的原生支持;
- 另一种是通过插件(plugin)方式引入的第三方实现方案,比如 Flannel,Calico 等等。
4.1 直接路由方式
4.2 桥接-pipework方式

root@docker01:~# apt-get install bridge-utils #两台docker宿主机都建议安装此工具
root@docker02:~# apt-get install bridge-utils #两台docker宿主机都建议安装此工具
root@docker01:~# docker run -dit --name container01 --net=none centos:7 /bin/bash
root@docker01:~# docker run -dit --name container02 --net=none centos:7 /bin/bash
root@docker02:~# docker run -dit --name container03 --net=none centos:7 /bin/bash
root@docker02:~# docker run -dit --name container04 --net=none centos:7 /bin/bash root@docker01:~# git clone https://github.com/jpetazzo/pipework
root@docker02:~# git clone https://github.com/jpetazzo/pipework
root@docker01:~# cp pipework/pipework /usr/local/bin/
root@docker02:~# cp pipework/pipework /usr/local/bin/
root@docker01:~# chmod u+x /usr/local/bin/pipework
root@docker01:~# brctl show #查看当前默认的桥接网卡

root@docker01:~# pipework br0 container01 172.24.8.201/24@172.24.8.2
root@docker01:~# pipework br0 container02 172.24.8.202/24@172.24.8.2
root@docker02:~# pipework br0 container03 172.24.8.203/24@172.24.8.2
root@docker02:~# pipework br0 container04 172.24.8.204/24@172.24.8.2
root@docker01:~# brctl show

root@docker02:~# brctl show

- 查看主机是否包含br0(可以自定义)网桥,如果不存在就创建;
- 向容器实例添加一块网卡(可以设置网卡名),并配置相应的固定IP;
- 若容器实例已经有默认的路由,则删除掉,将@后面的IP设置为默认路由的网关;
- 将容器实例连接到创建的br0网桥上。
root@docker01:~# docker network create --driver bridge --subnet 172.24.8.0/24 --gateway 172.24.8.2 br1
root@docker:~# docker network inspect br1

root@docker01:~# ip addr add 172.24.8.90/24 dev br0;\
ip addr del 172.24.8.90/24 dev eth0;\
brctl addif br0 eth0;\
ip route del default;\
ip route add default via 172.24.8.2 dev br0
root@docker02:~# ip addr add 172.24.8.91/24 dev br0 ;\
ip addr del 172.24.8.91/24 dev eth0;\
brctl addif br0 eth0;\
ip route del default;\
ip route add default via 172.24.8.2 dev br0


root@docker01:~# ping 172.24.8.201

4.3 基于etcd Docker原生overlay网络
4.4 基于Flannel的overlay网络
006.Docker网络管理的更多相关文章
- Docker网络管理机制实例解析+创建自己Docker网络
实例解析Docker网络管理机制(bridge network,overlay network),介绍Docker默认的网络方式,并创建自己的网络桥接方式,将开发的容器添加至自己新建的网络,提高Doc ...
- docker 实践十:docker 网络管理
本篇是关于 docker 网络管理的内容,同时也包含了 docker 网络的高级应用. 注:环境为 CentOS7,docker 19.03. docker 网络基础 docker 网络模型 在 do ...
- Docker 网络管理及容器跨主机通信
1.网络模式 docker支持四种网络模式,使用--net选项指定: host,--net=host,如果指定此模式,容器将不会获得一个独立的network namespace,而是和宿主机共用一个. ...
- Docker网络管理
一.Docker的四种网络模式(host.container.none.bridge) 1. host模式,使用docker run时使用--net=host指定,docker使用的网络实际上和宿主机 ...
- Docker网络管理-外部访问容器
注意:这里使用的方法是端口映射,需要说明的是端口映射是在容器启动的时候才能完成端口映射的. 1,搭建1个web服务器,让外部机器访问. docker run -itd centos /bin/bash ...
- Docker系统六:Docker网络管理
Docker网络 I. Docer的通信方式 默认情况下,Docker使用网桥(brige)+ NAT的通信模型. Docker启动时会自动创建网桥Docker0,并配置ip 172.17.0.1/1 ...
- Docker入门 - 006 Docker 多种数据库的安装
Docker 安装 MySQL 查找Docker Hub上的mysql镜像 root@VM_16_14_centos ~# docker search mysql INDEX NAME DESCRIP ...
- Docker 网络管理
网络模式 容器网络访问原理 桥接宿主机网络和配置固定IP地址 Docker 支持五种网络模式: 1.网络模式: --net 1.1 bridge 默认网络,Docker启动后默认创建一个docke ...
- ubuntu-docker入门到放弃(五)docker网络管理
查看docker宿主机的网卡信息我们会发现,有一个docker0的网卡,这个网卡就是用于跟docker容器进行通讯的,这个网段跟我们docker容器的网段是一样的: #ifconfig docker容 ...
随机推荐
- 【加密】Md5Util
import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; public class Md5U ...
- PWA,SPA,MPA
PWA渐进式应用 特点: 不会部署到应用商店. 离线应用,通过设备进行存储规划 在发布了pwa的网站,浏览器会询问是否安装app到主屏. 方便分享,通过url. 可推送通知 . 通过service w ...
- JavaScript练习 - 模态对话框
模态对话框练习 <!DOCTYPE html> <html lang="en"> <head> <meta charset="U ...
- JavaScript客户端签名直传OSS
参考链接: https://help.aliyun.com/document_detail/31925.html?spm=5176.11065259.1996646101.searchclickres ...
- 解决xadmin登录卡顿延迟的问题
我的django项目引入xadmin作为后台,之前登录一直很快,今天突然怎么也登录不了. 怀疑是xadmin请求了网络资源,当我断网再次登录,果然进去了. 然后在xadmin文件夹右键-find in ...
- JDK8 Lambda表达式对代码的简化
只是举个例子: public class LambdaDemo { public static String findData( String name , LambdaInterface finde ...
- 单例模式(懒汉、饿汉、同步锁、static、枚举)实现
使用前提: 需要频繁的进行创建和销毁的对象,创建对象时耗时过多或耗费资源过多 三要素: 1.构造方法私有化: 2.实例化的变量引用私有化: 3.获取实例的方法共有. 1.饿汉式单例 弊端:在类装载的时 ...
- S5PV210 ADC转换
第一节 S5PV210的ADCS5PV210的ADC可支持10bit和12bit,它支持10路输入,然后将输入的模拟的信号转换为10bit或者12bit的二进制数字信号.在5MHz的时钟下,最大转换速 ...
- [HTML]点击按钮,页面总是跳回顶端的解决方法(Clicking an button,always resets the view to top of page)
1 前言 当网页页面较长或者表单较多时,右侧会出现滚动条,然而经常会出现点击底部的<button>按钮或者<a>超链接,会出现点击后,当前页面会回到顶端. 2 方案 例如样例代 ...
- 取消Eclipse控制台显示行数的限制
--------------------------------------------------------------------------------------------------- ...