计算机网络第一章(概述)【湖科大教书匠】

1. 各种网络

  • 网络(Network)由若干**结点(Node)和连接这些结点的链路(Link)**组成
  • 多个网络还可以通过路由器互连起来,这样就构成了一个覆盖范围更大的网络,即互联网(互连网)。因此,互联网是"网络的网络(Network of Networks)"
  • **因特网(Internet)**是世界上最大的互连网络【小写iinternet是通用名词,互连的网络都叫internet

2. ISP

因特网服务提供者(Internet Service Provider)

普通用户如何接入因特网?

通过ISP接入因特网。ISP可以从因特网管理机构申请到成块的IP地址,同时拥有通信线路以及路由器等连网设备,任何机构和个人只要向ISP交纳规定的费用,就可以从ISP得到所需要的IP地址。互联网上的主机都必须有IP地址才能通信

uBXlYmagVoEebrt

基于ISP的三层结构的因特网

层数越小覆盖越多

2

3. 因特网的组成

  • 边缘部分:由所有连接在因特网上的主机组成,这部分是用户直接使用的,用来进行通信(传送数据、音频或视频)和资源共享
  • 核心部分:由大量网络和连接这些网络的路由器组成。这部分是为边缘部分提供服务的(提供连通性和交换)

3

4. 三种交换方式

①电路交换(Circuit Switching)

1. 电路交换怎么出现的?

电话问世后,人们发现所有电话之间都两两相连是不现实的。因此可以用一个中间设备将讲话接入,根据需要进行转发

4

2. 什么是电路交换?

电话交换机接通电话线的方式称为电路交换
从通信资源分配角度来看,交换(Switch)就是按照某种方式动态地分配传输线路的资源

3. 电路交换三个步骤

  1. 建立连接(分配通信资源):例如在使用电路交换打电话前,必须先拨号请求建立连接,当被叫用户听到电话交换机送来的拨号音并拿起电话后,从主叫端到被叫端就建立了一条连接,也就是一条专用的物理通路。这条连接保证了双方通话时所需的通信资源,而这些资源在双方通信中不会被其他用户占用
  2. 通话(一直占用通信资源):分配的资源始终被占用
  3. 释放连接(归还通信资源)

5

优点

  1. 通信时延小:通信线路为通信双方专用的,数据直达
  2. 有序传输:通信双方只有一条专用通信线路,数据只在这一线路上传输,不存在失序问题
  3. 没有冲突:不同的通信双方拥有不同的信道,不会出现争用物理通道的问题
  4. 适用范围广:适用于传输模拟信号,也适用于传输数字信号
  5. 实时性强:时延小所以实时性强
  6. 控制简单

缺点

  1. 建立连接时间长
  2. 线路独占,适用效率低
  3. 灵活性差:只要连接所建立的物理通路中的任何一点出现了故障,就必须重新拨号建立新的连接
  4. 难以规格化:不同类型、不同规格、不同速率的终端很难互相进行通信,也难以差错控制

②★分组交换(Packet Switching)

  • 发送方:①构建分组 ②发送分组
  • 路由器:①缓存分组 ②转发分组
  • 接收方:①接收分组 ②还原报文

6

优点

  1. 无需建立连接
  2. 线路利用率高
  3. 简化存储管理:因为分组大小固定,管理起来就容易一些
  4. 加速传输:因为分组是逐个传输,这样前一个交换机的转发操作与后一个交换机的存储操作可同时进行
  5. 减少出错率和重复数据量:分组比报文小,因此出错概率也会比较小,即使出错也只需要重传出错的这一小部分即可

缺点

  1. 引起了转发时延
  2. 需要传输额外信息量(分组头部信息)
  3. 分组交换采用数据报服务时,可能会出现失序、丢失、重复分组。分组到达目的结点时,需要重新还原成原始报文,比较麻烦。若分组交换采用虚电路服务,虽然没有分组失序问题,但有呼叫建立,数据传输和虚电路释放三个过程

③报文交换(Message Switching)

