28_计算机网络(Computer Networks)基础

本篇介绍计算机网络的基础知识。

文章目录

  • 1. 计算机网络历史
  • 2. 以太网" (Ethernet)
    • 2.1 以太网" (Ethernet)的简单形式及概念
    • 2.2 指数退避解决冲突问题
    • 2.3 利用交换机减少同一载体中设备
    • 2.4 互联网(The Internet)
    • 2.5 路由(routing)
    • 2.6 数据包(packs)解决阻塞问题
    • 2.7 分组交换(Packet Switching)
    • 2.8 物联网(internet of things)

1. 计算机网络历史

第一个计算机网络出现在1950~1960年代,通常在公司或研究室内部使用,为了方便信息交换,比把纸卡或磁带送到另一栋楼里更快速可靠,这叫"球鞋网络"
在这里插入图片描述
第二个好处是能共享物理资源,举个例子,与其每台电脑配一台打印机,大家可以共享一台联网的打印机,早期网络也会共享存储空间,因为每台电脑都配存储器太贵了
在这里插入图片描述
计算机近距离构成的小型网络叫局域网, 简称LAN(Local Area Networks),局域网能小到是同一个房间里的两台机器,或大到校园里的上千台机器尽管开发和部署了很多不同 LAN 技术,其中最著名和成功的是"以太网" (Ethernet) , 开发于1970年代在施乐的"帕洛阿尔托研究中心"诞生, 今日仍被广泛使用。

2. 以太网" (Ethernet)

2.1 以太网" (Ethernet)的简单形式及概念

以太网的最简单形式是:一条以太网电线连接数台计算机,当一台计算机要传数据给另一台计算机时,它以电信号形式,将数据传入电缆,当然 因为电缆是共享的,连在同一个网络里的其他计算机也看得到数据,但不知道数据是给它们的,还是给其他计算机的。
在这里插入图片描述
为了解决这个问题 以太网需要每台计算机有唯一的媒体访问控制地址,简称 MAC(Mdedia Acess Control)地址。
这个唯一的地址放在头部,作为数据的前缀发送到网络中,所以,计算机只需要监听以太网电缆只有看到自己的 MAC 地址,才处理数据。这运作得很好 现在制造的每台计算机都自带唯一的MAC地址,用于以太网和无线网络。
在这里插入图片描述

  • 多台电脑共享一个传输媒介,这种方法叫 "载波侦听多路访问(Carrier Sense Multiple Access)" 简称"CSMA"
  • 载体(carrier)指运输数据的共享媒介,以太网的"载体"是铜线, WiFi 的"载体"是传播无线电波的空气。
  • 很多计算机同时侦听载体,所以叫"侦听""多路访问"
  • 而载体传输数据的速度 叫"带宽"

2.2 指数退避解决冲突问题

不幸的是 使用共享载体有个很大的弊端,当网络流量较小时 计算机可以等待载体清空,然后传送数据,但随着网络流量上升 两台计算机想同时写入数据的概率也会上升,这叫冲突。 数据全都乱套了,就像两个人同时在电话里讲话。
在这里插入图片描述
在这里插入图片描述

幸运的是 计算机能够通过监听电线中的信号检测这些冲突,最明显的解决办法是停止传输,等待网络空闲, 然后再试一遍。
问题是其他计算机也打算这样做,其他等着的计算机可能在任何停顿间隙闯入,导致越来越多冲突,很快,每个人都一个接一个地讲话而且有一堆事要说,就像在家庭聚餐中和男朋友分手一样。

以太网有个超简单有效的解决方法,当计算机检测到冲突 就会在重传之前等待一小段时间,因为要举例,假设是 1 秒好了,当然 如果所有计算机用同样的等待时间 是不行的,它们会在一秒后再次冲突,所以加入一个随机时间 一台计算机可能等1.3秒,另一台计算机等待1.5秒,要是运气好 等1.3秒的计算机会醒来,发现载体是空闲的 然后开始传输,当1.5秒的计算机醒来后 会发现载体被占用会等待其他计算机完成。这有用,但不能完全解决问题 所以要用另一个小技巧,即"指数退避"

指数退避
正如前面所说,如果一台计算机在传输数据期间检测到冲突,会等一秒+随机时间,然而,如果再次发生冲突,表明有网络拥塞,这次不等1秒,而是等2秒,如果再次发生冲突 等4秒 然后8秒 16秒等等,直到成功传输,因为计算机的退避冲突次数降低了,数据再次开始流动起来 网络变得顺畅,这种指数级增长等待时间的方法叫:指数退避

