Docker网络

Docker网络
一、桥接模式(默认)
1、概念
桥接模式:部署好docker服务,启动之后,创建一个虚拟网桥(docker0),docker0是一个虚拟的网络设备,类似于交换机。每一次运行容器之后,docker就会从网段当中分配一个ip地址给这个容器。

docker inspect -f '{{range.NetworkSettings.Networks}}{{.IPAddress}}{{end}}' 容器名    # 查看虚拟ip地址

2、通信模式
不同网段:桥接模式(容器与主机)进行通信

同一网段:ip地址(容器和容器)进行通信

3、桥接工作模式
桥接模式:连接两个不同网络端的设备,共享通信方式

例如:172.17 ——路由器——192.168 # 基于mac地址转发数据帧

​ 当172.17这个网段访问192.168这个网段时

(1)桥接设备查看目标的mac地址

(2)APR广播。如果在mac地址表,桥接设备直接把数据帧转发目标的相应接口,如果不在,ARP广播,所有接口都会收到数据报文,有则响应,无则丢弃。

(3)物理层和数据链路层。桥接模式在物理层和数据链路层上工作,学习和转发mac地址,用于局域网内部的连接和扩展

(4)虚拟网卡。vetpair 方式生成一个对应的容器的虚拟网卡(ifconfig查看)

(5)docker虚拟网桥。docker网桥是宿主机虚拟出来的,并没有真的网络设备,外部是没有办法通过寻址找到的,即客户端是无法直接访问容器的ip地址,如果希望外部网络能够访问,要通过映射容器的端口到宿主机。

注意:容器要保持一直运行,必须要指定有一个运行的程序。以nginx容器为例,nginx镜像当中声明好了运行程序,保持nginx一直在后台运行,不加d,则前台运行展示运行结果。

nginx -g "daemon off"

4、端口映射(nat)
桥接模式的宿主机和容器之间的端口映射,实际上是做了nat地址转换,容器的私有ip映射到主机的ip上,从而实现容器与外部网络的通信,隐藏了容器内部的真实ip地址

二、Docker的网络模式
1、docker基于桥接模式的网络类型:(重要)
(1)host模式
容器不会虚拟出自己的网卡,也不会配置自己的ip,容器全部使用宿主机的ip和端口。一般用于端口不重复的类型的应用,docker本身是单节点模式,适用于部署单个服务的应用程序。

创建host

docker run -itd --name test1 --network host nginx:1.22

docker run -itd --name test2 --net=host nginx:1.22

docker ps     # 运行test1,
docker ps -a    # test1运行,test2关闭。原因:80端口被占用

(2)container模式
容器和容器之间共用一个network namesapce,不是和宿主机共享,新创建的容器也不会有自己的网卡,配置自己的ip,而是和一个容器共享ip端口,除了网络之外,其他的比如文件系统等等都是隔离

创建container

docker run -itd --name 指定名字1 centos:7 /bin/bash

docker run -itd --name 指定名字2 --net=container:指定名字1 centos:7 /bin/bash

查看容器进程号

docker inspect -f '{{.State.Pid}}' 指定名字1

docker inspect -f '{{.State.Pid}}' 指定名字2

ls -l /proc/进程号/ns   # net一样

(3)none模式
创建容器之后,容器有自己的网络命名空间,但是不会进行任何网络的配置,没有网卡,没有ip,没有端口,只有本地的lo的回环网络,没有办法进行联网,网络是封闭的,一般用于内部调试。

创建none

docker run -itd --name 指定名字 --network none nginx:1.22

(4)自定义网络
和桥接模式一样,只不过我们可以自定义容器的网段和给新创建的容器指定ip地址

只有自定义网络可以查看网络设备在创建容器的时候指定ip地址

查看网络设备

docker network ls     # 查看docker的网络设备

创建自定

docker network create --subnet=172.111.0.0/16 指定网络名字1    # 创建自定义网络

ifconfig   # 查看

docker run -itd --name 容器名 --net 指定网络名2 --ip 172.111.0.10 -p 88:80 nginx:1.22

创建自定并指定网卡名称
docker network create --subnet=172.112.0.0/16 --opt "com.docker.network.bridge.name"="docker2" 指定网络名字2    # docker2指定网卡名称  网段不要重复

报错

docker run -itd --name 指定名字 --network bridge --ip 172.17.0.10 nginx:1.22
# 系统创建的桥接模式,只能自动分配地址,也只能自动分配;我们在创建自定义网络时,才可以指定网段,并给指定网段分配ip地址

(5)总结
1、docker的网络模式就是桥接模式

host:与宿主机共享网络

container:容器之间共享

none:无网络模式,即单机模式

自定义网络 :只有自定义网络可以在创建容器的时候指定IP地址

  • 4
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值