在上一篇博文中,我们见证了 IP 地址的诞生,机器一旦有了 IP,就可以在网络的环境里和其他的机器展开沟通了。

    今天,我们来认识下 物理层MAC 层。

    日常生活中,身为 90 后的我们,如果不是通信相关专业出身的,应该从来没有接触过物理层和 MAC 层的设备。我们接触最多的,可能就是路由器了。而路由器实际上是第三层-网络层的设备了。

    那咱们怎么认识物理层呢?就不扯那些深奥的理论了,从宿舍联机打魔兽说起吧。

    要想宿舍里的几台电脑连接到一个局域网内,第一反应就是买个路由器,大家都连上去就 OK 了。但是在 15 年前,路由器还没有那么普及的时候,你在校园里找个通信专业的学生问,知道怎么组建宿舍局域网吗?他应该会回答你,有三种方式:

  1. 网线连接
  2. 集线器连接
  3. 交换机

物理层

    上面三种方式中,网线连接和集线器是完全在物理层工作,咱们就先见识下这两种方式。

网线连接

    是的,你没看错,是用一根网线连接在两个电脑上。网线水晶头的第 1、2 和第 3、6脚,分别起着发、收信号的作用,要想通过一根网线将两台电脑连接在一个局域网上,需要额外做的操作就是将网线其中一端的 1 号和 3 号线、2 号和 6 号线互换一下位置,这样就能在物理层实现一端发送的信号,另一端成功接收。

    当然,除了通过网线连接外,我们还需要配置这两台电脑的 IP 地址、子网掩码和默认网关,将这三项配置成为一个网络,否则是不通的。

    这样,一个宿舍的两台电脑就可以联机打魔兽了。

    问题来,如果又有一个舍友买了电脑,怎么把三台电脑连一起呢?先别说交换机这高档的东西,对于 15 年前的大学生来说,交换机太贵了,买不起。好在除了交换机外,还有个叫做 Hub 的东西,也就是集线器

集线器

    这种设备有多个口,可以将宿舍里的多台电脑连接起来。和交换机不同的是,集线器很“傻”,它没有大脑,完全在物理层工作,将自己收到的每一个字节,都复制到其它端口上去。

    这就像,小明想找小红表白,他不知道小红在哪个小区,于是他就找其它小伙伴,让每个小伙伴负责一个小区,去每一户问是不是小红家,找到小红的小伙伴就将表白语告诉小红。

