计算机网络之网络层

一、概述

主要任务是实现网络互连,进而实现数据包在各网络之间的传输

1.1网络引入的目的

从7层结构上看,网络层下是数据链路层

从4层结构上看,网络层下面是网络接口层

至少我们看到的网络层下面是以太网

以太网解决了什么问题?

答:以太网解决了具体网络上主机间数据传输的问题;主机之间可以以物理地址,以广播的传输方式进行数据的交换传输

网络解决问题的基本方案

1)强制要求采用一种新的统一的网络连接方式(强制的统一成一种物理地址)

2)保留现有网络,重新定义一个虚拟的新的网络连接方式;求同存异

TCP/IP协议网络解决问题的方案

1.虚拟的IP互连协议

该协议为了实现网络互连,要求对有互连需求的网络,必须在将原有的网络数据转换成IP数据报格式,然后在虚拟IP网络上进行数据的传输

2.潜在的IP协议中要给出协议的转换功能(翻译功能)

3.同样要求在虚拟的IP协议中要给出数据传输状态的报告信息

上述三个内容最后都要转换为3个具体的协议,因此IP协议不是一个协议,是一族协议;只不过这一族中IP地位最强

1.2网络扩展后可采用的数据传输方式

 面向连接的虚电路服务

  • 可靠的通信由网络来保证
  • 必须建立网络层的连接----虚电路VC(Virtual Circuit)
  • 通信双方沿着已建立的虚电路发送分组
  • 目的主机的地址仅在连接建立阶段使用,之后每个分组的首部只需携带一条虚电路的编号(构成虚电路的每一段链路都有一个虚电路编号)。
  • 这种通信方式如果再使用可靠传输的网络协议,就可使所发送的分组最终正确到达接收方(无差错按序到达、不丢失、不重复)。
  • 通信结束后,需要释放之前所建立的虚电路

无连接的数据报服务

  • 可靠通信应当由用户主机来保证
  • 不需要建立网络层连接
  • 每个分组可走不同路径
  • 每个分组的首部必须携带目的主机的完整地址
  • 这种通信方式所传送的分组可能误码、丢失、重复和失序
  • 由于网络本身不提供端到端的可靠传输服务,这就使网络中的路由器可以做得比较简单,而且价格低廉
  • 因特网采用了这种设计思想,也就是将复杂的网络处理功能置于因特网的边缘(用户主机和其内部的运输层),而将相对简单的尽最大努力的分组交付功能置于因特网核心。

1.3虚拟IP互连协议引入后数据的转发流程

1.直接交付

属于同一个虚拟逻辑网络和同一个现实物理网络上主机或主机接口之间数据的转发,只要解决目的地址IP地址对应的物理地址,就简单了,就利用物理地址直接在物理网络上进行传输了

属于同一个广播域(局域网)内的交付,可以利用ARP协议协议直接找到目的主机IP地址对应的物理地址,从而完成数据的交付

ARP怎么工作的,工作流程,解决的问题:IP->物理地址,数据链路层封装,

A,B是一家的,属于直接交付范围,怎么界定,通俗的老说就是姓氏相同 

2.间接交付

属于不同网络内的数据传输,因此无法直接找到目的地址主机的
MAC地址,只能将数据交付到网络出口路由器,因此,此时ARP协议并不是去寻找目的地址的MAC地址,而是寻找本网络出口路由器物理地址

A和C通信,隔着千山万水,借助第三方(邮筒),怎样把数据交付出去----中间路由器的接口和A属于同一个局域网,以广播的形式发给路由器,到网络层把真正的目的地提取出来了,在进行封装,交到C(MAC)

A-》C通信,一跳一跳的,路由器的作用就是传送数据(跳到网络层---数据真实的传输方向)换一个包装,向目的地传递,网络中传递数据,是一跳一跳的进行传输数据(传输数据的物理地址改变)大体方向不变,朝着目的地址走

ARP地址解析协议

在虚拟网络上的主机也必须有唯一的标识

虚拟统一网络的引入,为每一个在网络中的主机又提出了一个标识问题,在IP网络中就称为IP地址;也就是说在虚拟互连网络中每个接入主机必须有一个唯一的虚拟IP地址;这个是逻辑地址,与物理网络位置无关

