Docker(四):Docker基本网络配置
1、Libnetwork
Libnetwork提出了新的容器网络模型简称为CNM,定义了标准的API用于为容器配置网络。
CNM三个重要概念:
沙盒:一个隔离的网络运行环境,保存了容器网络栈的配置,包括了对网络接口、路由表、DNS的配置。
Endpoint:Endpoint将沙盒加入到一个网络中,一个Endpoint只能属于一个沙盒。
网络:网络包括一组能互相通信的Endpoint。
CNM的五种驱动:
bridge:Docker默认的网络驱动,Container通过一对veth pair链接到Dokcer网桥上,由Docker为容器动态分配IP及路由规则等。
host:容器与主机共享同一Network Namespace。
null:容器内网络配置为空,需要用户手动配置网络。
remote:Docker网络插件的实现,使CNM通过HTTP RESTful API对接第三方的网络方案。
overlay:Docker原生跨主机多子网网络方案,需要内核>=3.16才可正常使用。
2、基本网络配置
none:不为容器配置任何网络参数
启动容器:docker run --net=none -ti ubuntu:latest ip addr show
可以看到容器仅有一个lo环回接口,可以为手动容器配置网络。
container:与另一个容器共享Network Namespace
首先启动一个名为dockerNet的容器,dns为8.8.4.4
docker run -h dockerNet --dns 8.8.4.4 -tid ubuntu:latest bash
进入到容器并查看网络配置
docker exec -ti dockerNetID bash
再次启动共享网络的docker容器
docker run --net=container:dockerNetID -ti ubuntu:latest bash
再次查看网络配置,其IP地址、DNS、hostname都继承了dockerNet
host:与主机共享Root Network Namespace,容器可以完全操纵主机的协议栈、路由表,所以一般避免使用host模式
docker run --net=host -ti ubuntu:latest bash
查看网络配置与主机一样
bridge:Docker设计的NAT网络模型
docke run -ti --net=bridge ubuntu:latest ip addr show
该容器会从172.17.42.1/16子网内分配IP
overlay:Docker原生的跨主机多子网模型
overlay网络比较复杂,底层需要类似consul或etcd的KV存储系统进行消息同步,核心是通过Linux网桥与vxlan隧道实现跨主机划分子网。
overlay网络创建步骤:
获取实验版Docker:
curl -sSL https://experimental.docker.com/ | sh
主机1以bootstrap模式运行consul server
consul agent -server -bootstrap -data-dir /tmp/consul -bind Host-1-IP
主机2启动consul client
consul agent -data-dir /tmp/consul -bind HOST-2-IP
consul join HOST-1-IP
主机1启动Docker daemon
docker daemon --kv-store=consul:localhost:8500 --label=com.docker.network.driver.overlay.bind_interface=eth0
主机2启动daemon
docker daemon --kv-store=consul:localhost:8500 --label=com.docker.network.driver.overlay.bind_interface=eth0 \
--label=com.docker.network.driver.overlay.neighbor_ip=Host-1-IP
在主机1上创建overlay网络
docker network create -d overlay dev
查看创建的网络:docker network ls
在主机1上运行一个容器
docker run -tid --publish-service test.dev ubuntu:latest bash
test.dev:为容器在dev网络上绑定一个test的服务
在主机2上运行一个容器
docker run -tid --publish-service test1.dev.overlay ubuntu:latest bash
test1.dev.overlay:绑定名为test1的服务,test1服务所在的网络是dev,网络类型是overlay
此时主机1和主机2上的容器是可以通信的
overlay网络详情查看
沙盒保存在/var/run/docker/netns
创建软连接:ln -s /var/run/docker/netns/OverLayNetID /var/run/netns/OverLayNetID
创建软连接是为了能够使用IP命令操纵名字空间
查看端口详细信息:
ip netns exec OverLayNetID ip addr show
查看网桥信息:
ip netns exec OverLayNetID brctl show
查看vxlan信息:
ip netns exec OverLayNetID ip -d link show vxlan1 (vxlan1为网桥信息显示的interfaces)
# vxlan id表示为占用的vxlan隧道,一般为256~1000
3、Docker相关网络参数
Daemon相关:
查看帮助:docker daemon --help
-b,--bridge= #指定docker使用的网桥,默认为docker0
--bip= #指定docker0网桥的IP,不能与-b一起使用
--default-gateway= #设置容器的默认网关
--default-gateway-ipv6 #设置容器的ipv6网关
--dns=[] #设置容器的dns
--dns-search=[] #设置容器的search domain
--fixed-cidr= #定义容器的网段
--fixed-cidr-ipv6=
-H,--host=[] #指定docker client和docker daemon通信的socket地址,可以是tcp地址、unix socket地址或socket文件描述符,可同时指定多个
#如:docker daemon -H tcp://10.10.10.10:60000 -H unix:///var/run/docker.sock
#代表docker同时监听60000端口和docker.sock文件
--icc=true #允许/禁止容器间通信
--ip=0.0.0.0 #容器暴露端口时绑定的主机IP,默认为0.0.0.0
--ip-forward=true #开启转发功能
--userland-proxy=true #生产环境建议设置为false
Client相关:
查看帮助:docker run --help
--add-host=[] #在容器内的hosts文件添加一行解析
--dns=[]
--dns-search=[]
--expose=[] #暴露容器的端口,而不映射到主机端口
-h,--hostname= #设置容器的主机名
--link=[] #链接到另一个容器,在容器中可以通过ID或主机名访问到其他容器
--max-address=
-net=bridge #设置容器的网络运行模式,模式为上述介绍
-P,--publish-all=false #将容器所有暴露出的端口映射到主机随机端口
-p,--publish=[] #将容器一段范围内的端口映射到主机指定的端口
Docker Daemon实例:
docker daemon -H tcp://10.10.10.10:50000 -H unix:///var/run/docker.sock --fixed-cidr=172.17.55.0/24 --icc=false --userland-proxy=false
# --fixed-cidr指定容器将从172.17.55.0网段分配IP,--icc 禁止容器间通信,
Dokcer Client示例1:
docker run -tid --net=bridge -p 10000:22/tcp -h docker ubuntu:latest bash
# 启动一个主机名为docker 网络模式为bridge的容器,将10000映射到22端口,此容器会获取一个55.0网段的IP
Docker Client示例2:
docker run -tid --name=c1 ubuntu:latest bash
docker run -tid --link=c1:alias_c1 --name=c2 ubuntu:latest bash
# 首先启动了一个名为c1的容器,然后启动了一个连接到c1的名叫c2的容器,c1别名起为alias_c1,此时容器c2可通过c1别名与c1通信
Docker(四):Docker基本网络配置的更多相关文章
- Docker 使用指南 (三)—— 网络配置
版权声明:本文由田飞雨原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/95 来源:腾云阁 https://www.qclou ...
- Docker Network Configuration 高级网络配置
Network Configuration TL;DR When Docker starts, it creates a virtual interface named docker0 on the ...
- DOCKER学习_005:Flannel网络配置
一 简介 Flannel是一种基于overlay网络的跨主机容器网络解决方案,也就是将TCP数据包封装在另一种网络包里面进行路由转发和通信, Flannel是CoreOS开发,专门用于docker多机 ...
- (转) docker跨主机 macvlan 网络配置
原文链接 https://github.com/alfredhuang211/study-docker-doc/blob/master/docker%E8%B7%A8%E4%B8%BB%E6%9C%B ...
- Docker——四种网络模式
docker run创建Docker容器时,可以用–net选项指定容器的网络模式,Docker有以下4种网络模式: bridge模式:使用–net =bridge指定,默认设置: host模式 ...
- Docker学习第四天(Docker四种网络模式)
Docker四种网络模式 实现原理 Docker使用Linux桥接(参考<Linux虚拟网络技术>),在宿主机虚拟一个Docker容器网桥(docker0),Docker启动一个容器时会根 ...
- 5、Docker网络配置(单机)
一.概述 以下内容参考:https://docs.docker.com/network/#network-drivers Docker容器和服务如此强大的原因之一是您可以将它们连接在一起,或者将它们连 ...
- Docker 四种网络模式
原文 https://www.cnblogs.com/gispathfinder/p/5871043.html 我们在使用docker run创建Docker容器时,可以用--net选项指定容器的网络 ...
- Docker的4种网络模式
我们在使用docker run创建Docker容器时,可以用--net选项指定容器的网络模式,Docker有以下4种网络模式: · host模式,使用--net=host指定. · container ...
- docker学习3-虚拟网络模式
一.虚拟机网络模式 在理解docker网络隔离前,先看下之前虚拟机里对网络的处理,VirtualBox中有4中网络连接方式: NAT Bridged Adapter Internal Host-onl ...
随机推荐
- CM5(5.11.0)和CDH5(5.11.0)离线安装
概述 文件下载 系统环境搭建 日志查看 Q&A 参考 概述 CDH (Cloudera's Distribution, including Apache Hadoop),是Hadoop众多分支 ...
- (新)elasticsearch6.0版本安装head插件
ES6.0版本安装head插件 1.1 前言 不知道是我电脑问题还是最近的开源软件都比较**,mysql和elasticsearch新版本变动都比较大. elasticsearch6.0貌似已经不支持 ...
- 逻辑运算&数据
数据在计算机中只是0和1而已 数据在我们的理论中可以无穷大,但是在计算机中并不是,毕竟硬盘是有大小的. 具体可以通过一张图来理解 例如,0-F的表示 上面是有符号数,那么无符号数则是 事实上,计算机中 ...
- toastr 通知提示插件
table.sb-tb td,table.sb-tb th { padding: 5px 10px !important } jquery toastr 一款轻量级的通知提示框插件. 网页开发中经常会 ...
- JavaScript--我发现,原来你是这样的JS:函数表达式和闭包
一.介绍 本次博客主要介绍函数表达式的内容,主要是闭包. 二.函数表达式 定义函数的两种方式:一个是函数声明,另一个就是函数表达式. //1.函数声明写法 function fn2(){ consol ...
- ORACLE+PYTHON实战:复制A表数据到B表
最近在学习python ,看到了pythod的oracle,不仅可以一次fetch多条,也可以一次insert多条,想写一个复制A表数据到B表的程序来看看实际效率能不能提高.写完发现,非常惊艳!效率提 ...
- 关于pipelineDB调用GetLocalStreamReaders的BUG
如果想获取一个stream所有的reader,那么必须调用这个函数: Bitmapset *targets = GetLocalStreamReaders(relid); 如果stream下面没有re ...
- Java-----关于eclipse导入项目发生的问题及解决办法
今天通过eclipse导入了几个项目,项目名出现红叉,对于我这样的强迫症来说是无法容忍的,故现做总结,遇到同学可按照以下方法来操作. 改动的地方主要是两个方面: 1.Tomcat版本问题. 此问题是由 ...
- 10.0.0.55训练赛 Writeup
From LB@10.0.0.55 Misc 0x01 misc100(图片隐写) 首先用binwalk扫了一下,发现没毛病. 然后就搜了一下jpg的文件尾FFD9,如下图,看到了png格式的标志IH ...
- EasyUI实现异步载入tree(整合Struts2)
首先jsp页面有一ul用于展现Tree <ul id="mytree"></ul> 载入Tree <script type="text/ja ...