报文交换与分组交换类似,不过对报文没有限制大小,现如今多使用分组交换。

优点

  1. 无需建立连接
  2. 动态分配线路
  3. 提高线路可靠性:如果某条线路出现故障,会重新选择另一条线路
  4. 提高线路利用率:通信双方在不同的时间分段占用物理线路
  5. 提供多目标服务:一个报文可以同时发送给多个目的地址

缺点

  1. 引起转发时延:报文在节点交换机上要经历存储转发的过程
  2. 需要较大的存储转发空间:因为报文大小没有限制
  3. 需要传输额外信息量:有头部等信息

三种交换对比

纵坐标为时间,分组交换相对报文交换分的更小,可以减少时延,防止过长时间占用线路以及方便排错

7

5. 计算机网络

定义

一些互相连接的、自治的计算机的集合

  • 互连:指计算机之间可以通过有线或无线的方式进行数据通信
  • 自治:指独立的计算机,它有自己的硬件和软件,可以单独运行使用
  • 集合:指至少需要两台计算机

分类

按交换技术:①电路交换网络 ②报文交换网络 ③分组交换网络

按使用者:①公用网 ②专用网

按传输介质:①有线网络 ②无线网络

按覆盖范围:①广域网WAN ②城域网MAN ③局域网LAN ④个域网PAN

按拓扑结构:①总线型网络 ②星型网络 ③环型网络 ④网状型网络

性能指标

性能指标可以从不同的方面来度量计算机网络的性能

1. 速率

连接在计算机网络上的主机在数字信道上传送比特的速率,也称为比特率或数据率

常用数据率单位

8

比特

计算机中的数据量单位,也是信息论中信息量的单位。一个比特就是二进制数字中的一个10.

常用数据量

9

2. 带宽

带宽在模拟信号系统中的意义

信号所包含的各种不同频率成分所占据的频率范围

单位:Hz(kHz,MHz,GHz)

带宽在计算机网络中的意义

用来表示网络的通信线路所能传送数据的能力,因此网络带宽表示在单位时间内从网络中的某一点到另一点所能通过的"最高数据率"

单位:b/s(kb/s,Mb/s,Gb/s,Tb/s)

一条通信线路的"频带宽度"越宽,其所传输数据的"最高数据率"也越高

3. 吞吐量

吞吐量表示在单位时间内通过某个网络(或信道、接口)的数据量。
吞吐量被经常用于对现实世界中的网络的一种测量,以便知道实际上到底有多少数据量能够通过网络。
吞吐量
受网络的带宽或额定速率的限制

4. ★时延

在处理过程中所需要的时间

10

11

5. 时延带宽积

12

6. 往返时间

在许多情况下,因特网上的信息不仅仅单方向传输,而是双向交互
我们有时很需要知道双向交互一次所需要的时间
因此,往返时间RTT(Round-Trip Time)也是一个重要的性能指标

7. ★利用率

信道利用率:用来表示某信道有百分之几的时间是被利用的(有数据通过)
网络利用率:全网络的信道利用率的加权平均

  • 根据排队论,当某信道的利用率增大时,该信道引起的时延也会迅速增加。因此信道利用率不是越高越好

  • 如果令** D 0 D_0 D0表示网络空闲时的时延**,D表示网络当前的时延,那么在适当的假定条件下,可以用下面的简单公式来表示D D 0 D_0 D0利用率U之间的关系

    D = D 0 1 − U D=\dfrac{D_0}{1-U} D=1UD0

    13

    当网络利用率U50%时,时延急剧增大。

    当网络利用率接近100%时,时延趋于无穷大

    但是也不能使信道利用率过低,这回使宝贵的通信资源被浪费

因此一些拥有较大主干网的ISP通常会控制它们的信道利用率不超过50%。如果超过了,就要准备扩容,增大线路带宽

8. 丢包率

丢包率即分组丢失率,是指在一定的时间范围内,传输过程中丢失的分组数量与总分组数量的比率
具体可分为:接口丢包率、结点丢包率、链路丢包率、路径丢包率、网络丢包率等

