Dcoker网络

Docker网络

一、桥接模式(默认)

1、概念

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

bash 复制代码
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,则前台运行展示运行结果。

bash 复制代码
nginx -g "daemon off"

4、端口映射(nat)

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

二、Docker的网络模式

1、docker基于桥接模式的网络类型:(重要)

(1)host模式

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

创建host
bash 复制代码
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
bash 复制代码
docker run -itd --name 指定名字1 centos:7 /bin/bash

docker run -itd --name 指定名字2 --net=container:指定名字1 centos:7 /bin/bash
查看容器进程号
bash 复制代码
docker inspect -f '{{.State.Pid}}' 指定名字1

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

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

(3)none模式

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

创建none
bash 复制代码
docker run -itd --name 指定名字 --network none nginx:1.22

(4)自定义网络

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

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

查看网络设备
bash 复制代码
docker network ls     # 查看docker的网络设备
创建自定
bash 复制代码
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指定网卡名称  网段不要重复
报错
bash 复制代码
docker run -itd --name 指定名字 --network bridge --ip 172.17.0.10 nginx:1.22
# 系统创建的桥接模式,只能自动分配地址,也只能自动分配;我们在创建自定义网络时,才可以指定网段,并给指定网段分配ip地址

(5)总结

1、docker的网络模式就是桥接模式

host:与宿主机共享网络

container:容器之间共享

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

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

相关推荐
HUODUNYUN1 小时前
小程序免备案
网络·web安全·小程序·1024程序员节
basic_code1 小时前
Docker部署kafka集群
docker·容器·kafka
速盾cdn1 小时前
速盾:如何有效防止服务器遭受攻击?
网络·安全·web安全
华纳云IDC服务商1 小时前
怎么选择香港服务器的线路?解决方案
服务器·网络·香港服务器
可可爱爱的你吖2 小时前
webSocket的使用文档
网络·websocket·网络协议
EasyCVR2 小时前
GA/T1400视图库平台EasyCVR视频融合平台HLS视频协议是什么?
服务器·网络·人工智能·音视频
白白♛~2 小时前
网络管理之---3种网络模式配置
linux·服务器·网络
GOTXX2 小时前
NAT、代理服务与内网穿透技术全解析
linux·网络·人工智能·计算机网络·智能路由器
Z y..2 小时前
记:Docker部署kafka消费者注册不到问题
docker·容器·kafka
训山2 小时前
4000字浅谈Java网络编程
java·开发语言·网络