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地址

相关推荐
技术小齐25 分钟前
网络运维学习笔记 022 HCIA-Datacom新增知识点03园区网典型组网架构及案例实战
运维·网络·学习
黄卷青灯771 小时前
抓包工具 wireshark
网络·测试工具·wireshark
哥是黑大帅1 小时前
Docker基于Ollama本地部署大语言模型
python·docker·语言模型
LUCIAZZZ2 小时前
Https解决了Http的哪些问题
java·网络·网络协议·spring·http·rpc·https
、BeYourself2 小时前
计算机网络常考大题
网络
ZachOn1y2 小时前
计算机网络:应用层 —— 文件传送协议 FTP
网络·计算机网络·应用层·文件传送协议ftp·考研408·知识积累
刘什么洋啊Zz3 小时前
剖析IO原理和零拷贝机制
java·运维·网络
升讯威在线客服系统3 小时前
如何通过 Docker 在没有域名的情况下快速上线客服系统
java·运维·前端·python·docker·容器·.net
Karoku0665 小时前
【CI/CD】CI/CD环境搭建流程和持续集成环境配置
运维·ci/cd·docker·容器·kubernetes·prometheus
阿里云云原生5 小时前
山石网科×阿里云通义灵码,开启研发“AI智造”新时代
网络·人工智能·阿里云·ai程序员·ai程序员体验官