独立模式: 计算机之间相互独立。
网络互联: 多台计算机连接在一起, 完成数据共享。
局域网LAN: 计算机数量更多了, 通过交换机和路由器连接在一起。
广域网WAN: 将远隔千里的计算机都连在一起。
所谓 “局域网” 和 “广域网” 只是一个相对的概念. 比如, 我们有 “天朝特色” 的广域网, 也可以看做一个比较大的局域网。
我们知道计算机之间的传输媒介是光信号和电信号. 通过 “频率” 和 “强弱” 来表示 0 和 1 这样的信息. 要想传递各种不同的信息, 就需要约定好双方的数据格式。
计算机生产厂商有很多;,计算机操作系统, 也有很多;,计算机网络硬件设备, 还是有很多, 如何让这些不同厂商之间生产的计算机能够相互顺畅的通信? 就需要有人站出来, 约定一个共同的标准, 大家都来遵守, 这就是网络协议。
首先来举一个通俗易懂的栗子:比如我们打电话。
两个人互相拿着电话通信,在他们的视角上其实认为他们是直接在通信,但实际上并不是这样的,而是他们电话机之间的通信,也就是说此时电话机为用户提供了通信服务,并且用户不关心服务的具体实现,只关心如何使用服务,这样就把用户与电话机分在了不同层次,当哪一部分出现问题时就只处理那一部分就行了。
在这个例子中, 我们的协议只有两层; 但是实际的网络通信会更加复杂, 需要分更多的层次.分层最大的好处在于 “封装”。
TCP/IP是一组协议的代名词,它还包括许多协议,组成了TCP/IP协议簇.。
TCP/IP通讯协议采用了5层的层级结构 (本来TCP/IP通讯协议采用的是4层协议,但是为了教学完整便把物理层也加在了里面,所以为5层,但是我们讲解的重点并不在物理层,所以这里会讲的很简略) ,每一层都呼叫它的下一层所提供的网络来完成自己的需求。
一般而言对于一台主机, 它的操作系统内核实现了从传输层到物理层的内容;对于一台路由器, 它实现了从网络层到物理层;对于一台交换机, 它实现了从数据链路层到物理层;对于集线器, 它只实现了物理层;
但是并不绝对. 很多交换机也实现了网络层的转发; 很多路由器也实现了部分传输层的内容(比如端口转发)。
我们可以用下图来表示CP/IP模型与操作系统的关系:
我们知道操作系统的管理包含一下四个模块:进程管理,文件管理,内存管理,驱动管理。那么网络这部分是属于哪一个呢?其实在Linux中,对于网络这部分的管理是属于文件管理。为什么呢?因为在Linux下一切皆文件,那么也就说明我们未来学到的很多网络接口都跟文件是相关的。我们要学习的网络在本质上就是操作系统的一部分,我们在上图的右侧里面的系统调用(socket编程)就是操作系统为网络通信所创建的接口。
同一个网段内的两台主机进行文件传输:
两台计算机通过TCP/IP协议通讯的过程如下:
跨网段的主机的文件传输.。数据从一台计算机到另一台计算机传输过程中要经过一个或多个路由器:
通过前面我们讲解打电话的栗子中我们不难知道在物理上"数据"的传输是从上到下,在从下到上的;但在逻辑上"数据"的传输可以认为是同层间直接进行交互。
在这里我们简单讲解下以太网和令牌环的通信原理:
数据包封装和分用:
但是数据在传输过程中为了每一层能够正确接受的转发数据,我们还得进行数据包的封装和分用。
不同的协议层对数据包有不同的称谓,在传输层叫做段(segment),在网络层叫做数据报 (datagram),在链路层叫做帧(frame).应用层数据通过协议栈发到网络上时,每层协议都要加上一个数据首部(header),称为封装(Encapsulation).。
首部信息中包含了一些类似于首部有多长, 载荷(payload)有多长, 上层协议是什么等信息。
数据封装成帧后发到传输介质上,到达目的主机后每层协议再剥掉相应的首部, 根据首部中的 “上层协议字段” 将数据交给对应的上层协议处理。
MAC地址用来识别数据链路层中相连的节点;
IP协议有两个版本, IPv4和IPv6. 我们整个的课程, 凡是提到IP协议, 没有特殊说明的, 默认都是指IPv4.
那么IP地址跟MAC地址有啥区别呢?
我们可以举一个简单的栗子来理解理解:
比如西天取经的栗子,唐僧在取经的路上盖通关文牒的时候,总是会被询问:你是从哪儿来的,要去往哪里?你的上一站是在哪里,下一站又要往哪里去?在这些问题中,MAC地址就是上一站地址和下一站地址,而源IP地址就是唐僧的出发点,目的IP地址就是唐僧的最终目的地。
端口号(port)是传输层协议的内容: