侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Docker 网络模式(四种)详细介绍

Docker  /  管理员 发布于 5年前   346

Docker 网络模式

本文首先介绍了Docker自身的4种网络工作方式,

Docker作为目前最火的轻量级容器技术,有很多令人称道的功能,如Docker的镜像管理。然而,Docker同样有着很多不完善的地方,网络方面就是Docker比较薄弱的部分。因此,我们有必要深入了解Docker的网络知识,以满足更高的网络需求。

四种网络模式

我们在使用docker run创建Docker容器时,可以用--net选项指定容器的网络模式,Docker有以下4种网络模式:

・ host模式,使用--net=host指定。

・ container模式,使用--net=container:NAME_or_ID指定。

・ none模式,使用--net=none指定。

・ bridge模式,使用--net=bridge指定,默认设置。

1 host模式

众所周知,Docker使用了Linux的Namespaces技术来进行资源隔离,如PID Namespace隔离进程,Mount Namespace隔离文件系统,Network Namespace隔离网络等。一个Network Namespace提供了一份独立的网络环境,包括网卡、路由、Iptable规则等都与其他的Network Namespace隔离。一个Docker容器一般会分配一个独立的Network Namespace。但如果启动容器的时候使用host模式,那么这个容器将不会获得一个独立的Network Namespace,而是和宿主机共用一个Network Namespace。容器将不会虚拟出自己的网卡,配置自己的IP等,而是使用宿主机的IP和端口。

例如,我们在10.10.101.105/24的机器上用host模式启动一个含有web应用的Docker容器,监听tcp80端口。当我们在容器中执行任何类似ifconfig命令查看网络环境时,看到的都是宿主机上的信息。而外界访问容器中的应用,则直接使用10.10.101.105:80即可,不用任何NAT转换,就如直接跑在宿主机中一样。但是,容器的其他方面,如文件系统、进程列表等还是和宿主机隔离的。

 2 container模式

在理解了host模式后,这个模式也就好理解了。这个模式指定新创建的容器和已经存在的一个容器共享一个Network Namespace,而不是和宿主机共享。新创建的容器不会创建自己的网卡,配置自己的IP,而是和一个指定的容器共享IP、端口范围等。同样,两个容器除了网络方面,其他的如文件系统、进程列表等还是隔离的。两个容器的进程可以通过lo网卡设备通信。

 3 none模式

这个模式和前两个不同。在这种模式下,Docker容器拥有自己的Network Namespace,但是,并不为Docker容器进行任何网络配置。也就是说,这个Docker容器没有网卡、IP、路由等信息。需要我们自己为Docker容器添加网卡、配置IP等。

 4 bridge模式

bridge模式是Docker默认的网络设置,此模式会为每一个容器分配Network Namespace、设置IP等,并将一个主机上的Docker容器连接到一个虚拟网桥上。下面着重介绍一下此模式。
host模式

使用Docker run时使用Cnet=host指定
Docker使用的网络实际上和宿主机一样,在容器内看到的网卡ip是宿主机上的ip。

[root@localhost ~]# docker run -it --rm --net=host centos_with_net bash

Crm,退出镜像时同时删除该镜像

[root@localhost /]# ifconfigdocker0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500    inet 172.17.42.1 netmask 255.255.0.0 broadcast 0.0.0.0    inet6 fe80::8cfc:c7ff:fe49:f1ae prefixlen 64 scopeid 0x20<link>    ether 4e:90:a4:b6:91:91 txqueuelen 0 (Ethernet)    RX packets 58 bytes 3820 (3.7 KiB)    RX errors 0 dropped 0 overruns 0 frame 0    TX packets 6 bytes 468 (468.0 B)    TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500    inet 192.168.1.179 netmask 255.255.255.0 broadcast 192.168.1.255    inet6 fe80::20c:29ff:fedb:b228 prefixlen 64 scopeid 0x20<link>    ether 00:0c:29:db:b2:28 txqueuelen 1000 (Ethernet)    RX packets 10562 bytes 868003 (847.6 KiB)    RX errors 0 dropped 0 overruns 0 frame 0    TX packets 2985 bytes 390673 (381.5 KiB)    TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536    inet 127.0.0.1 netmask 255.0.0.0    inet6 ::1 prefixlen 128 scopeid 0x10<host>    loop txqueuelen 0 (Local Loopback)    RX packets 16 bytes 960 (960.0 B)    RX errors 0 dropped 0 overruns 0 frame 0    TX packets 16 bytes 960 (960.0 B)    TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0veth5446780: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500    inet6 fe80::c0f4:f5ff:fe71:f3bd prefixlen 64 scopeid 0x20<link>    ether c2:f4:f5:71:f3:bd txqueuelen 0 (Ethernet)    RX packets 7 bytes 558 (558.0 B)    RX errors 0 dropped 0 overruns 0 frame 0    TX packets 49 bytes 3894 (3.8 KiB)    TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0veth111b1ca: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500    inet6 fe80::4c90:a4ff:feb6:9191 prefixlen 64 scopeid 0x20<link>    ether 4e:90:a4:b6:91:91 txqueuelen 0 (Ethernet)    RX packets 7 bytes 558 (558.0 B)    RX errors 0 dropped 0 overruns 0 frame 0    TX packets 13 bytes 1026 (1.0 KiB)    TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0veth55dbbb2: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500    inet6 fe80::c84d:9ff:fecd:da27 prefixlen 64 scopeid 0x20<link>    ether ca:4d:09:cd:da:27 txqueuelen 0 (Ethernet)    RX packets 7 bytes 558 (558.0 B)    RX errors 0 dropped 0 overruns 0 frame 0    TX packets 42 bytes 3336 (3.2 KiB)    TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0veth5e2dff4: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500    inet6 fe80::9465:1bff:fed2:f75d prefixlen 64 scopeid 0x20<link>    ether 96:65:1b:d2:f7:5d txqueuelen 0 (Ethernet)    RX packets 7 bytes 558 (558.0 B)    RX errors 0 dropped 0 overruns 0 frame 0    TX packets 20 bytes 1584 (1.5 KiB)    TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0veth628d605: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500    inet6 fe80::5cc8:ebff:fedb:ea69 prefixlen 64 scopeid 0x20<link>    ether 5e:c8:eb:db:ea:69 txqueuelen 0 (Ethernet)    RX packets 7 bytes 558 (558.0 B)    RX errors 0 dropped 0 overruns 0 frame 0    TX packets 6 bytes 468 (468.0 B)    TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0veth991629e: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500    inet6 fe80::b464:e5ff:fed5:1bd6 prefixlen 64 scopeid 0x20<link>    ether b6:64:e5:d5:1b:d6 txqueuelen 0 (Ethernet)    RX packets 7 bytes 558 (558.0 B)    RX errors 0 dropped 0 overruns 0 frame 0    TX packets 27 bytes 2142 (2.0 KiB)    TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0vethb086b1c: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500    inet6 fe80::dcdf:66ff:fed8:f2df prefixlen 64 scopeid 0x20<link>    ether de:df:66:d8:f2:df txqueuelen 0 (Ethernet)    RX packets 8 bytes 636 (636.0 B)    RX errors 0 dropped 0 overruns 0 frame 0    TX packets 34 bytes 2700 (2.6 KiB)    TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0[root@localhost /]# exitexit

与宿主机的IP信息对比