虚拟网络是在现实物理网络上进行抽象总结抽象形成的,而现实网络上每台接入网络的主机都有一个固有的物理地址

两个地址之间的关系是什么,两个地址如何进行相互的转换

1)协议作用

应用进程看到的网络是统一的IP网络,因此它所描述的进程之间数据的传输是在统一一致的IP网络上进行传输;而这个统一的IP网络是在不同的现实物理网络上进行抽象的,所以虚拟网络间数据的传输必须要经过现实的物理地址才能完成真正的传输,就必须有个地址能完成两种地址之间的转换

封装成以太数据帧

 2)协议工作原理

A->B发送消息时,首先去查找自己的内存ARP表格,若找到对应的MAC地址则直接进行封装,转到介质上进行传输,否则,就封装一个数据链路层上的广播帧,去询问对应的IP的MAC地址

根据发送的性质:该协议只能解决同一个广播域(局域网)内,逻辑IP地址到物理MAC地址的转换问题

3)协议存在缺陷

协议本身工作是开放性的工作方式,缺乏验证机制 

1.4  IPv4地址

IPv4地址就是因特网上的每一台主机(或路由器)的每一个接口分配一个在全世界范围内是唯一的32比特的标识符

分类编址

 

  • A类地址网络号第1位固定为0,网络号后面部分不能全0,也不能全1,所以网络号范围是1~126
  • B类地址网络号前2位固定为10,网络号后面部分可以全取0或1,所以网络号范围是128.0~191.255
  • C类地址网络号前3位固定为110,网络后后面部分可以全取0或1,所以网络号范围是192.0.0~223.255.255
  • D类地址为多播地址,IP地址为224.0.0.0~239.255.255.255

 

 划分子网的IPv4地址

为什么需要划分子网?

比如一个单位有300台主机,此时需要申请一个B类网络地址,很容易得知,分配出去300个IP地址后,申请得到的B类网络还剩下很多IP地址。
当单位扩大规模,需要再添加两个子网的时,又要为这两个子网分别申请B类地址,这会花费一些不必要的支出,实际上子网1申请到的B类地址还有很多没用到,我们希望能够将这些剩余地址应用到其他子网中(节约地址)

如何实现子网划分?

32比特的子网掩码可以表明分类IP地址的主机号部分被借用了几个比特作为子网号

  • 子网掩码使用连续的比特1来对应网络号和子网号(子网号来自原先的一部分主机号)
  • 子网掩码使用连续的比特0来对应主机号
  • 将划分子网的IPv4地址与其相应的子网掩码进行逻辑与运算【即掩码是1的部分】就可得到IPv4地址所在子网的网络地址

 无分类编址的IPv4地址

为什么需要?

划分子网在一定程度上缓解了因特网发展中遇到的困难,但是数量巨大的C类网因为其地址空间太小并没有得到充分使用,而因特网的IP地址仍在加速消耗,整个IPv4地址空间面临全部耗尽的威胁

 

路由聚合

如路由器A上连接同一网络的多台主机,路由器B与A相连。若A将所有主机的具体IP地址都报给B,则路由器B中会增加多项路由条目。可实际上B向A中任意一个主机转发数据的时都是走同一个端口,因此我们可以将这些网络的共同前缀提取出来成为新的网络号,同时将剩余主机号置0放入路由器B中

如:A连接了172.1.4.0/25和172.1.7.0/24,则提取公共前缀聚合后变为172.1.4.0/22

IPV4地址的应用规划

对于一个给定的IP地址,我们又进行了内部的划分的重新分配,这样分配就称为内部子网的划分

权利对主机地址部分进行重新的组合,来表示内部使用方式的分配

定长掩码划分方式

对于一个给定IP地址,我们有权对主机地址部分进行重新的组合,来表示内部使用方式的分配

变长掩码划分方式

1.5IP数据报发送转发过程 

1.IP网络虚拟互连网络的互连设备-----路由器

路由器的作用:

1)工作在网络层上,意味着它能识别网络层上的数据传输格式

2)路由器按网络层上数据传输地址,进行有目的的数据转发

3)路由器有针对性的数据转发依赖于路由器中的路由表

2.IP网络中路由器转发分组的算法

特定 默认 一般的网络路由

