计算机网络(四):网络层

参考引用

  • 计算机网络微课堂-湖科大教书匠
  • 计算机网络(第7版)-谢希仁

1. 网络层概述

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

  • 要实现网络层任务,需要解决以下主要问题

    • 网络层向运输层提供怎样的服务 (“可靠传输”还是“不可靠传输”)
    • 网络层寻址问题
    • 路由选择问题
  • 因特网 (Internet) 是目前全世界用户数量最多的互联网,它使用 TCP/IP 协议栈

    • 由于 TCP/IP 协议栈的网络层使用网际协议 IP,它是整个协议栈的核心协议,因此在 TCP/IP 协议栈中网络层常称为网际层

在这里插入图片描述

2. 网络层提供的两种服务

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

3. IPv4 地址

3.1 概述
  • 在 TCP/IP 体系中,IPv4 地址就是给因特网上的每一台主机(或路由器)的每一个接口分配一个在全世界范围内是唯一的 32 比特的标识符

  • IP 地址由因特网名字和数字分配机构 ICANN(Interet Corporation for Assigned Names and Numbers) 进行分配

    • 我国用户可向亚太网络信息中心 APNIC(Asia Pacific Network lnformation Center) 申请 IP 地址,需要缴费
    • 2011年2月3日,互联网号码分配管理局 IANA (由 ICANN 行使职能)宣布,IPv4 地址已经分配完毕
    • 我国在 2014 至 2015 年也逐步停止了向新用户和应用分配 IPv4 地址,同时全面开展商用部署 IPv6
  • IPv4 地址的编址方法经历了如下三个历史阶段
    在这里插入图片描述

  • 32 比特的 IPv4 地址不方便阅读、记录以及输入等,因此 IPv4 地址采用点分十进制表示方法以方便用户使用
    在这里插入图片描述

  • 8 位无符号二进制整数转十进制数
    在这里插入图片描述

  • 十进制正整数转 8 位无符号二进制数
    在这里插入图片描述

3.2 分类编址的 IPv4 地址
  • 只有 A 类、B 类和 C 类地址可分配给网络中的主机或路由器的各接口
  • 主机号为 “全 0” 的地址是网络地址,不能分配给主机或路由器的各接口
  • 主机号为 “全 1” 的地址是广播地址,不能分配给主机或路由器的各接口

在这里插入图片描述

  • A 类地址(网络号占 1 个字节,主机号占 3 个字节)

    • 最小网络号 0,保留不指派
    • 第一个可指派的网络号为 1 ,网络地址为 1.0.0.0
    • 最大网络号 127,作为本地环回测试地址,不指派
    • 最小的本地环回测试地址为 127.0.0.1
    • 最大的本地环回测试地址为 127.255255254
    • 最后一个可指派的网络号为 126 ,网络地址为 126.0.0.0
    • 可指派的网络数量为 2 ( 8 − 1 ) − 2 = 126 2^{(8-1)}-2=126 2(81)2=126
      • 减 2 的原因是除去最小网络号 0 和最大网络号 127
    • 每个网络中可分配的 IP 地址数量为 2 24 − 2 = 16777214 2^{24}-2= 16777214 2242=16777214
      • 减 2 的原因是除去主机号为全 0 的网络地址和全 1 的广播地址
        在这里插入图片描述
  • B 类地址(网络号和主机号各占 2 个字节)

    • 最小网络号也是第一个可指派的网络号 128.0,网络地址为 128.0.0.0
    • 最大网络号也是最后一个可指派的网络号 191.255,网络地址为 191.255.0.0
    • 可指派的网络数量为 2 ( 16 − 2 ) = 16384 2^{(16-2)}= 16384 2(162)=16384
    • 每个网络中可分配的 IP 地址数量为 2 16 − 2 = 65534 2^{16}-2=65534 2162=65534
      • 减 2 的原因是除去主机号为全 0 的网络地址和全 1 的广播地址
        在这里插入图片描述
  • C 类地址(网络号占 3 个字节,主机号占 1 个字节)

    • 最小网络号也是第一个可指派的网络号 192.0.0,网络地址为 192.0.0.0
    • 最大网络号也是最后一个可指派的网络号 223.255.255,网络地址为 223.255.255.0
    • 可指派的网络数量为 2 ( 24 − 3 ) = 2097152 2^{(24-3)}=2097152 2(243)=2097152
    • 每个网络中可分配的IP地址数量为 2 8 − 2 = 254 2^{8}- 2 =254 282=254
      • 减 2 的原因是除去机号为全 0 的网络地址和全 1 的广播地址
        在这里插入图片描述
  • 示例
    在这里插入图片描述

    解析

    • 根据地址左起第一个十进制数的值,可以判断出网络类别
      - 小于 127 的为 A 类,128~191 的为 B 类,192~223 的为 C 类
    • 根据网络类别,就可找出地址中的网络号部分和主机号部分
      - A 类地址网络号为左起第一个字节,B 类地址网络号为左起前两个字节,C 类地址网络号为左起前三个字节
    • 以下三种情况的地址不能指派给主机或路由器接口
      - A 类网络号 0 和 127
      - 主机号为 “全0”,这是网络地址
      - 机号为 “全1”,这是广播地址
