聊聊网络通信机制中的物理传输和数据链路

2023-12-20 10:30

本文主要是介绍聊聊网络通信机制中的物理传输和数据链路,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

今天来聊一聊关于计算机中的网络通讯息息相关的内容。

在计算机中,数据中的传输离不开分层协议。为什么分层?分几层?每一层都在做什么?今天我们来一起看看;

村里有个姑娘叫老薛,长得好看又漂亮,一米八几的大高个而且还幽默;

老薛花费巨资,买了两个电脑,但是有个问题,希望这两个电脑能够通讯,但是怎么办呢?

老薛找了根线,直接怼上。好了,恭喜,通了; 通过物理接线的方式,直接进行数据交互;

在这种情况下,就出现了一个问题,如果我有多个设备,那么为了保证多个设备上都能够传输数据,就导致我的连线特别复杂:

这里对于硬件设备4和5都还没有画,如果也画上直接废废了。所以老薛开动小脑袋瓜,想到了一个比较好的方式;

能不能使用转发的思想来解决呢?

假设我有一个设备,能够帮助我通过将比如将1号的的信息发送到**5号,**这样似乎也不赖;

这里使用的就是HUB集线器

这里集线器采用的方式就是广播;

通过广播的方式将数据发送出去,但是他存在一些问题:

  • 数据转发的时候,不是Hub集线器去判定数据从哪个源出来,到哪里去,而是把所有的信息都转发的所有设备上;导致数据传输速度差;网络链路的利用率差;
  • 数据广播的时候,带宽利用率很差;甚至可能出现错误数据,主要是如果同一时刻存在多个设备发送数据,比如1号设备发送数据给4号,3号设备发送数据到2号,此时可能导致4号设备接收到的数据是1号和3号数据杂糅在一起的;可以使用CSMA/CD 来避免这种情况;
  • 比较适合网络设备很少的情况;另外一般情况下使用的都是双绞线

在这样的情况下,我想到了一个绝妙的注意:

能不能做一张表,这张表中能够记录一个设备编号,然后再加一个物理端口,然后用一个设备去记录:

这样数据设备1在给设备2发送信息的时候,就会通过交换机,然后再交换机内部通过查表的方式来确定另外一台设备在哪里;

因为在交换机中,能够保证的是全双工通信;并且还能够进行桥接

为什么能够做到这一点呢?

使用到连接线就是我们现在看到的网线,一共8根线,最少有4根可以接受消息,另外4根就可以发送消息;

这样就保证了同一时刻不需要担心数据在链路中出现糅杂的情况;

另外一个原因就是因为使用了交换机,而交换机内部是能够查表的方式来指定广播的目标地址,而不是将信息都广播到所有设备上;

那么另外一个问题就是交换机中的表是如何创建出来的呢?

  • 当买了一台交换机之后,连接多台设备,此时交换机中是没有映射表的;
  • 当你通过设备A给设备B发送信息的时候,此时交换机中会查表,但是表是空的,所以会记录A设备的信息
  • 记录A中的[mac地址,物理端口],然后广播到其他两台机器上;
  • 然后当B给其他设备发送信息的时候,也会记录B的[mac地址,物理端口];
  • 依次往复,所有的设备中的mac地址和物理端口被记录下之后成为一张表;

mac地址是你的设备出厂之后就带的,当然也是可以修改的,它是数据通信的基石;数据通过mac地址进行传输;

Tips:mac地址是一个6个分段,每个分段是8个字节,一共48个字节长度;另外这里的表不是路由表;

如何完成桥接呢? 其实就是我们可以通过网线连接多个交换机;

  • 这里对于交换机sw1sw2而言;也是在刚开始的时候就会进行全局广播;
  • 然后如果1号设备发信息到6号设备,此时在sw1中记录的就是 [1号设备mac地址,1号端口]****;
  • 然后等到找到第二台交换机,到下一次6号设备1号设备的时候,在sw2中记录[1号设备mac地址,5号端口];
  • 依此类推,两个交换几种记录的表如下:

针对于这个,现在有两个问题:为什么ne?

问题1:如果mac地址负责数据传输,IP还有意义吗?

