(。・∀・)ノ゙嗨!你好这里是ky233的主页:这里是ky233的主页,欢迎光临~
https://blog.csdn.net/ky233?type=blog
点个关注不迷路⌯'▾'⌯
目录
3.局域网LAN: 计算机数量更多了, 通过交换机和路由器连接在一起
一、网络发展
1.独立模式: 计算机之间相互独立
独立模式: 计算机之间相互独立
这个阶段需要有人参与,比如小松可能要用光盘把数据拷贝到终端二,所以效率很低
2.网络互联: 多台计算机连接在一起, 完成数据共享
初步具备网络雏形
3.局域网LAN: 计算机数量更多了, 通过交换机和路由器连接在一起
4.广域网WAN: 将远隔千里的计算机都连在一起
所谓 "局域网" 和 "广域网" 只是一个相对的概念,也可以看作是一个很大的局域网
二、认识 "协议"
"协议" 是一种约定
1.高小琴例子
计算机之间的传输媒介是光信号和电信号. 通过 "频率" 和 "强弱" 来表示 0 和 1 这样的信息. 要想传递各种不同的信息, 就需要约定好双方的数据格式
数据是由类别的,有些是属性有些是内容,因为类别不同所以我们处理的方式也应该不同,为了能让千里相隔的计算机快速识别出一些含义,所以就会用提前约定好的协议来减少消耗!
2.方言例子
计算机生产厂商有很多,OS也有很多,网络硬件设备, 还是有很多
那么如何让这些不同厂商之间生产的计算机能够相互顺畅的通信?
就需要有人站出来, 约定一个共同的标准, 大家都来遵守, 这就是网络协议
三、网络协议初识
1.协议分层
1.操作系统要进行协议管理——先描述,在组织,本质上全都是一个个的结构体
2.协议本质就是软件,软件是可以分层的,分层:如一个类,创建是一个分层,使用也是一个分层
3.协议在被设计的时候,就是被层状划分的
那么为什么要划分为层状结构呢?
- 这是因为我们面对的场景会复杂
- 可以进行功能解耦,便于各种维护
- 所以综上所述,网络协议也被设计成了层状结构。
2.OSI七层模型
- OSI(Open System Interconnection,开放系统互连)七层网络模型称为开放式系统互联参考模型, 是一个逻辑上的定义和规范;
- 把网络从逻辑上分为了7层. 每一层都有相关、相对应的物理设备,比如路由器,交换机;
- OSI 七层模型是一种框架性的设计方法,其最主要的功能使就是帮助不同类型的主机实现数据传输;
- 它的最大优点是将服务、接口和协议这三个概念明确地区分开来,概念清楚,理论也比较完整. 通过七 个层次化的结构模型使不同的系统不同的网络之间实现可靠的通讯;
- 但是, 它既复杂又不实用; 所以我们按照TCP/IP四层模型来讲解.
3.TCP/IP协议
- 物理层: 负责光/电信号的传递方式. 比如现在以太网通用的网线(双绞 线)、早期以太网采用的的同轴电缆 (现在主要用于有线电视)、光纤, 现在的wifi无线网使用电磁波等都属于物理层的概念。物理层的能力决 定了最大传输速率、传输距离、抗干扰性等. 集线器(Hub)工作在物理层.
- 数据链路层: 负责设备之间的数据帧的传送和识别. 例如网卡设备的驱动、帧同步(就是说从网线上检测 到什么信号算作新帧的开始)、冲突检测(如果检测到冲突就自动重发)、数据差错校验等工作. 有以太 网、令牌环网, 无线LAN等标准. 交换机(Switch)工作在数据链路层.
- 网络层: 负责地址管理和路由选择. 例如在IP协议中, 通过IP地址来标识一台主机, 并通过路由表的方式规 划出两台主机之间的数据传输的线路(路由). 路由器(Router)工作在网路层.
- 传输层: 负责两台主机之间的数据传输. 如传输控制协议 (TCP), 能够确保数据可靠的从源主机发送到目标 主机.
- 应用层: 负责应用程序间沟通,如简单电子邮件传输(SMTP)、文件传输协议(FTP)、网络远程访问 协议(Telnet)等. 我们的网络编程主要就是针对应用层.
通信的复杂,本质是和距离成正相关的!
复杂的体现就是协议栈要解决的问题,如:
应用范畴:
- 如何处理数据
通信范畴:基于TCP/IP协议
- 丢包——传输层
- 定位问题——网络层
- 解决下一跳主机的问题:中间转输的问题——数据链路层
一般而言
- 对于一台主机, 它的操作系统内核实现了从传输层到物理层的内容;
- 对于一台路由器, 它实现了从网络层到物理层;
- 对于一台交换机, 它实现了从数据链路层到物理层;
- 对于集线器, 它只实现了物理层
- 但是并不绝对. 很多交换机也实现了网络层的转发; 很多路由器也实现了部分传输层的内容(比如端口转发)
四、网络传输基本流程
1. TCP/IP通信过程
两台主机通过局域网是可以直接进行通信的
在逻辑上将,两台主机直接在应用层进行通信,但是在物理上,两台主机无法直接在应用层进行通信
也就是说我们在物理上是从:
应用层——传输层——网络层——链路层——另一个以太网——另一个网络层——另一个传输测——另一个应用层,
而不是直接从应用层到——另一个应用层
———————————————————————————————————————————
每层都有自己的协议定制方案:
- 每层协议都要有自己的协议报头
- 从上到下交付数据的时候,要添加报头
- 从下到上递交数据的时候,要去掉报头
1.协议报头:当上层把书记交给下层时,下层也有自己的协议,下层需要把上层交给的数据,添加上自己的报头,以供对方的同层协议,来进行解包对属性做提取,
2.我们可以把从上到下交付的过程称之为封装:到达链路层之后
其实是用户创建的数据加上这几个层级的报头一起在以太网中传递的
3.去报头的过程称之为解包:到达对方的链路层之后,在一层层的提取去报头得到想要的数据
而每一层因为功能解耦,所以每一层都只能传输到相对应的其他机器的每一层,所以,同层都认为自己在与对方的同一层进行逻辑上的直接通信!
2.那么是如何通信的呢?
每一台主机都有自己的MAC地址,其他的主机收到了一个信息,发现不是自己的地址,所以直接丢弃掉了,所以只有对应地址的主机才会解包。
MAC地址:
3.跨网络通信的原理
跨网段的主机的文件传输. 数据从一台计算机到另一台计算机传输过程中要经过一个或多个路由器
A主机是以太网,经过路由器转换为令牌环的报头,而路由器和以太网,令牌环都可通信,所以,也可以转换,经过一次或者数次转换就可以到达B主机
转换的过程:首先我们的资源带着我们的源IP和目的IP,到达我们的第一个路由器,获取到现在的MAC地址,和下一站的MAC地址,然后根据刚刚获取到的下一站MAC地址,去下一次路由,就这样直到达到B主机
就比如上图,我们的资源加上IP报头,加以太网报头,到路由器去以太网的报头,加上令牌环的报头,到达B主机然后去掉令牌环的报头。
这其中在使用我们的TCP/IP协议的网络中,不管是那个局域网,IP及其向上的协议,看到的报头都是一样的
五、网络中的地址管理
1.IP地址
IP协议有两个版本, IPv4和IPv6. 我们整个的课程, 凡是提到IP协议, 没有特殊说明的, 默认都是指IPv4
- IP地址是在IP协议中, 用来标识网络中不同主机的地址;
- 对于IPv4来说, IP地址是一个4字节, 32位的整数;
- 我们通常也使用 "点分十进制" 的字符串表示IP地址, 例如 192.168.0.1 ; 用点分割的每一个数字表示一个 字节, 范围是 0 - 255
2.MAC地址
- MAC地址用来识别数据链路层中相连的节点;
- 长度为48位, 及6个字节. 一般用16进制数字加上冒号的形式来表示(例如: 08:00:27:03:fb:19)
- 在网卡出厂时就确定了, 不能修改. mac地址通常是唯一的(虚拟机中的mac地址不是真实的mac地址, 可 能会冲突; 也有些网卡支持用户配置mac地址)