数据链路层

    上面通过 Hub 实现局域网的方式,你可能已经发现了,Hub 采取的是广播的模式。如果每一台电脑发出的包,局域网内的其它电脑都能收到,那就麻烦了。这就需要解决几个问题:

  1. 这个包是发给谁的?谁接收?
  2. 大家都在发生消息,会不会产生混乱?有没有先后的规则?
  3. 如果发生的时候出错了,怎么办?

    这几个问题,都是数据链路层,也就是 MAC 层要解决的问题。MAC 的全称是 Medium Access Control,即媒体介质访问控制。这里的控制,其实就是控制在往媒体上发数据时,谁先发、谁后发的问题,也就是防止发生混乱。这就解决了第二个问题。这个问题中的规则,学名叫多路访问。和我们交通管制一样,常见的有下面三种方式:

  • 方式一:分车道。每个车一个车道,你走你的,我走我的,互不干扰。这在计算机网络中叫做信道划分
  • 方式二:今天单号出现,明天双号出现,轮着来。这叫做轮流协议
  • 方式三:不管三七二十一,有事先出门,发现很堵,就回去等待 ,错过高峰期再走。这叫做随机接入协议。著名的以太网,用的就是这种方式。

    要解决第一个问题:发给谁?谁接收?这里用到一个物理地址,叫做链路层地址。但是因为第二层主要解决媒体接入控制的问题,所以它常常被称为 MAC 地址。

    解决第一个问题就牵扯到第二层的网络包格式。对于以太网,第二层的最开始,就是目标 MAC 地址和源 MAC 地址。

    接下来是类型。大部分的类型是 IP 数据包,其中 IP 里面包含 TCP、UDP,以及 HTTP 等,这些都是里层封装的事情。

    有了这个目标 MAC 地址,数据包在链路上广播,MAC 的网卡才能发现,这个包是给它的。MAC 的网卡把包收进来,然后打开 IP 包,发现 IP 地址也是自己的,再打开 TCP 包,发现端口是 80,而 nginx 就是监听 80 端口。

    于是就将请求提交给 nginx,nginx 返回一个网页,最后再经过层层封装,返回到 MAC 层。因为来的时候有源 MAC 地址,返回的时候,源 MAC 地址就变成了目标 MAC 地址,再返给请求的机器。

    对于以太网,第二层的最后面是 CRC,也就是循环冗余检测。通过 XOR 异或的算法,来计算整个包是否在发送的过程中出现了错误,这主要解决了第三个问题。

    这里还有一个没有解决的问题,当源机器知道目标机器的时候,可以将模板地址放入包里。如果不知道呢?一个广播的网络里面接入了 N 台地址,我怎么知道每个 MAC 地址是谁呢?这就是 ARP 协议,也就是已知 IP 地址,求 MAC 地址的协议

    在一个局域网里,如果知道了 IP 地址,不知道 MAC 地址怎么办?这个在网络协议-概述中有提过,本地通信靠“吼”。

    发送一个广播包,广而告之,谁说这个 IP 谁来回答。具体询问和回答的报文就像下面这样:

    为了避免每次都用 ARP 协议,机器本地会进行 ARP 缓存。当然,缓存的 MAC 地址会有一个过期时间。

    上面解决了广播发出的包,局域网内所有机器都能收到的问题。那么 Hub 是采用怎么样的方式?

    实际上,Hub 不管某个接口是否需要,所有的数据都会发送出去,然后让主机来判断是否需要相关数据。这种方式会有两个问题:

  1. 机器数目大幅增多后,产生冲突的概率就提高了。这很好理解,那么多小伙伴去找小红,发生交通事故的概率要大于,直接去她家表白发生交通事故的概率;
  2. 把大量不需要发送的包发送出去,浪费资源。

    明显可以看出,要解决上面两个问题,只要我们知道哪个接口对应哪个 MAC 地址就好了。如果目标 MAC 地址不是这台电脑的,这个口就不用转发了。

    那么,谁能知道目标 MAC 地址是否就是连接某个口的电脑的 MAC 地址呢?这就需要一个能把 MAC 头拿下来,检查一下目标 MAC 地址,然后根据策略转发的设备,也就是我们之前提过的,二层设备-交换机

    交换机怎么知道每个口对应的电脑的 MAC 地址呢?这需要交换机能学习。这个也是交换机和 Hub 最明显的区别。

    一台 MAC1 电脑将一个包发送给另一台 MAC2 电脑,当这个包到达交换机的时候,一开始交换机也不知道 MAC2 电脑再哪个口,所以没办法,它只能将包转发给除了来的那个口之外的其他所有的口。但是,这个时候,交换机会干一件很聪明的事情,就是交换机记住,MAC1 是来自一个明确的口,以后有包的目的地址是 MAC1 的,就直接发送到对应口就可以了。

    当交换机作为一个关卡一样,过来一段时间后,就有了整个网络的一个结构了。这个时候,基本上不用广播,全部可以准确转发。而交换机学习的结果,我们成为转发表。当然,每台机器的 IP 地址会变,所在的口也会变,所以转发表也是有一个过期时间的。

小结

上面扯了一大堆,实际上也就是几句话的事:

  • MAC 层是用来解决多路访问的堵车问题的
  • ARP 是通过“吼”的方式来寻找目标 MAC 地址,之后会记住一段时间,这个叫做 ARP 缓存
  • 交换机是升级版的 Hub,它有 MAC 地址学习能力,学完就能记住每个 MAC 地址对应哪个口,学习的成果叫转发表

欢迎添加个人微信号:Like若所思。

欢迎关注我的公众号,不仅为你推荐最新的博文,还有更多惊喜和资源在等着你!一起学习共同进步!