3.3 划分子网的 IPv4 地址

在这里插入图片描述

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

    • 子网掩码使用连续的比特 1 来对应网络号和子网号
    • 子网掩码使用连续的比特 0 来对应主机号
    • 将划分子网的 IPv4 地址与其相应的子网掩码进行逻辑与运算就可得到 IPv4 地址所在子网的网络地址
      在这里插入图片描述
  • 示例:已知某个网络的地址为 218.75.230.0,使用子网掩码 255.255.255.128 对其进行子网划分,请给出划分细节
    在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

  • 默认的子网掩码是指在未划分子网的情况下使用的子网掩码
    在这里插入图片描述
3.4 无分类编址的 IPv4 地址
  • 背景

    • 划分子网在一定程度上缓解了因特网在发展中遇到的困难,但是数量巨大的 C 类网因为其地址空间太小并没有得到充分使用,而因特网的 IP 地址仍在加速消耗,整个 IPv4 地址空间面临全部耗尽的威胁
    • 为此,因特网工程任务组 IETF 又提出了采用无分类编址的方法来解决 IP 地址紧张的问题,同时还专门成立 IPv6 工作组负责研究新版本 IP 以彻底解决 IP 地址耗尽问题
    • 1993年,IETF 发布了无分类域间路由选择 CIDR(Classless Inter-Domain Routing) 的 RFC 文档:RFC1517~1519 和 1520
      • CIDR 消除了传统的 A 类、B 类和 C 类地址,以及划分子网的概念
      • CIDR 可以更加有效地分配 IPv4 的地址空间,并且可以在新的 IPv6 使用之前允许因特网的规模继续增长
  • 用法

    • CIDR 使用 “斜线记法”,或称 CIDR 记法。即在 IPv4 地址后面加上斜线 “/”,在斜线后面写上网络前缀所占的比特数量
      在这里插入图片描述

    • CIDR 实际上是将网络前缀都相同的连续的 IP 地址组成一个 CIDR 地址块,只要知道 CIDR 地址块中的任何一个地址,就可以知道该地址块的全部细节

      • 地址块的最小地址
      • 地址块的最大地址
      • 地址块中的地址数量
      • 地址块聚合某类网络 (A 类、B 类或 C 类) 的数量
      • 地址掩码 (也可继续称为子网掩码)
  • 示例

    • 请给出 CIDR 地址块 128.14.35.7/20 的全部细节 (最小地址,最大地址,地址数量,聚合 C 类网数量,地址掩码)
      在这里插入图片描述
  • 路由聚合(构造超网)

    • 网络前缀越长,地址块越小,路由越具体
    • 若路由器查表转发分组时发现有多条路由可选,则选择网络前缀最长的那条,这称为最长前缀匹配,因为这样的路由更具体
      在这里插入图片描述
3.5 IPv4 地址的应用规划

在这里插入图片描述

  • 变长的子网掩码 VLSM
    在这里插入图片描述

在这里插入图片描述

4. 路由选择协议

在这里插入图片描述

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

    • 自适应:动态路由选择,能较好地适应网络状态的变化
    • 分布式:路由器之间交换路由信息
    • 分层次:将整个因特网划分为许多较小的自治系统 AS(Autonomous System)
      在这里插入图片描述
  • 常见的路由选择协议
    在这里插入图片描述

  • 路由器的基本结构
    在这里插入图片描述

5. 虚拟专用网 VPN 与网络地址转换 NAT