同一个网络之间的主机可以直接通信,不同网络之间的主机通信需要路由器中转 

源主机如何判断目的主机是否和自己在同一个网络中?

将自身的IP地址与子网掩码相与得到自身的网络号1,再将目的IP地址与自身子网掩码相与得到网络号2。若两个网络号相等,则说明处在同一个网络 

主机如何知道应该把IP数据报交给哪个路由器进行转发呢?

通过设置默认网关。所谓默认网关,即当路由表中查不到数据时会将数据发往的路由器端口IP地址 

 静态路由配置

静态路由配置是指用户或网络管理员使用路由器的相关命令给路由器人工配置路由表

  • 这种人工配置方式简单、开销小。但不能及时适应网络状态的变化。一般只在小规模网络中采用
  • 可能由于:①配置错误 ②聚合了不存在的网络 ③网络故障 而出现路由环路错误
  • 默认路由为:0.0.0.0/0 。其作用是当路由表不知道往哪里转发时,就会往默认路由指定的下一跳位置转发,根据网络号最长匹配原理,默认路由网络号长度为0,因此一定是最后一个被匹配的条目
  • 特定主机路由:具体主机IP/32。网络号前缀长度32保证了这是第一个被匹配的静态条目

 如何防止错误路由导致IP数据报永久兜圈?

  1. IP数据报首部设置生存时间TTL字段
    • IP数据报进入路由器后,TTL字段的值减1若TTL的值不等于0,则被路由器转发,否则被丢弃
  2. 对于聚合后或由于网络故障而不存在的路由条目设置黑洞路由
    • 所谓黑洞路由,即路由器应该丢弃的路由

1.6 路由选择协议

因特网所采用的的路由选择协议主要特点

  • 自适应:动态路由选择,能较好地适应网络状态的变化
  • 分布式:路由器之间交换路由信息
  • 分层次:将整个因特网划分为许多较小的自治系统AS

路由信息协议RIP

基于距离向量的路由选择协议(应用层是UDP)   RIP协议(路由信息协议) 

动态的形成路由器上路由表的内容,作为数据包转发的依据

距离:是指去某一个网络所经过路由器的个数(跳数);一个路由器直接相连的网络距离为1;距离为16表示网络不可达1

工作原理:

1)通过与相邻路由器进行信息交互,完成AS内部路由的形成

2)相邻路由器之间相互交换彼此的全部路由表信息

3)固定时间进行一次交换20s-30s

RIP算法的工作流程:

基于最短距离来形成路由

  • RIP包含以下三个要点
    • 仅和相邻路由器交换信息
    • 交换的是各自路由表的信息
    • 周期性交换信息

RIP存在的问题

存在"坏消息传播很慢"的问题,又称为路由环路(两个路由器相互学习错误路由,造成循环)或距离无穷计数问题,这是距离向量算法的一个固有问题,可以采取多种措施减少出现该问题的概率或减小该问题带来的危害

  • 限制最大路径距离为15(16表示不可达)
  • 当路由表发生变化时就立即发送更新报文(即"触发更新"),而不是周期性发送
  • 让路由器记录收到某特定路由信息的接口,而不让同一路由信息再通过此接口反方向传送(即**“水平分割”“毒性反转”**)

开放最短路径优先OSPF

简单来说就是得到一个带权有向图,以当前路由器为起点,通过迪杰斯特拉算法得到到达某个点的最短路径