网络协议 3 - 物理层 和 MAC 层的更多相关文章

  1. 网络协议 3 - 从物理层到 MAC 层

        在上一篇博文中,我们见证了 IP 地址的诞生,机器一旦有了 IP,就可以在网络的环境里和其他的机器展开沟通了.     今天,我们来认识下 物理层 和 MAC 层.     日常生活中,身为 ...

  2. 网络协议学习笔记(二)物理层到MAC层,交换机和VLAN,ICMP与ping原理

    概述 之前网络学习笔记主要讲解了IP的诞生,或者说整个操作系统的诞生,一旦有了IP,就可以在网络的环境里和其他的机器展开沟通了.现在开始给大家讲解关于网络底层的相关知识. 从物理层到MAC层:如何在宿 ...

  3. 5.从物理层到MAC层

    第一层(物理层)     如何用两台电脑构成最小的局域网(LAN)?     网线的水晶头1.2和3.6脚分别起着收.发信号的作用,随意只要将水晶头做交叉线1-3.2-6交叉法,然后连接两台电脑.除了 ...

  4. 5(计算机网络)从物理层到MAC层

    故事就从我的大学宿舍开始讲起吧.作为一个八零后,我要暴露年龄了. 我们宿舍四个人,大一的时候学校不让上网,不给开通网络.但是,宿舍有一个人比较有钱,率先买了一台电脑.那买了电脑干什么呢? 首先,有单机 ...

  5. 第5讲 | 从物理层到MAC层:如何在宿舍里自己组网玩联机游戏?

    第一层(物理层) 水晶头要做交叉线,用的就是所谓的 1-3.2-6 交叉接法. 有一个叫做 Hub 的东西,也就是集线器.这种设备有多个口,可以将宿舍里的多台电脑连接起来.但是,和交换机不同,集线器没 ...

  6. 网络协议学习笔记(四)传输层的UDP和TCP

    概述 传输层里比较重要的两个协议,一个是 TCP,一个是 UDP.对于不从事底层开发的人员来讲,或者对于开发应用的人来讲,最常用的就是这两个协议.由于面试的时候,这两个协议经常会被放在一起问,因而我在 ...

  7. 网络编程网络协议篇(osi七层协议)

    一 互联网的本质 咱们先不说互联网是如何通信的(发送数据,文件等),先用一个经典的例子,给大家说明什么是互联网通信. 现在追溯到八九十年代,当时电话刚刚兴起,还没有手机的概念,只是有线电话,那么此时你 ...

  8. 网络协议 13 - HTTPS 协议:加密路上无尽头

    系列文章传送门: 网络协议 1 - 概述 网络协议 2 - IP 是怎么来,又是怎么没的? 网络协议 3 - 从物理层到 MAC 层 网络协议 4 - 交换机与 VLAN:办公室太复杂,我要回学校 网 ...

  9. 网络协议 12 - HTTP 协议:常用而不简单

    系列文章传送门: 网络协议 1 - 概述 网络协议 2 - IP 是怎么来,又是怎么没的? 网络协议 3 - 从物理层到 MAC 层 网络协议 4 - 交换机与 VLAN:办公室太复杂,我要回学校 网 ...

随机推荐

  1. 关于ConfigurationSection自定义config的简单使用

    1.1.自定义config结构(参考对应颜色标注),放到configuration根节点下: <test> <testInfos> <" /> <& ...

  2. Android中Parcelable的使用

    转载请标明出处 :https://www.cnblogs.com/tangZH/p/10998065.html  Parcelable与Serializable Serializable是Java为我 ...

  3. ORACLE数据库中执行计划出现INTERNAL_FUNCTION一定是隐式转换吗?

    ORACLE数据库中,我们会使用一些SQL语句找出存在隐式转换的问题SQL,其中网上流传的一个SQL语句如下,查询V$SQL_PLAN的字段FILTER_PREDICATES中是否存在INTERNAL ...

  4. 初学Manjaro

    近期,看有朋友在使用Manjaro系统,感觉这个系统挺不错,于是我也安装了Manjaro,学习一下!!!! Manjaro下载地址:https://manjaro.org/download/ Manj ...

  5. 面试连环炮系列(十一):说说你们的分布式ID设计方案

    说说你们的分布式ID设计方案 我们采用Snowflake算法,生成一个64bit的数字,64bit被划分成多个段,分别表示时间戳.机器编码.序号. 41位的时间序列(精确到毫秒,41位的长度可以使用6 ...

  6. ps -ef |grep -v 在shell sh 脚本中貌似无效?

    想通过ps -ef |grep erdp_ |awk '{print $2}' 获取 erdp_ 开头的进程id, 执行在终端环境下执行是ok的,但是在 sh 脚本里面竟然多出了 两个 root 11 ...

  7. asp.net core的AOP记录

    序曲:学习编程最好的方式就是敲代码,没有比这个更好的方法,哪怕你看了上百G的视频,都不如你自己敲几行代码更为有效.还有要记得敲完代码然后写一篇随笔来记录一下你所学所想. 什么叫AOP? AOP面向切面 ...

  8. 精通awk系列(11):awk的工作流程

    回到: Linux系列文章 Shell系列文章 Awk系列文章 awk工作流程 参考自:man awk的"AWK PROGRAM EXECUTION"段. man --pager= ...

  9. wpf 模拟抖音很火的罗盘时钟,附源码,下载就能跑

    wpf 模拟抖音很火的罗盘时钟,附源码 前端时间突然发现,抖音火了个壁纸,就是黑底蕾丝~~~  错错错,黑底白字的罗盘时钟! 作为程序员的我,也觉得很新颖,所以想空了研究下,这不,空下来了就用wpf, ...

  10. C# 结合 PInvoke 对接 IP 摄像头的笔记

    最近做项目的时候,需要对接厂商提供的 IP 摄像头.但是他们只提供了 C++ 的 SDK,没办法,只能开始撸 C# 的 SDK Helper 类.本篇文章主要记录了对接 C++ DLL 需要注意的几个 ...