5.1 虚拟专用网 VPN(Virtual Private Network)
  • 利用公用的因特网作为本机构各专用网之间的通信载体,这样的专用网又称为虚拟专用网

    • 由于 IPv4 地址的紧缺,一个机构能够申请到的 IPv4 地址数量往往远小于本机构所拥有的主机数量。因此,虚拟专用网中的各主机所分配的地址应该是本机构可自由分配的专用地址,而不是需要申请的、在因特网上使用的公有地址
    • 专用地址只能用于一个机构的内部通信,只能用于本地地址而不能用于全球地址
      在这里插入图片描述
  • 内联网 VPN

    • 同一机构内不同部门的内部网络所构成的虚拟专用网 VPN
  • 外联网 VPN

    • 有时一个机构的 VPN 需要有某些外部机构 (通常就是合作伙伴) 参加进来,这样的 VPN 就称为外联网 VPN
  • 远程接入 VPN

    • 在外地工作的员工需要访问公司内部的专用网络时,只要在任何地点接入到因特网,运行驻留在员工 PC 中的 VPN 软件,在员工的 PC 和公司的主机之间建立 VPN 隧道,即可访问专用网络中的资源
5.2 网络地址转换 NAT(Network Address Translation)
  • 虽然因特网采用了无分类编址方式来减缓 IPv4 地址空间耗尽的速度,但由于因特网用户数目的激增,特别是大量小型办公室网络和家庭网络接入因特网的需求不断增加,IPv4 地址空间即将面临耗尽的危险仍然没有被解除
  • 1994 年提出了一种网络地址转换 NAT 的方法再次缓解了 IPv4 地址空间即将耗尽的问题
    • NAT 能使大量使用内部专用地址的专用网络用户共享少量外部全球地址来访问因特网上的主机和资源

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

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

相关文章

QQ浏览器怎么才能设置默认搜索引擎为百度

问题: 打开QQ浏览器,搜索相关信息时发现总是默认为”搜狗搜索引擎“,想将其转为”百度搜索引擎“ 解决: 1、点击浏览器右侧”菜单“图标,选择”设置“,如下图所示: 2、在”常规设置“中的”搜…

竞赛选题 深度学习 YOLO 实现车牌识别算法

文章目录 0 前言1 课题介绍2 算法简介2.1网络架构 3 数据准备4 模型训练5 实现效果5.1 图片识别效果5.2视频识别效果 6 部分关键代码7 最后 0 前言 🔥 优质竞赛项目系列,今天要分享的是 🚩 基于yolov5的深度学习车牌识别系统实现 该项目较…

二叉搜索树的基础操作