问题2:按照交换机的存储映射表,会存在那些问题呢?

这篇关于聊聊网络通信机制中的物理传输和数据链路的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Java ArrayList扩容机制 (源码解读)

结论:初始长度为10,若所需长度小于1.5倍原长度,则按照1.5倍扩容。若不够用则按照所需长度扩容。 一. 明确类内部重要变量含义         1:数组默认长度         2:这是一个共享的空数组实例,用于明确创建长度为0时的ArrayList ,比如通过 new ArrayList<>(0),ArrayList 内部的数组 elementData 会指向这个 EMPTY_EL

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。

【Tools】大模型中的自注意力机制

摇来摇去摇碎点点的金黄 伸手牵来一片梦的霞光 南方的小巷推开多情的门窗 年轻和我们歌唱 摇来摇去摇着温柔的阳光 轻轻托起一件梦的衣裳 古老的都市每天都改变模样                      🎵 方芳《摇太阳》 自注意力机制(Self-Attention)是一种在Transformer等大模型中经常使用的注意力机制。该机制通过对输入序列中的每个元素计算与其他元素之间的相似性,

如何通俗理解注意力机制?

1、注意力机制(Attention Mechanism)是机器学习和深度学习中一种模拟人类注意力的方法,用于提高模型在处理大量信息时的效率和效果。通俗地理解,它就像是在一堆信息中找到最重要的部分,把注意力集中在这些关键点上,从而更好地完成任务。以下是几个简单的比喻来帮助理解注意力机制: 2、寻找重点:想象一下,你在阅读一篇文章的时候,有些段落特别重要,你会特别注意这些段落,反复阅读,而对其他部分

【Tools】大模型中的注意力机制

摇来摇去摇碎点点的金黄 伸手牵来一片梦的霞光 南方的小巷推开多情的门窗 年轻和我们歌唱 摇来摇去摇着温柔的阳光 轻轻托起一件梦的衣裳 古老的都市每天都改变模样                      🎵 方芳《摇太阳》 在大模型中,注意力机制是一种重要的技术,它被广泛应用于自然语言处理领域,特别是在机器翻译和语言模型中。 注意力机制的基本思想是通过计算输入序列中各个位置的权重,以确

FreeRTOS内部机制学习03(事件组内部机制)

文章目录 事件组使用的场景事件组的核心以及Set事件API做的事情事件组的特殊之处事件组为什么不关闭中断xEventGroupSetBitsFromISR内部是怎么做的? 事件组使用的场景 学校组织秋游,组长在等待: 张三:我到了 李四:我到了 王五:我到了 组长说:好,大家都到齐了,出发! 秋游回来第二天就要提交一篇心得报告,组长在焦急等待:张三、李四、王五谁先写好就交谁的

多路转接之select(fd_set介绍,参数详细介绍),实现非阻塞式网络通信

目录 多路转接之select 引入 介绍 fd_set 函数原型 nfds readfds / writefds / exceptfds readfds  总结  fd_set操作接口  timeout timevalue 结构体 传入值 返回值 代码 注意点 -- 调用函数 select的参数填充  获取新连接 注意点 -- 通信时的调用函数 添加新fd到

UVM:callback机制的意义和用法

1. 作用         Callback机制在UVM验证平台,最大用处就是为了提高验证平台的可重用性。在不创建复杂的OOP层次结构前提下,针对组件中的某些行为,在其之前后之后,内置一些函数,增加或者修改UVM组件的操作,增加新的功能,从而实现一个环境多个用例。此外还可以通过Callback机制构建异常的测试用例。 2. 使用步骤         (1)在UVM组件中内嵌callback函

Smarty模板引擎工作机制(一)

深入浅出Smarty模板引擎工作机制,我们将对比使用smarty模板引擎和没使用smarty模板引擎的两种开发方式的区别,并动手开发一个自己的模板引擎,以便加深对smarty模板引擎工作机制的理解。 在没有使用Smarty模板引擎的情况下,我们都是将PHP程序和网页模板合在一起编辑的,好比下面的源代码: <?php$title="深处浅出之Smarty模板引擎工作机制";$content=