独立模式:计算机之间相互独立
在早期的时候,计算机之间是相互独立的,此时如果多个计算机要协同完成某种业务,那么就只能等一台计算机处理完后再将数据传递给下一台计算机,然后下一台计算机再进行相应的业务处理,效率非常低下。
网络互联: 多台计算机连接在一起, 完成数据共享;
这时就有人就设法将这些计算机连接在一起,当某个业务需要多台计算机协同完成时,就可以将共享的数据放到服务器中进行集中管理,此时各个计算机就都能获取到这些共享的数据,所以各个业务在处理就能随时进行切换了。
局域网LAN: 计算机数量更多了, 通过交换机连接在一起;
网络雏形逐渐发展,连入这个网络中的机器变得越来越多,于是就出现了局域网的概念。
在局域网中有一种设备叫做交换机,交换机主要完成局域网内数据的转发工作,也就是在局域网内将数据从一台主机转发给另一台主机。各个局域网之间通过路由器连接起来,路由器主要完成数据的路由转发工作。
广域网WAN: 将远隔千里的计算机都连在一起
各个局域网之间通过路由器相互连接在一起,便组成了一个更大的网络结构,我们将其称之为广域网。实际局域网和广域网是一种相对的概念,我们也可以将广域网看作一个比较大的局域网。
计算机之间的传输媒介是光信号和电信号. 通过 “频率” 和 “强弱” 来表示 0 和 1 这样的信息,要想传递各种不同的信息, 就需要约定好双方的数据格式。
“协议” 的本质是一种约定,通信双方只要曾经做过某种约定,之后就可以使用这种约定来完成某种事情,有了协议我们通信的数据才能被正常识别,通信才有意义。
为了让计算机能够相互顺畅的通信, 需要约定一个共同的标准,大家都来遵守,这就是网络协议。
为了定制好协议,我们应该先分析网络通信的时候,有哪些问题会产生?有哪些需求要解决?要为什么会产生这些问题?
问题:
为什么会产生上面的问题?单纯的是传输的距离变长了!!!
需求:
仔细分析需求我们就会发现,上面的需求的不同类型的需求,而且它们的问题解决是要有先后顺序的,只有定位了一台目标主机,才会有路径选择的问题,路径选择的问题解决了才会有数据异常的问题(丢失)的问题!
所以我们在解决问题时,要把相关的问题放在一起,做出解决方案,而不是眉毛胡子一把抓,这样我们做出的方案才是高内聚低耦合的解决方案,又由于上面的问题解决是要有先后顺序的,所以我们的解决方案一定是层状的,每一层都是高内聚低耦合的!
分层最大的好处在于“封装”,在分层情况下,将某层的协议进行替换后,通信双方之间是不会受到影响的。
OSI七层模型如下:
————————————————
版权声明:图片来自于为CSDN博主「2021dragon」的原创文章。
TCP/IP是一组协议的代名词,它还包括许多协议,组成了TCP/IP协议簇.
TCP/IP通讯协议采用了5层的层级结构(将OSI的会话层,表示层,应用层三层进行压缩为一层,统一称为应用层),每一层都呼叫它的下一层所提供的网络来完成自己的需求.
TCP/IP模型和计算机体系结构是什么关系呢?
对于网络协议栈的的传输层最经典的协议是TCP协议,对于网络层最经典的协议是IP协议,所以TCP/IP协议其是在操作系统内部实现的!这两部分所有的操作系统都要相同,这样才能保证网络能够正常通信,但是对于网络协议的其他部分的实现就可以有不同,只要能够使传输层和网络层能正常工作就行。
操作系统没有网络管理的大类,但是由于一切皆文件的思想,网卡在操作系统看来也是一种文件,所以从网卡中拿取数据就好像从文件中拿取数据一样,所以网络管理是隶属于文件管理的!
OSI参考模型与TCP/IP模型和计算机体系结构的关系
物理层我们考虑的比较少. 因此很多时候也可以称为 TCP/IP四层模型.
一般而言:
但是并不绝对. 很多交换机也实现了网络层的转发; 很多路由器也实现了部分传输层的内容(比如端口转发);
集线器
电磁信号在长距离传输过程中信号是会衰减的,而集线器的主要功能就是对接收到的信号进行再生整形放大,以扩大网络的传输距离,同时把所有节点集中在以它为中心的节点上。
需要注意的是,集线器属于纯硬件网络底层设备,基本上不具有类似于交换机的“智能记忆”能力和“学习”能力,也不具备交换机所具有的MAC地址表,所以它发送数据时都是没有针对性的,而是采用广播方式发送,也就是说,当集线器要向某节点发送数据时,不是直接把数据发送到目的节点,而是把数据包发送到与集线器相连的所有节点。
两台主机进行文件传输为例,此时各层对应的协议有以下协议:
两个主机通信的本质,是两个主机的OS与网络协议栈在通信,在网络通信时,每层都要有自己的协议!,协议的表现形式: 协议报头。
类比到我们日常的网购中,我们买了东西,最后并不是直接收到了买到的商品,而是一个包裹,包裹上面贴着快递单。虽然这个快递单对于我们自己来说不是必须的,但是对于快递员来说是必须要有的。在物流体系中,快递单 + 商品,才是物流的主体。同理,在每一层协议中,协议报头 + 有效载荷才是协议的主体
数据包封装和分用
当用户要将文件传输给另一台主机前,该文件数据需要先通过网络协议栈进行封装:
数据封装完毕后就可以通过局域网将其发送给对端主机了,而当对端主机收到数据后,对应也需要通过网络协议栈对该数据进行解包与分用:
下图为数据解包与分用的过程:
总结:
局域网内数据是怎么进行传输的?
在一个局域网当中,除了当前正在进行通信的A主机和B主机以外,还可能会有其他的主机,那A主机是如何将数据成功发送给B主机的呢?
实际上,局域网内传输数据时是通过广播的方式进行传输数据,所以该局域网内的所有主机其实都能收到数据。
任何设备要通信,都需要有唯一的标示符,对于计算机也是如此,每台计算机都配有网卡,网卡在出厂时,就在内部被写入了sn号,也称MAC地址,此地址全球唯一。
在局域网中发送的数据实际叫做MAC数据帧,在这个MAC数据帧的报头当中会包含两个字段,分别叫做源MAC地址和目的MAC地址。
在局域网中进行通信的时候,每一个主机在收到一个MAC数据帧后,都会提取该MAC数据帧的报头,找到对应的目的MAC地址与自己的MAC地址进行比对。如果该MAC地址与自己的MAC地址不匹配,则直接将该MAC数据帧丢弃,只有MAC地址匹配时,该主机才会将该数据帧的有效载荷继续向上进行交付处理。
什么是碰撞?
当主机A在向主机B发送数据时,其他主机彼此之间可能也正在进行通信,甚至主机A在和主机B通信的同时也在和其他主机进行通信。
但同一局域网中的所有主机在通信时,使用的都是一个共同的通信信道,因此如果局域网内的多台主机同时进行通信,此时这些数据之间就可能会相互干扰。
每一个局域网都可以看作是一个碰撞域,如果某个主机发送出去的数据与其他主机发送的数据之间产生了干扰,我们就称这两台主机在该碰撞域中发生了碰撞。
如何判断发送出去的数据是否发生了碰撞?
因为发送到局域网当中的数据是所有主机都能够收到的,因此当一个主机将数据发送出去后,该主机本身也是能够收到这个数据的。当该主机收到该数据后就可以将其与之前发送出去的数据进行对比,如果发现收到的数据与之前发送出去的数据不相同,则说明在发送过程中发生了碰撞。
也就是说,主机实际是能够通过某种方式,知道曾经发送出去的数据是否发生了碰撞的。
发生碰撞后是如何处理的?
当一个主机发现自己发送出去的数据产生了碰撞,此时该主机就要执行“碰撞避免”算法。“碰撞避免”算法实际很简单:当一个主机发送出去的数据产生了碰撞,那么该主机可以选择等一段时间后,再重新发送该数据。这就像现实生活中的两个人同时想要说话,此时对方就都会说“你先说吧”,这实际上就是一种碰撞避免。
需要注意的是,实际在网络通信压力不大的时候发生碰撞的概率是不大的,我们不要太小瞧计算机的处理速度,也不要太小瞧网线传播数据的速度。
与碰撞相关的一种局域网攻击机制
如果局域网内的某台主机一直向该局域网内发送一些无用的数据,那么其他主机一发数据就会产生碰撞,此时该局域网也就瘫痪了,这实际就是局域网本身的一个攻击原理。但需要注意的是,这台一直发送“垃圾数据”的主机,必须要通过某种方式绕过“碰撞避免”算法,否则当其发送的数据产生碰撞后,该主机自己也会执行“碰撞避免”算法。
上面说的都是同一局域网内的主机之间的通信,那跨局域网的两台主机之间是如何进行通信的呢?
局域网之间都是通过路由器连接起来的,因此一个路由器至少能够横跨两个局域网。而这些被路由器链接的局域网都认为:该路由器就是本局域网内的一台主机,因此路由器可以和这些局域网内的任意一台主机进行直接通信。
跨网络的两台主机通信原理与局域网类似,但是还有一些重要的问题:
怎么确定我们要通信的两台主机是在同一个局域网内还是在两个不同的局域网内?
在网络中我们可以使用IP地址来标识不同主机,报文在自顶向下发送的时候,会经过网络层,在网络层中可以根据目的IP查询路由表,确定目标主机与自己在不在同一个网络,如果在就将报文发送给对应的主机,如果不在,报文就会通过内网被转发到路由器,由路由器进行转发。
采用不同通信标准的两个局域网内的主机,为什么能够正常通信?
例如上面的的两台分别在以太网与令牌环网的主机,当路由器接收到来自以太网的报文时,会对对应的报头进行解包,然后将剩下的数据向上交付给网络层,在网络层进行路由确定目标IP所在的网络,再将数据向下交付给对应的链路层,此时在链路层当中就会给该数据添加上令牌环对应的报头信息,然后再将该数据发送到令牌网当中,此时该数据就能够在令牌环网当中正常传输和解包了。
IP地址的好处
IP地址的存在除了帮助数据路由以外,还有一个很重要的作用,那就是屏蔽了底层网络的差异。对于通信主机双方的IP层及其往上的协议来说,它们并不需要关心底层采用的是以太网还是令牌环网,它们认为只要填写了源IP地址和目的IP地址就能够将数据发送出去,因此现在主流的网络也叫做“IP网络”。
MAC地址与IP地址的区别:
IP地址为报文定制最终地址,在数据转发的路上根据IP地址进行路径选择。
MAC地址用来选择数据转发的下一站的设备地址,所以数据一路转发的过程中,转发数据的设备在变,所以MAC地址也会变,但是IP地址不会变。
在Linux中,我们可以使用ifconfig
命令可以查看当前主机所对应的的MAC地址和IP地址。