[root@localhost ~]# ifconfigdocker0  Link encap:Ethernet HWaddr 4E:90:A4:B6:91:91     inet addr:172.17.42.1 Bcast:0.0.0.0 Mask:255.255.0.0     inet6 addr: fe80::8cfc:c7ff:fe49:f1ae/64 Scope:Link     UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1     RX packets:58 errors:0 dropped:0 overruns:0 frame:0     TX packets:6 errors:0 dropped:0 overruns:0 carrier:0     collisions:0 txqueuelen:0     RX bytes:3820 (3.7 KiB) TX bytes:468 (468.0 b)eth0   Link encap:Ethernet HWaddr 00:0C:29:DB:B2:28     inet addr:192.168.1.179 Bcast:192.168.1.255 Mask:255.255.255.0     inet6 addr: fe80::20c:29ff:fedb:b228/64 Scope:Link     UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1     RX packets:10661 errors:0 dropped:0 overruns:0 frame:0     TX packets:3012 errors:0 dropped:0 overruns:0 carrier:0     collisions:0 txqueuelen:1000     RX bytes:876797 (856.2 KiB) TX bytes:398049 (388.7 KiB)lo    Link encap:Local Loopback     inet addr:127.0.0.1 Mask:255.0.0.0     inet6 addr: ::1/128 Scope:Host     UP LOOPBACK RUNNING MTU:65536 Metric:1     RX packets:16 errors:0 dropped:0 overruns:0 frame:0     TX packets:16 errors:0 dropped:0 overruns:0 carrier:0     collisions:0 txqueuelen:0     RX bytes:960 (960.0 b) TX bytes:960 (960.0 b)veth5e2dff4 Link encap:Ethernet HWaddr 96:65:1B:D2:F7:5D     inet6 addr: fe80::9465:1bff:fed2:f75d/64 Scope:Link     UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1     RX packets:7 errors:0 dropped:0 overruns:0 frame:0     TX packets:20 errors:0 dropped:0 overruns:0 carrier:0     collisions:0 txqueuelen:0     RX bytes:558 (558.0 b) TX bytes:1584 (1.5 KiB)vethb086b1c Link encap:Ethernet HWaddr DE:DF:66:D8:F2:DF     inet6 addr: fe80::dcdf:66ff:fed8:f2df/64 Scope:Link     UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1     RX packets:8 errors:0 dropped:0 overruns:0 frame:0     TX packets:34 errors:0 dropped:0 overruns:0 carrier:0     collisions:0 txqueuelen:0     RX bytes:636 (636.0 b) TX bytes:2700 (2.6 KiB)veth55dbbb2 Link encap:Ethernet HWaddr CA:4D:09:CD:DA:27     inet6 addr: fe80::c84d:9ff:fecd:da27/64 Scope:Link     UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1     RX packets:7 errors:0 dropped:0 overruns:0 frame:0     TX packets:42 errors:0 dropped:0 overruns:0 carrier:0     collisions:0 txqueuelen:0     RX bytes:558 (558.0 b) TX bytes:3336 (3.2 KiB)veth111b1ca Link encap:Ethernet HWaddr 4E:90:A4:B6:91:91     inet6 addr: fe80::4c90:a4ff:feb6:9191/64 Scope:Link     UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1     RX packets:7 errors:0 dropped:0 overruns:0 frame:0     TX packets:13 errors:0 dropped:0 overruns:0 carrier:0     collisions:0 txqueuelen:0     RX bytes:558 (558.0 b) TX bytes:1026 (1.0 KiB)veth628d605 Link encap:Ethernet HWaddr 5E:C8:EB:DB:EA:69     inet6 addr: fe80::5cc8:ebff:fedb:ea69/64 Scope:Link     UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1     RX packets:7 errors:0 dropped:0 overruns:0 frame:0     TX packets:6 errors:0 dropped:0 overruns:0 carrier:0     collisions:0 txqueuelen:0     RX bytes:558 (558.0 b) TX bytes:468 (468.0 b)veth991629e Link encap:Ethernet HWaddr B6:64:E5:D5:1B:D6     inet6 addr: fe80::b464:e5ff:fed5:1bd6/64 Scope:Link     UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1     RX packets:7 errors:0 dropped:0 overruns:0 frame:0     TX packets:27 errors:0 dropped:0 overruns:0 carrier:0     collisions:0 txqueuelen:0     RX bytes:558 (558.0 b) TX bytes:2142 (2.0 KiB)veth5446780 Link encap:Ethernet HWaddr C2:F4:F5:71:F3:BD     inet6 addr: fe80::c0f4:f5ff:fe71:f3bd/64 Scope:Link     UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1     RX packets:7 errors:0 dropped:0 overruns:0 frame:0     TX packets:49 errors:0 dropped:0 overruns:0 carrier:0     collisions:0 txqueuelen:0     RX bytes:558 (558.0 b) TX bytes:3894 (3.8 KiB)

container模式

使用Cnet=Container:container_id/container_name,多个容器使用共同的网络看到的ip是一样的。