丢包率是网络运维人员非常关心的一个网络性能指标,但对于普通用户来说往往并不关心这个指标,因为他们意识不到丢包

分组丢失的两种情况

  • 分组在传输过程中出现误码,被结点丢弃
  • 分组到达一台队列已满的分组交换机时被丢弃,在通信量较大时就可能造成网络拥塞

丢包率反映了网络的拥塞情况

  • 无拥塞时路径丢包率为0
  • 轻度拥塞时路径丢包率为1%~4%
  • 严重拥塞时路径丢包率为5%~15%

★体系结构

1

1. 分层的必要性

在平常编程时,我们总是喜欢利用不同的类实现不同的功能,最后进行整合实现真正的功能。这样的好处是让结构更加清晰,维护也更加简单。计算机网络分层同理,在计算机网络上实现不同进程的通信需要解决众多问题,分层便于维护与管理。

0

2. 分层举例

当我们利用浏览器发送网页请求到服务器并发生响应的过程中,数据会怎么变化呢?

1

浏览器发送

  • 应用层按照HTTP协议的规定构建一个HTTP请求报文(请求要干什么)。应用层将HTTP请求的报文交给运输层处理
  • 运输层给HTTP请求报文添加一个TCP首部(区分应用进程),使之成为TCP报文段。运输层将TCP报文段交给网络层处理
  • 网络层给TCP报文段添加一个IP首部(使之可以在互联网上传输),使之成为IP数据报。网络层将IP数据报交付给数据链路层处理
  • 数据链路层给IP数据报添加一个首部(让其能在一段链路上传输,能被相应主机接收)和一个尾部(让目的主机检查所接收到的帧是否有误码),使之成为。数据链路层将帧交给物理层
  • 物理层将帧看作比特流,如果网络是以太网,它还会在帧上加前导码(让目的主机做好接收帧的准备)。接着将比特流变成相应信号发送到传输媒体

路由器转发

  • 物理层收到信号将其变为比特流,去掉前导码后,将其交付给数据链路层**(交付的实际是帧)**
  • 数据链路层将帧去掉首部和尾部后,将其交付给网络层**(交付的实际是IP数据报)**
  • 网络层解析IP数据报首部,从中提取目的网络地址,然后查找自身路由表,确定转发端口。接着数据链路层封装,物理层再封装,将比特流变成信号发送出去。

服务器接收

  • 物理层收到信号将其变为比特流,去掉前导码后,将其交付给数据链路层**(交付的实际是帧)**
  • 数据链路层收到帧后,去除首部和尾部,将其交付给网络层**(交付的实际是IP数据报)**
  • 网络层收到IP数据报后,去除IP首部,将其交付给运输层**(交付的实际是TCP报文)**
  • 运输层收到TCP报文后,从中得知是与哪个端口上的进程通信,去除TCP头部后,交付给应用层**(交付的实际是HTTP请求报文)**
  • 应用层收到HTTP请求报文后,将其解析给对应进程,并执行相关操作,返回HTTP响应报文

专用术语

①实体

任何可发送或接收信息的硬件或者软件进程

对等实体:收发双方相同层次中的实体

2

②协议

控制两个对等实体进行**逻辑通信(这种通信实际上不存在,只是便于我们考虑问题)**的规则的集合

3

三要素

  • 语法:定义所交换信息的格式(即报文格式)
  • 语义:定义收发双方所要完成的操作(即收,发任务需要各自定义)
  • 同步:定义收发双方的时序关系(如先建立侦听才可以通信是有先后顺序的)

③服务

  • 在协议控制下,两个对等实体间的逻辑通信使得本层能够向上一层提供服务(也就是说通过协议完成本层的内容后就可以向上提供服务)
  • 要实现本层协议,还需要使用下面一层所提供的服务
  • 协议是**“水平的”,服务是"垂直的"**
  • 实体看得见相邻下层所提供的的服务,但是并不知道实现该服务的具体协议。也就是说,下面的协议对上面的实体是**“透明”**的(就像手机为我们提供服务,但是我们并不知道具体是如何实现的)