2.3 利用交换机减少同一载体中设备

以太网和WiFi都用这种方法,很多其他传输协议也用,但即便有了"指数退避"这种技巧,想用一根网线链接整个大学的计算机还是不可能的,为了减少冲突+提升效率,我们需要减少同一载体中设备的数量。载体和其中的设备总称 "冲突域"(Collision Domain)

让我们回到之前以太网的例子 一根电缆连6台计算机,也叫一个冲突域,为了减少冲突 我们可以用交换机把它拆成两个冲突域,交换机位于两个更小的网络之间, 必要时才在两个网络间传数据。
在这里插入图片描述
交换机会记录一个列表,写着哪个 MAC 地址在哪边网络,如果A想传数据给C,交换机不会把数据转发给另一边的网络;
在这里插入图片描述

如果E想同一时间传数据给F,网络仍然是空的,两个传输可以同时发生;
在这里插入图片描述

但如果F想发数据给A 数据会通过交换机,两个网络都会被短暂占用;
在这里插入图片描述

2.4 互联网(The Internet)

大的计算机网络也是这样构建的,包括最大的网络 - 互联网(The Internet),也是多个连在一起的稍小一点网络,使不同网络间可以传递信息。
在这里插入图片描述
下篇将会细讲。

2.5 路由(routing)

这些大型网络有趣之处是,从一个地点到另一个地点通常有多条路线,这就带出了另一个话题路由(routing)
连接两台相隔遥远的计算机或网路,最简单的办法是分配一条专用的通信线路。早期电话系统就是这样运作的,假设"印第安纳波利斯"和"米苏拉"之间,有五条电话线,如果在1910年代,John 想打电话给 Hank,John要告诉操作员他想打到什么地方,然后工作人员手动将 John 的电话连到通往米苏拉的未使用线路,通话期间 这条线就被占用了, 如果五条线都被占用了John 要等待某条线空出来,这叫 "电路交换"
在这里插入图片描述

因为是把电路连接到正确目的地,能用倒是能用, 但不灵活而且价格昂贵,因为总有闲置的线路,好处是,如果有一条专属于自己的线路, 你可以最大限度地随意使用,无需共享,因此军队, 银行和其他一些机构,依然会购买专用线路来连接数据中心。
在这里插入图片描述

传输数据的另一个方法是 "报文交换(Message Switching)",“报文交换” 就像邮政系统一样,不像之前A和B有一条专有线路,消息会经过好几个站点,如果 John 写一封信给 Hank,信件可能从"印第安纳波利斯"到"芝加哥",然后"明尼阿波利斯" 然后"比林斯" 最后到"米苏拉"。
在这里插入图片描述

每个站点都知道下一站发哪里,因为站点有表格,记录到各个目的地,信件该怎么传,报文交换的好处是 可以用不同路由使通信更可靠更能容错。回到邮件的例子,如果"明尼阿波利斯"有暴风雪中断了通信, “芝加哥"可以传给"奥马哈”。
在这里插入图片描述
在这个例子里,城市就像路由器一样,消息沿着路由跳转的次数叫"跳数"(hop count),记录跳数很有用,因为可以分辨出路由问题,举例,假设芝加哥认为去米苏拉的最快路线是奥马哈,但奥马哈认为去米苏拉的最快路线是芝加哥,这就糟糕了,因为2个城市看到目的地是米苏拉,结果报文会在2个城市之间不停传来传去,不仅浪费带宽 而且这个路由错误需要修复!

这种错误会被检测到,因为跳数记录在消息中而且传输时会更新跳数,如果看到某条消息的跳数很高就知道路由肯定哪里错了,这叫"跳数限制(Hop Limit)"

2.6 数据包(packs)解决阻塞问题

报文交换的缺点之一是有时候报文比较大,会堵塞网络 因为要把整个报文从一站传到下一站后才能继续传递其他报文,传输一个大文件时 整条路都阻塞了,即便你只有一个1KB的电子邮件要传输也只能等大文件传完,或是选另一条效率稍低的路线,这就糟了,解决方法是:将大报文分成很多小块,叫"数据包(packs)"

就像报文交换 每个数据包都有目标地址因此路由器知道发到哪里,报文具体格式由"互联网协议(Internet Protocol)"定义,简称 IP,这个标准创建于 1970 年代,每台联网的计算机都需要一个IP地址,你可能见过,以点分隔的4组数字。例如 172.217.7.238 是 Google 其中一个服务器的IP地址,数百万台计算机在网络上不断交换数据瓶颈的出现和消失是毫秒级的,路由器会平衡与其他路由器之间的负载以确保传输可以快速可靠,这叫"阻塞控制(congestion control)"