[root@localhost ~]# docker psCONTAINER ID    IMAGE        COMMAND       CREATED       STATUS       PORTS        NAMES7169e8be6d3e    centos       "/bin/bash"     About an hour ago  Up About an hour            serene_goldstine4cd696928bbe    centos       "bash"       About an hour ago  Up About an hour            cent_testv24f5bf6f33f2c    centos       "bash"       About an hour ago  Up About an hour            gloomy_colden0a80861145c9    centos       "bash"       About an hour ago  Up About an hour            mad_carsonfb45150dbc21    centos       "bash"       About an hour ago  Up About an hour            cent_testv3222c7c5c456    centos       "bash"       2 hours ago     Up 2 hours               sick_albattanie136b27a8e17    centos       "bash"       2 hours ago     Up 2 hours               tender_euclid[root@localhost ~]# docker exec -it 7169 bash[root@7169e8be6d3e /]# ifconfigbash: ifconfig: command not found[root@7169e8be6d3e /]# yum install -y net-tools ifconfig[root@7169e8be6d3e /]# ifconfigeth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500    inet 172.17.0.8 netmask 255.255.0.0 broadcast 0.0.0.0    inet6 fe80::42:acff:fe11:8 prefixlen 64 scopeid 0x20<link>    ether 02:42:ac:11:00:08 txqueuelen 0 (Ethernet)    RX packets 5938 bytes 15420209 (14.7 MiB)    RX errors 0 dropped 0 overruns 0 frame 0    TX packets 4841 bytes 329652 (321.9 KiB)    TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536    inet 127.0.0.1 netmask 255.0.0.0    inet6 ::1 prefixlen 128 scopeid 0x10<host>    loop txqueuelen 0 (Local Loopback)    RX packets 0 bytes 0 (0.0 B)    RX errors 0 dropped 0 overruns 0 frame 0    TX packets 0 bytes 0 (0.0 B)    TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0[root@7169e8be6d3e /]# exitexit[root@localhost ~]# docker run -it --rm --net=container:7169 centos_with_net bash[root@7169e8be6d3e /]# ifconfigeth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500    inet 172.17.0.8 netmask 255.255.0.0 broadcast 0.0.0.0    inet6 fe80::42:acff:fe11:8 prefixlen 64 scopeid 0x20<link>    ether 02:42:ac:11:00:08 txqueuelen 0 (Ethernet)    RX packets 5942 bytes 15420377 (14.7 MiB)    RX errors 0 dropped 0 overruns 0 frame 0    TX packets 4855 bytes 330480 (322.7 KiB)    TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0lo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536    inet 127.0.0.1 netmask 255.0.0.0    inet6 ::1 prefixlen 128 scopeid 0x10<host>    loop txqueuelen 0 (Local Loopback)    RX packets 0 bytes 0 (0.0 B)    RX errors 0 dropped 0 overruns 0 frame 0    TX packets 0 bytes 0 (0.0 B)    TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

none模式

使用Cnet=none指定,这种模式下不会配置任何网络。

[root@localhost ~]# docker run -it --rm --net=none centos_with_net bash[root@67d037935636 /]# ifconfiglo: flags=73<UP,LOOPBACK,RUNNING> mtu 65536    inet 127.0.0.1 netmask 255.0.0.0    inet6 ::1 prefixlen 128 scopeid 0x10<host>    loop txqueuelen 0 (Local Loopback)    RX packets 0 bytes 0 (0.0 B)    RX errors 0 dropped 0 overruns 0 frame 0    TX packets 0 bytes 0 (0.0 B)    TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0

bridge模式(默认模式)

使用Cnet=bridge指定,不用指定默认就是这种网络模式。这种模式会为每个容器分配一个独立的Network Namespace。类似于Vmware的nat网络模式。同一个宿主机上的所有容器会在同一个网段下,相互之间是可以通信的。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


  • 上一条:
    Docker 网络工作原理详解
    下一条:
    Docker 自动部署tomcat详解
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在docker环境中实现Laravel项目执行定时任务和消息队列流程步骤(0个评论)
    • 在MacBook下laravel项目多php版本docker开发环境配置方案(0个评论)
    • 在docker环境中部署docker部署elk架构流程步骤(1个评论)
    • docker compose跟Dockerfile的区别浅析(0个评论)
    • Ubuntu 22.04系统中安装podman流程步骤(1个评论)
    • 近期文章
    • 智能合约Solidity学习CryptoZombie第三课:组建僵尸军队(高级Solidity理论)(0个评论)
    • 智能合约Solidity学习CryptoZombie第二课:让你的僵尸猎食(0个评论)
    • 智能合约Solidity学习CryptoZombie第一课:生成一只你的僵尸(0个评论)
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2017-11
    • 2020-06
    • 2021-05
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-11
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2024-03
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客