基于链路状态的路由选择协议(网络层 IP)  OSPF协议(开放最短路径优先算法形成的路由

OSPF协议:基于链路状态的路由协议、

链路状态:又只链路成本,就是数据在这条链路上传输所花费的时延,安全,费用等等信息所构成的

链路状态就是综合参数来形成路由协议

工作原理:(是网络层的协议)

(1)每个路由器将自己的状态数据摘要以洪范的方式向所有路由器进行转发

(2)所有路由器最终会获取到每个路由器的邻接关系和链路权重(即全网的网络拓扑结构)

(3)每个路由器以自己为根节点,采用迪杰斯特拉算法计算一个最小生成树,到达每个路由器

(4)路由稳定后,只有链路状态发生改变时,才将改变的路由状态发给所有路由器以便重新计算路由

边界网关协议BGP

尽力寻找一条能够到达目的网络且比较好的路由(不兜圈子),而并非找最佳路由

内部网关协议IGP(如路由信息协议RIP或最短路径优先OSPF)

  • 设法使分组在一个自治系统内尽可能有效地从源网络传输到目的网络
  • 无需考虑自治系统外部其他方面的策略

外部网关协议EGP(如边界网关协议BGP)

  • 在不同自治系统内,度量路由的"代价"(距离,宽带,费用等)可能不同。因此,对于自治系统之间的路由选择,使用"代价"作为度量来寻找最佳路由是不行的
    • 比如A系统路由选择度量是距离,B系统是带宽……那么A到系统E的路由怎样走最好呢?由于没有统一度量,所以不能直接得到最佳路由
  • 自治系统之间的路由选择必须考虑相关策略(政治、经济、安全等)
    • 如中国的数据报尽量要绕开美国的自治系统

 1.7IPv4数据报首部格式

  • 版本

    4比特,表示IP协议版本。通信双方使用的IP协议版本必须一致。目前广泛使用的IP协议版本为号为4(IPv4)

  • 首部长度

    4比特,表示IP数据报首部长度。该字段取值以4字节为单位

    最小十进制取值为5,表示IP数据报首部只有20字节4字节单位,所以取值5对应20字节】固定部分

    最大十进制取值为15,表示IP数据报首部包含20字节固定部分和最大40字节可变部分

  • 总长度

    16比特,表示IP数据报的总长度【首部+数据载荷】,最大取值为十进制65535以字节为单位

  • 可选字段

    长度从140个字节不等。用来支持排错、测量及安全等措施

    可选字段增加了IP数据报的功能,但这同时也使得IP数据报的首部长度成为可变的。这就增加了每一个路由器处理IP数据报的开销。实际上可选字段很少被使用

  • 填充字段

    确保首部长度为4字节长度的整数倍,使用全0进行填充

1.8网际控制报文ICMP 

为了更有效地转发IP数据报和提高交付成功的机会,在网际层使用了网际控制报文协议ICMP

  • 主机或路由器使用ICMP来发送差错报告报文和询问报文
  • ICMP报文被封装在IP数据报中发送

回答报文类型

终点不可达

当路由器或主机不能交付数据报时,就向源点发送终点不可达报文。具体可再根据ICMP的代码字段细分为目的网络不可达、目的主机不可达、目的协议不可达、目的端口不可达、目的网络位置、目的主机未知等13种错误 

源点抑制

当路由器或主机由于拥塞而丢弃数据报时,就向源点发送源点抑制报文,使源点知道应当把数据报发送速率放慢 

时间超过

当路由器收到一个目的IP地址不是自己的IP数据报,会将其生存时间TTL字段值减1。若结果不为0,则将该IP数据报转发出去;若结果为0,除丢弃该IP数据报外,还要向源点发送时间超过报文

当终点在预先规定的时间内不能收到一个数据报的全部数据报片时,就把已收到的数据报片都丢弃,也会向源点发送时间超过报文

 参数问题

当路由器或目的主机收到IP数据报后,根据其首部中的检验和字段发现首部在传输过程中出现了误码,就丢弃该数据报,并向源点发送参数问题报文

改变路由(重定向)

路由器把改变路由报文发送给主机,让主机知道下次应将数据报发送给另外的路由器(可通过更好的路由)

如主机1的默认路由是R1,信息经过R1时,R1发现最佳路由不是自己,而是R2,所以通过ICMP告知主机1

1.9虚拟专用网VPN

利用公用的因特网作为本机构各专用网之间的通信载体,这样的专用网又称为虚拟专用网。
虚拟专用网中各主机所分配的地址应该是本机构可自由分配的专用地址 

 1.10网络地址转换NAT

NAT能使大量使用内部专用地址的专用网络用户共享少量外部全球地址来访问因特网上的主机和资源【为了节省IPv4地址】

由于绝大多数的网络应用都是使用运输层协议TCPUDP来传送数据,因此可以利用运输层的端口号和IP地址一起进行转换。

这样,用一个全球IP地址就可以使多个拥有本地地址的主机同时和因特网上的主机进行通信。这种将端口号和IP地址一起进行转换的技术叫作网络地址与端口号转换NAPT

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/212214.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

事务对隔离性的原理理解

脏读:两个事务并行,A事务做的一切,B事务就可以立刻知道。不可重复读:一个事务受到另一个事务的影响导致连续的select不统一,RU、RC都会导致。幻读:一般的数据库在可重复读情况的时候,无法屏蔽其…

leetcode刷题日志-70爬楼梯

假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢? 示例 1: 输入:n 2 输出:2 解释:有两种方法可以爬到楼顶。 1 阶 1 阶2 阶 示例 2: …

【C++】泛型编程 ⑭ ( 类模板示例 - 数组类模板 | 容器思想 | 自定义类可拷贝 - 深拷贝与浅拷贝 | 自定义类可打印 - 左移运算符重载 )

文章目录 一、容器思想1、自定义类可拷贝 - 深拷贝与浅拷贝2、自定义类可拷贝 - 代码示例3、自定义类可打印 - 左移运算符重载 二、代码示例1、Array.h 头文件2、Array.cpp 代码文件3、Test.cpp 主函数代码文件4、执行结果 一、容器思想 1、自定义类可拷贝 - 深拷贝与浅拷贝 上…

【分布式】分布式事务及其解决方案

目录 一、分布式事务二、分布式事务的解决方案1. 全局事务(1)DTP模型(2) 两阶段提交协议(2PC)原理二阶段提交的缺点 (3)三阶段提交协议(3PC)原理 2. 基于可靠…

计算机视觉项目-人脸识别与检测

😊😊😊欢迎来到本博客😊😊😊 本次博客内容将继续讲解关于OpenCV的相关知识 🎉作者简介:⭐️⭐️⭐️目前计算机研究生在读。主要研究方向是人工智能和群智能算法方向。目前熟悉深度学…

机器学习---最大似然估计和贝叶斯参数估计

1. 估计 贝叶斯框架下的数据收集,在以下条件下我们可以设计一个可选择的分类器 : P(wi) (先验);P(x | wi) (类条件密度) 但是。我们很少能够完整的得到这些信息! 从一个传统的样本中设计一个分类器: ①先验估计不成问题 ②对类条件密度…

mysql:修改密码的几种方式

背景 当我们 brew install mysql 新安装 mysql 的时候,是没有密码的,我们可以直接通过 mysql -u root 连接上。但是密码还是要设置的,一是为了安全,二是有些数据库软件如 Sequel 连接都是必须要密码的,接下来我们来看…

基于JavaWeb+SSM+Vue校园水电费管理小程序系统的设计和实现

基于JavaWebSSMVue校园水电费管理小程序系统的设计和实现 源码获取入口Lun文目录前言主要技术系统设计功能截图订阅经典源码专栏Java项目精品实战案例《500套》 源码获取 源码获取入口 Lun文目录 摘 要 III Abstract 1 1 系统概述 2 1.1 概述 2 1.2课题意义 3 1.3 主要内容 3…

朋友圈被折叠怎么解决?

最近有客户咨询发的朋友圈老被折叠怎么办,正常发都被折叠。一些朋友在微信做私域的,在朋友圈日常营销是必不可少的,如何避免这种问题和怎么解决呢? 为什么会被折叠? 1.据了解,朋友圈内容折叠功能是主要针对…

Spring第一课,了解IDEA里面的文件,回顾Cookie和Session,获取Session,Cookie,Header的方式

目录 IDEA第一课(熟悉里面内容) 建立连接 -RequestMapping 路由映射 请求 1.传递单个参数​编辑 2.多个参数​编辑 3.传递数组 4.传递一个集合,但是这里我们传递的时候发生了500的错误 简单介绍JSON 回顾Cookie和S…

github批量仓库克隆,git clone某个用户的所有仓库

利用github的api工具, 首先拿到用户名为kevin的所有仓库的url: curl "https://api.github.com/users/kevin/repos?per_page100&&page1" | grep -w clone_url >clone.txt过滤一下: grep -o https://[^"]* clone…

java.lang.ArrayIndexOutOfBoundsException: (数组越界异常)

java.lang.ArrayIndexOutOfBoundsException: (数组越界异常) 如何解决数组越界异常?1.1条件判断1.2循环结构1.3 try-catch(异常捕获)避免数组越界异常的方法:数组越界异常的调试和排查技巧: 当我…