10_32_Docker【进阶知识】—Docker0网络详解(用来给容器编排,集群部署做铺垫)

本文主要是介绍10_32_Docker【进阶知识】—Docker0网络详解(用来给容器编排,集群部署做铺垫),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、Docker网络

理解Docker0

清空所有环境

测试

Linux里面获取当前的ip地址:ip addr

在这里插入图片描述

  • 三个网络
# 问题:docker 是如何处理容器网络访问的?

在这里插入图片描述

  • tomcat里面的web项目需要访问mysql,这之间是如何访问的呢?

在这里插入图片描述
尝试解决:

# docker run -d -p --name tomcat01 tomcat# 查看容器的内部网络地址:ip addr* 发现容器启动的时候会得到一个eth0@if262的ip地址,这是docker分配的!# docker exec -it tomcat01 ip addr

在这里插入图片描述

# 思考:Linux 能不能 ping 通容器内部?

在这里插入图片描述

# Linux可以ping 通 docker容器内部

解释:
192.168.0.1 :路由器

  • 手机连上wifi之后,分配的就是192.168.0.2
  • 他们就在同一个网段:所以之间是可以ping通的

原理

1、我们每启动一个docker容器,docker就会给docker容器分配一个ip,我们只要安装了docker,就会有一个网卡叫做:docker0

桥接模式:使用的技术是veth-pair技术
再次测试ip addr
在这里插入图片描述
2、再启动一个容器测试,发现又多了一对网卡
在这里插入图片描述

  • 在Linux里面他是263,绑定了264

在这里插入图片描述

  • 在容器里面他是264,绑定了263
# 我们发现这个容器带来网卡,都是一对对的
# veth-pair 就是一对的虚拟设备接口,他们都是成对出现的,一端连着接口,一端彼此相连
# 正因为这个特性,【veth-pair 充当一个桥梁,连接各种网络虚拟设备的】
# OpenStac,Docker容器之间的连接,OVS的连接,都是使用 veth-pair技术

3、 我们来测试一下 tomcat01 和 tomcat02 是否能ping 通
在这里插入图片描述

# docker exec -it tomcat02 ping 172.18.0.2# 结论:【容器和容器之间是可以互相ping通的】

绘制一个网络模型图【给 tomcat01 和 tomcat02 ping 通做解释】
在这里插入图片描述

# 结论:tomcat01和tomcat02是公用的一个路由器,docker0所有容器不指定网络的情况下(可以通过--net来指定),都是 docker0 路由的,docker会给我们的容器分配一个默认的可用ip
网络基础问题:255.255.0.1/16这里能存多少ip地址(主机)计算机正常的:11111111.11111111.11111111.11111111
改为10进制:255.255.255.255
16就是取前16位网络号【分开网络标识和主机标识】:255.255.0.0* 斜杠后面的数字就表示【子网掩码】* 16位前面就是网络号,后面就是主机号* 16地方写的24就是只剩下最后的255了,就相当于一个域,局域网
所以真正的ip地址是:255 * 255 -2 = 65535(因为主机为全0和全1的保留不用,所以需要减2)* 0.0.0.0:回环地址* 255.255.255.255:子网掩码

可参考:IP地址(分类)、子网掩码、网络号、主机号、子网号

小结

Docker使用的是Linux的桥接,宿主机中是一个Docker容器的网桥 docker0
在这里插入图片描述
Docker 中的所有网络接口都是虚拟的,虚拟的转发效率高!(内网传递)
只要容器删除,对应网桥一对就没了

思考一个场景,我们编写了一个微服务,databast url = ip:,项目不重启,数据库ip换掉了,我们希望可以处理这样的问题,可以名字来访问容器?————docker里有一个命令:–link【老版本】

  • 这里mybatis数据库连接url的时候,每次连接都会重新分配ip。
  • SpringCloud feigh = 服务名
  • mysql ip => 能否做到通过mysql来ping通,这样ip怎么变就不会影响

在这里插入图片描述

  • 输入docker network inspect 5a008c015cac【当前网卡的ID】
    在这里插入图片描述

这篇关于10_32_Docker【进阶知识】—Docker0网络详解(用来给容器编排,集群部署做铺垫)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/541485

相关文章

C++ move 的作用详解及陷阱最佳实践

《C++move的作用详解及陷阱最佳实践》文章详细介绍了C++中的`std::move`函数的作用,包括为什么需要它、它的本质、典型使用场景、以及一些常见陷阱和最佳实践,感兴趣的朋友跟随小编一起看... 目录C++ move 的作用详解一、一句话总结二、为什么需要 move?C++98/03 的痛点⚡C++

MySQL中between and的基本用法、范围查询示例详解

《MySQL中betweenand的基本用法、范围查询示例详解》BETWEENAND操作符在MySQL中用于选择在两个值之间的数据,包括边界值,它支持数值和日期类型,示例展示了如何使用BETWEEN... 目录一、between and语法二、使用示例2.1、betwphpeen and数值查询2.2、be

python中的flask_sqlalchemy的使用及示例详解

《python中的flask_sqlalchemy的使用及示例详解》文章主要介绍了在使用SQLAlchemy创建模型实例时,通过元类动态创建实例的方式,并说明了如何在实例化时执行__init__方法,... 目录@orm.reconstructorSQLAlchemy的回滚关联其他模型数据库基本操作将数据添

Java中ArrayList与顺序表示例详解

《Java中ArrayList与顺序表示例详解》顺序表是在计算机内存中以数组的形式保存的线性表,是指用一组地址连续的存储单元依次存储数据元素的线性结构,:本文主要介绍Java中ArrayList与... 目录前言一、Java集合框架核心接口与分类ArrayList二、顺序表数据结构中的顺序表三、常用代码手动

JAVA线程的周期及调度机制详解

《JAVA线程的周期及调度机制详解》Java线程的生命周期包括NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING和TERMINATED,线程调度依赖操作系统,采用抢占... 目录Java线程的生命周期线程状态转换示例代码JAVA线程调度机制优先级设置示例注意事项JAVA线程

JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)

《JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)》:本文主要介绍如何在IntelliJIDEA2020.1中创建和部署一个JavaWeb项目,包括创建项目、配置Tomcat服务... 目录简介:一、创建项目二、tomcat部署1、将tomcat解压在一个自己找得到路径2、在idea中添加

详解C++ 存储二进制数据容器的几种方法

《详解C++存储二进制数据容器的几种方法》本文主要介绍了详解C++存储二进制数据容器,包括std::vector、std::array、std::string、std::bitset和std::ve... 目录1.std::vector<uint8_t>(最常用)特点:适用场景:示例:2.std::arra

C++构造函数中explicit详解

《C++构造函数中explicit详解》explicit关键字用于修饰单参数构造函数或可以看作单参数的构造函数,阻止编译器进行隐式类型转换或拷贝初始化,本文就来介绍explicit的使用,感兴趣的可以... 目录1. 什么是explicit2. 隐式转换的问题3.explicit的使用示例基本用法多参数构造

Android使用java实现网络连通性检查详解

《Android使用java实现网络连通性检查详解》这篇文章主要为大家详细介绍了Android使用java实现网络连通性检查的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录NetCheck.Java(可直接拷贝)使用示例(Activity/Fragment 内)权限要求

MyBatis中的两种参数传递类型详解(示例代码)

《MyBatis中的两种参数传递类型详解(示例代码)》文章介绍了MyBatis中传递多个参数的两种方式,使用Map和使用@Param注解或封装POJO,Map方式适用于动态、不固定的参数,但可读性和安... 目录✅ android方式一:使用Map<String, Object>✅ 方式二:使用@Param