有时,同一个报文的多个数据包会经过不同线路,到达顺序可能会不一样,这对一些软件是个问题。
在这里插入图片描述
在这里插入图片描述

2.7 分组交换(Packet Switching)

幸运的是,在 IP 之上还有其他协议,比如 TCP/IP, 可以解决乱序问题,我们下周会讲,将数据拆分成多个小数据包,然后通过灵活的路由传递,非常高效且可容错,如今互联网就是这么运行的,这叫"分组交换(Packet Switching)"
有个好处是 它是去中心化的,没有中心权威机构 没有单点失败问题。事实上 因为冷战期间有核攻击的威胁,所以创造了分组交换。
如今,全球的路由器协同工作,找出最高效的线路,用各种标准协议运输数据,比如 "因特网控制消息协议"( Internet Control Message Protocol ICMP)"边界网关协议"(Border Gateway Protocol BGP)
世界上第一个分组交换网络以及现代互联网的祖先是 ARPANET,名字来源于赞助这个项目的机构,美国高级研究计划局( Advanced Research Projects Agency)
在这里插入图片描述
上图是 1974 年整个 ARPANET 的样子,每个小圆表示一个地点比如大学或实验室,那里运行着一个路由器,并且有一台或多台计算机,能看到 “PDP-1” 和"IBM 360系统",甚至还有一个伦敦的 ATLAS是通过卫星连到网络里的。

2.8 物联网(internet of things)

显然 互联网在这几十年间发展迅速,如今不再只有几十台计算机联网据估计 有接近100亿台联网设备,而且互联网会继续快速发展,特别是如今各种智能设备层出不穷比如联网冰箱,恒温器以及其他智能家电,它们组成了"物联网"(internet of things)
在这里插入图片描述

第一部分到此结束 我们对计算机网络进行了概览,网络是一堆管子组成的吗?,额 算是吧。
下篇我们会讨论一些高级传输协议,然后讲万维网(World Wide Web)

3. 视频地址:计算机网络

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

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

相关文章

基于峰谷分时电价引导下的电动汽车充电负荷优化(matlab代码)

目录 1 主要内容 峰谷电价优化 电动汽车充电负荷变化 2 部分代码 3 程序结果 1 主要内容 该程序基本复现《基于峰谷分时电价引导下的电动汽车充电负荷优化》,代码主要做的是基于NSGA-II的电动汽车充电负荷优化,首先,在研究电动汽车用户充…

重生之我要学C++第五天

这篇文章主要内容是构造函数的初始化列表以及运算符重载在顺序表中的简单应用,运算符重载实现自定义类型的流插入流提取。希望对大家有所帮助,点赞收藏评论,支持一下吧! 目录 构造函数进阶理解 1.内置类型成员在参数列表中的定义 …

【云原生】Docker容器命令监控+Prometheus监控平台

