ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

docker网络管理

2019-12-30 17:53:29  阅读:246  来源: 互联网

标签:容器 网络管理 IP 宿主机 端口 网络 模式 docker


五种网络管理的模式?

bridge network 模式(网桥):默认的网络模式。类似虚拟机的nat模式

 

特点:

1、宿主机上需要单独的bridge网卡,如默认docker默认创建的docker0。
2、容器之间、容器与主机之间的网络通信,是借助为每一个容器生成的一对veth pair虚拟网络设备对,进行通信的。一个在容器上,另一个在宿主机上。
3、每创建一个基于bridge网络的容器,都会自动在宿主机上创建一个veth**虚拟网络设备。
4、外部无法直接访问容器。需要建立端口映射才能访问。
5、容器借由veth虚拟设备通过如docker0这种bridge网络设备进行通信。
6、每一容器具有单独的IP

端口映射:

命令格式:
  docker run/create -P …
  或者 docker run/create –p …
命令参数(OPTIONS):
  -P, --publish-all 将容器内部所有暴露端口进行随机映射
  -p, --publish list 手动指定端口映射
注意:
  -p [HOST_IP]:[HOST_PORT]:CONTAINER_PORT
  如:-p ::80 将容器的80端口随机(端口)映射到宿主机任意IP
    -p :8000:6379 将容器的6379端口映射到宿主机任意IP的8000端口
    -p 192.168.5.1::3306 将容器的3306端口随机(端口)映射到宿主机的192.168.5.1IP

host network 模式(主机):容器与宿主机之间的网络无隔离,即容器直接使用宿主机网络

特点:

1、容器完全共享宿主机的网络。网络没有隔离。宿主机的网络就是容器的网络。
2、容器、主机上的应用所使用的端口不能重复。例如:如果宿主机已经占用了8090端口,那么任何一个host模式的容器都不可以使用8090端口了;反之同理。
3、外部可以直接访问容器,不需要端口映射。
4、容器的IP就是宿主机的IP

特殊host 网络模式(Container网络模式):

1、Container网络模式,其实就是容器共享其他容器的网络。
2、相当于该容器,,在网络层面上,将其他容器作为“主机”。它们之间的网络没有隔离。
3、这些容器之间的特性同host模式。
使用方法:
Docker run/create --network container:CONTAINER …

None network 模式:容器禁用所有网络。

特点:

1、容器上没有网络,也无任何网络设备。
2、如果需要使用网络,需要用户自行安装与配置。

应用场景:

该模式适合需要高度定制网络的用户使用。

Overlay network 模式(覆盖网络): 利用VXLAN实现的bridge模式,主要用于跨主机之前容器的通信

应用场景:

需要管理成百上千个跨主机的容器集群的网络时。

Macvlan network 模式:容器具备Mac地址,使其显示为网络上的物理设备

特点:

1、macvlan网络模式,最主要的特征就是他们的通信会直接基于mac地址进行转发。
2、这时宿主机其实充当一个二层交换机。Docker会维护着一个MAC地址表,当宿主机网络收到一个数据包后,直接根据mac地址找到对应的容器,再把数据交给对应的容器。
3、容器之间可以直接通过IP互通,通过宿主机上内建的虚拟网络设备(创建macvlan网络时自动创建),但与主机无法直接利用IP互通。

应用场景:

由于每个外来的数据包的目的mac地址就是容器的mac地址,这时每个容器对于外面网络来说就相当于一个真实的物理网络设备。因此当需要让容器来的网络看起来是一个真实的物理机时,使用macvlan模式

标签:容器,网络管理,IP,宿主机,端口,网络,模式,docker
来源: https://www.cnblogs.com/ycg-blog/p/12120960.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有