如果对于二叉搜索树不是太清楚,为什么要使用二叉搜索树?作者推荐:二叉搜索树的初步认识_加瓦不加班的博客-CSDN博客 定义节点 static class BSTNode {int key; // 若希望任意类型作为 key, 则后续可以将其设计为 Comparable 接口Object val…

3.(vue3.x+vite)class动态绑定的方式

前端技术社区总目录(订阅之前请先查看该博客) 效果浏览 代码如下 <template><div><div :class="{acti

通用监控视频web播放方案

业务场景 对接监控视频&#xff0c;实现海康大华等监控摄像头的实时画面在web端播放 方案一&#xff0c;使用 RTSP2webnode.jsffmpeg 说明&#xff1a;需要node环境&#xff0c;原理就是RTSP2web实时调用ffmpeg解码。使用单独html页面部署到服务器后&#xff0c;在项目中需要播…

IP 子网划分(VLSM)

目录 一、 为什么要划分子网 二、如何划分子网 1、划分两个子网 2、划分多个子网 一、 为什么要划分子网 假设有一个B类IP地址172.16.0.0&#xff0c;B类IP的默认子网掩码是 255.255.0.0&#xff0c;那么该网段内IP的变化范围为 172.16.0.0 ~ 172.16.255.255&#xff0c;即…

【Java 进阶篇】HTML块级元素详解

HTML&#xff08;Hypertext Markup Language&#xff09;是用于创建网页的标记语言。在HTML中&#xff0c;元素被分为块级元素和内联元素两种主要类型。块级元素通常用于构建网页的结构&#xff0c;而内联元素则嵌套在块级元素内&#xff0c;用于添加文本和其他内容。本文将重点…

C++设计模式-单件(Singleton)

目录 C设计模式-单件&#xff08;Singleton&#xff09; 一、意图 二、适用性 三、结构 四、参与者 五、代码 C设计模式-单件&#xff08;Singleton&#xff09; 一、意图 保证一个类仅有一个实例&#xff0c;并提供一个访问它的全局访问点。 二、适用性 当类只能有一…

【17】c++设计模式——>原型模式

原型模式的定义 c中的原型模式&#xff08;Prototype Pattern&#xff09;是一种创建型设计模式&#xff0c;其目的是通过复制&#xff08;克隆&#xff09;已有对象来创建新的对象&#xff0c;而不需要显示的使用构造函数创建对象&#xff0c;原型模式适用于创建复杂对象时&a…

浅谈内存函数以及模拟实现

1.memcpy void * memcpy ( void * destination, const void * source, size_t num ); 函数memcpy从source的位置开始向后复制num个字节的数据到destination的内存位置。 这个函数在遇到 \0 的时候并不会停下来。 如果source和destination有任何的重叠&#xff0c;复制的结果都…

保姆级微服务部署教程

大家好&#xff0c;我是鱼皮。 项目上线是每位学编程同学必须掌握的基本技能。之前我已经给大家分享过很多种上线单体项目的方法了&#xff0c;今天再出一期微服务项目的部署教程&#xff0c;用一种最简单的方法&#xff0c;带大家轻松部署微服务项目。 开始之前&#xff0c;…

Linux虚拟机搭建RabbitMQ集群

普通集群模式&#xff0c;意思就是在多台机器上启动多个 RabbitMQ 实例&#xff0c;每台机器启动一个。创建的 queue&#xff0c;只会放在一个 RabbitMQ 实例上&#xff0c;但是每个实例都同步 queue 的元数据&#xff08;元数据可以认为是 queue 的一些配置信息&#xff0c;通…

自定义无边框窗口

效果&#xff1a; 可拖动拉伸 ui&#xff1a;设计如下 样式表&#xff1a;在ui CustomDialog 里设置的 #widget_title{background: #E6F1EB;border-top-left-radius: 20px;border-top-right-radius: 20px;}#widget_client{background-color: rgb(255, 255, 255);border-bottom…

react create-react-app v5配置 px2rem (不暴露 eject方式)

环境信息&#xff1a; create-react-app v5 “react”: “^18.2.0” “postcss-plugin-px2rem”: “^0.8.1” 配置步骤&#xff1a; 不暴露 eject 配置自己的webpack&#xff1a; 1.下载react-app-rewired 和 customize-cra-5 npm install react-app-rewired customize-cra…

十三、Django之添加用户(原始方法实现)

修改urls.py path("user/add/", views.user_add),添加user_add.html {% extends layout.html %} {% block content %}<div class"container"><div class"panel panel-default"><div class"panel-heading"><h3 c…

OSI七层网络模型

1. OSI模型 网络协议是网络中两台计算机之间传输数据的标准语言。各种计算机系统使用 OSI&#xff08;Open Systems Interconnection&#xff09;模型规定的标准相互通信。OSI 模型有七个抽象层&#xff0c;每个层都有不同的职责和协议。 下图显示了 OSI 模型中每一层的功能。…

【python海洋专题十四】读取多个盐度nc数据画盐度季节变化图

本期内容 读取多个盐度文件&#xff1b;拼接数据在画盐度的季节分布图Part01. 使用数据 IAP 网格盐度数据集 数据详细介绍&#xff1a; 见文件附件&#xff1a; pages/file/dl?fid378649712527544320 全球温盐格点数据.pdf IAP_Global_ocean_gridded_product.pdf 全球温…

python实现UI自动化配置谷歌浏览器驱动

web端UI自动化执行在哪个浏览器&#xff0c;需要对应哪个浏览器的驱动。以谷歌浏览器为例&#xff0c;进行配置。一、查看谷歌浏览器版本 如下截图&#xff1a;我的谷歌浏览器版本是&#xff1a; 117.0.5938.150 二、下载对应版本谷歌浏览器驱动 首先可以从其他版本驱动地址中…

【AI】深度学习——人工智能、深度学习与神经网络

文章目录 0.1 如何开发一个AI系统0.2 表示学习(特征处理)0.2.1 传统特征学习特征选择过滤式包裹式 L 1 L_1 L1​ 正则化 特征抽取监督的特征学习无监督的特征学习 特征工程作用 0.2.2 语义鸿沟0.2.3 表示方式关联 0.2.4 表示学习对比 0.3 深度学习0.3.1 表示学习与深度学习0.3.…

云原生Kubernetes:K8S集群kubectl命令汇总

目录 一、理论 1.概念 2. kubectl 帮助方法 3.kubectl 子命令使用分类 4.使用kubectl 命令的必要环境 5.kubectl 详细命令 一、理论 1.概念 kubectl是一个命令行工具&#xff0c;通过跟 K8S 集群的 API Server 通信&#xff0c;来执行集群的管理工作。 kubectl命令是操…