服务访问点:在同一系统中相邻两层的实体交换信息的逻辑接口(就像Web里的request域,后端前端都能取到),用于区分不同的服务类型

  • 数据链路层的服务访问点为帧的"类型"字段
  • 网络层的服务访问点位IP数据报首部中的"协议字段"
  • 运输层的服务访问点为"端口号"

服务原语:上层使用下层所提供的服务必须通过与下层交换一些命令,这些命令称为服务原语

4

协议数据单元PDU(横向):对等层次之间传送的数据包称为该层的协议数据单元

  • 物理层是比特流;数据链路层是帧;网络层是IP数据报或分组……

服务数据单元SDU(竖向):同一系统内,层与层之间交换的数据报称为服务数据单元

  • 物理层往上送是比特流;数据链路层往下送是帧……

多个SDU可用合成为一个PDU;一个SDU页可以划分为几个PDU

借鉴:https://blog.csdn.net/weixin_45488428/article/details/115102326

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Mybatis的二级缓存

缓存的概述和分类 概述 缓存就是一块内存空间.保存临时数据 为什么使用缓存 将数据源(数据库或者文件)中的数据读取出来存放到缓存中,再次获取的时候 ,直接从缓存中获取,可以减少和数据库交互的次数,这样可以提升程序的性能! 缓存的适用情况 …

38-二叉树练习-LeetCode145二叉树的后序遍历

题目 给你一棵二叉树的根节点 root ,返回其节点值的 后序遍历 。 示例 1: 输入:root [1,null,2,3] 输出:[3,2,1] 示例 2: 输入:root [] 输出:[] 示例 3: 输入:ro…

让chatGPT当我的老师如何? 通过和chatGPT交互式学习,了解在ES中,一条JSON数据是如何写到磁盘上的

最近一直有一个问题,如鲠在喉。争取早一天解决,早一天踏踏实实的睡觉。 问题是:在ES中,一条JSON数据是如何写入到磁盘上的? 如何解决这个问题?我想到了chatGPT,还有lucene的学习资料。这篇文章&…

【机器学习】决策树(理论)