目录 1.常用命令监控 docker ps docker top docker stats 2.weave scope 1.下载 2.安装 3.访问查询即可 3.Prometheus监控平台 1.部署数据收集器cadvisor 2.部署Prometheus 3.部署可视化平台Gragana 4.进入后台控制台 1.常用命令监控 docker ps [rootlocalhost ~…

重新审视MHA与Transformer

本文将基于PyTorch源码重新审视MultiheadAttention与Transformer。事实上,早在一年前博主就已经分别介绍了两者:各种注意力机制的PyTorch实现、从零开始手写一个Transformer,但当时的实现大部分是基于d2l教程的,这次将基于PyTorch…

opencv顺时针,逆时针旋转视频并保存视频

原视频 代码 import cv2# 打开视频文件 video cv2.VideoCapture(inference/video/lianzhang.mp4)# 获取原视频的宽度和高度 width int(video.get(cv2.CAP_PROP_FRAME_WIDTH)) height int(video.get(cv2.CAP_PROP_FRAME_HEIGHT))# 创建视频编写器并设置输出视频参数 fourcc …

【C++】类和对象(下)

1、初始化列表 初始化列表:以一个冒号开始,接着是一个以逗号分隔的数据成员列表,每个"成员变量"后面跟一个放在括号中的初始值或表达式。 class Date { public:Date(int year, int month, int day): _year(year), _month(month), _…

OSPF协议RIP协议+OSPF实验(eNSP)

本篇博客主要讲解单区域的ospf,多区域的仅作了解。 目录 一、OSPF路由协议概述 1.内部网关协议和外部网关协议 二、OSPF的应用环境 1.从以下几方面考虑OSPF的使用 2.OSPF的特点 三、OSPF重要基本概念 3.1,辨析邻居和邻接关系以及七种邻居状态 3…

【MySQL】索引与B+树

【MySQL】索引与B树 索引概念前导硬件软件方面 索引的理解单个page多个page引入B树B树的特征为什么B树做索引优于其他数据结构?聚簇索引与非聚簇索引辅助索引 索引的创建主键索引的创建和查看唯一键索引的创建和查看普通索引的创建和查看复合索引全文索引索引的其他…

js全端支持的深拷贝structuredClone

Jul 7, 2023 经过一年半的试用,structuredClone转正了,全端可以正式使用。 https://developer.mozilla.org/en-US/docs/Web/API/structuredClone

OpenHarmony开源鸿蒙学习入门 - 基于3.2Release 应用开发环境安装

OpenHarmony开源鸿蒙学习入门 - 基于3.2Release 应用开发环境安装 基于目前官方master主支,最新文档版本3.2Release,更新应用开发环境安装文档。 一、安装IDE: 1.IDE安装的系统要求 2.IDE下载官网链接(IDE下载链接) …

Modbus tcp转ETHERCAT在Modbus软件中的配置方法

Modbus tcp和ETHERCAT是两种不同的协议,这给工业生产带来了很大的麻烦,因为这两种设备之间无法通讯。但是,捷米JM-ECT-TCP网关的出现,却为这个难题提供了解决方案。 JM-ECT-TCP网关能够连接到Modbus tcp总线和ETHERCAT总线中&…

网络面试合集

传输层的数据结构是什么? 就是在问他的协议格式:UDP&TCP 2.1.1三次握手 通信前,要先建立连接,确保双方都是在线,具有数据收发的能力。 2.1.2四次挥手 通信结束后,会有一个断开连接的过程&#xff0…

Qsys介绍

文章目录 前言一、为什么需要Qsys1、简化了系统的设计流程2、Qsys涉及的技术 二、Qsys真身1、一种系统集成工具2、何为Nios II1、内核架构2、Nios II选型 三、Qsys设计涉及到的软件&工具四、总结五、参考资料 前言 Qsys是Altera下的一个系统集成工具,可用于搭建…

APP自动化测试-Python+Appium+Pytest+Allure框架实战封装(详细)

目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 pytest只是单独的…

JVM入门篇-JVM的概念与学习路线

JVM入门篇-JVM的概念与学习路线 什么是 JVM 定义 Java Virtual Machine - java 程序的运行环境(java 二进制字节码的运行环境) 好处 一次编写,到处运行自动内存管理,垃圾回收功能数组下标越界检查多态 比较 jvm jre jdk 常…

单片机第一季:零基础12——I2C和EEPROM

目录 1,EEPROM 2,I2C 2.1,I2C物理层 2.2,I2C协议层 3,AT24C02介绍 4,代码 1,EEPROM 为什么需要EEPROM? 单片机内部的ROM只能在程序下载时进行擦除和改写,但是…

护眼灯全光谱和减蓝光哪个好?推荐五款好用护眼台灯

如今,面临视力下降的问题越来越重视,护眼灯越来越成为人们日常生活中不可或缺的一部分,特别是在工作和学习中使用电脑、手机等电子设备时间较长的人群中。对于护眼灯来说,全光谱和减蓝光都是其主要功能之一,那么哪一种…

aws中opensearch 日志通(Centralized Logging with OpenSearch)2.0(一)

aws日志通2.0 实现全面的日志管理和分析功能 一体化日志摄取 :把aws服务器日志和应用日志传输到opensearch域中无代码日志处理 :在网页控制台中就可以实现数据处理开箱即用 :提供可视化模版(nginx、HTTP server ) 架构…

使用 CSS 自定义属性

我们常见的网站日夜间模式的变化,其实用到了 css 自定义属性。 CSS 自定义属性(也称为 CSS 变量)是一种在 CSS 中预定义和使用的变量。它们提供了一种简洁和灵活的方式来通过多个 CSS 规则共享相同的值,使得样式更易于维护和修改。…

【LeetCode每日一题】——566.重塑矩阵

文章目录 一【题目类别】二【题目难度】三【题目编号】四【题目描述】五【题目示例】六【题目提示】七【解题思路】八【时间频度】九【代码实现】十【提交结果】 一【题目类别】 矩阵 二【题目难度】 简单 三【题目编号】 566.重塑矩阵 四【题目描述】 在 MATLAB 中&…