决策树(理论) 目录一、何为决策树1、决策树的组成2、决策树的构建二、熵1、熵的作用2、熵的定义3、熵的计算4、条件熵的引入5、条件熵的计算三、划分选择1、信息增益( ID3 算法选用的评估标准)2、信息增益率( C4.5 算法…

DetectGPT:使用概率曲率的零样本机器生成文本检测

DetectGPT的目的是确定一段文本是否由特定的llm生成,例如GPT-3。为了对段落 x 进行分类,DetectGPT 首先使用通用的预训练模型(例如 T5)对段落 ~xi 生成较小的扰动。然后DetectGPT将原始样本x的对数概率与每个扰动样本~xi进行比较。…

Springboot 多线程分批切割处理 大数据量List集合 ,实用示例

前言 哲学提问镇贴: 不了解异步怎么使用的看官, 可阅: SpringBoot 最简单的使用异步线程案例 Async_小目标青年的博客-CSDN博客 Springboot Async异步扩展使用 结合 CompletableFuture_小目标青年的博客-CSDN博客 想了解更多关于批量list处…

25- 卷积神经网络(CNN)原理 (TensorFlow系列) (深度学习)

知识要点 卷积神经网络的几个主要结构: 卷积层(Convolutions): Valid :不填充,也就是最终大小为卷积后的大小. Same:输出大小与原图大小一致,那么N ​变成了​N2P. padding-零填充. 池化层(Subsampli…

《程序员面试金典(第6版)》面试题 08.08. 有重复字符串的排列组合(回溯算法,全排列问题)C++

题目描述 有重复字符串的排列组合。编写一种方法,计算某字符串的所有排列组合。 示例1: 输入:S “qqe” 输出:[“eqq”,“qeq”,“qqe”] 示例2: 输入:S “ab” 输出:[“ab”, “ba”] 提示: 字符都是英文字母。…

Mybatis持久层框架 | Lombok搭建

💗wei_shuo的个人主页 💫wei_shuo的学习社区 🌐Hello World ! Lombok Lombok项目是一个java库,它可以自动插入到编辑器和构建工具中,增强java的性能。不需要再写getter、setter或equals方法,只要…

自然语言大模型介绍

1 简介 最近一直被大语言模型刷屏。本文是周末技术分享会的提纲,总结了一些自然语言模型相关的重要技术,以及各个主流公司的研究方向和进展,和大家共同学习。 2 Transformer 目前的大模型基本都是Transformer及其变种。本部分将介绍Transf…

【WEB前端进阶之路】 HTML 全路线学习知识点梳理(上)

前言 HTML 是一切Web开发的基础,本文专门为小白整理,针对前端零基础的朋友们,手把手教你学习HTML,让你轻松迈入WEB开发的行列。 首先,感谢 橙子_ 在HTML学习以及本文编写过程中对我的帮助。 文章目录前言一.HTML简介1.…

【NLP经典论文阅读】Efficient Estimation of Word Representations in Vector Space(附代码)

❤️觉得内容不错的话,欢迎点赞收藏加关注😊😊😊,后续会继续输入更多优质内容❤️👉有问题欢迎大家加关注私戳或者评论(包括但不限于NLP算法相关,linux学习相关,读研读博…

二值mask转polygon/RLE (coco segment格式)

coco数据集annotation的segmentation并不是二值mask,而是polygon格式, 看一个annotation. {"segmentation": [[510.66,423.01,511.72,420.03,510.45......]], #两两组成(x,y)坐标,polygon格式"area": 702.1057499999998…

腾讯自研万亿级NLP大模型,自动生成和衍生广告文案

编者按:随着大数据与AI技术的不断发展,人们越来越看见AI大模型在数据理解、运算以及诸多泛化能力上的潜力,时下,大模型已然成为学术界与工业界探索的重点方向。然而,随着模型规模与容量的不断扩大,其所需训…

mac 把word公式默认字体Cambria Math换成LaTex字体以及带章节自动编号

word默认是Cambria Math,想用latex那种公式的字体,这里使用的是XITS Math字体 搜了很多地方,都是用ab Text这个方法先转成文本,再换字体,然后设置斜体 可是公式多起来的话这种办法很麻烦,而且一个公式里常…

PyTorch深度学习实战 | 典型卷积神经网络

在深度学习的发展过程中,出现了很多经典的卷积神经网络,它们对深度学习的学术研究和工业生产都起到了巨大的促进作用,如VGG、ResNet、Inception和DenseNet等,很多投入实用的卷积神经都是在它们的基础上进行改进的。初学者应从试验…

C语言实现堆

注:这里我们所实现的是大根堆(即父节点不小于子节点的堆) 目录 一,堆的介绍 二,堆结构的创建 三,接口实现 1,初始化与销毁 2,数据的插入与删除 3,其他接口 一&…

力扣:最后一个单词的长度(详解)

前言:内容包括:题目,代码实现,大致思路,代码解读 题目: 给你一个字符串 s,由若干单词组成,单词前后用一些空格字符隔开。返回字符串中 最后一个 单词的长度。 单词 是指仅由字母组…

基于springboot实现留守儿童爱心网站平台【源码+论文】

基于springboot实现留守儿童爱心网站演示开发语言:Java 框架:springboot JDK版本:JDK1.8 服务器:tomcat7 数据库:mysql 5.7 数据库工具:Navicat11 开发软件:eclipse/myeclipse/idea Maven包&…

qt 关于QtXlsx的编译 使用

版本:qt 5.14.0 qt creator4.11.0 平时用mingw编译器 QtXlsx源码下载地址:QtXlsxWriter:https://github.com/dbzhang800/QtXlsxWriter 在Qt的XLSX模块提供了一组类来读写Excel文件。它不需要 Microsoft Excel,可以…