网络基础1

网络基础1

1. 计算机网络背景

1.1 网络发展

独立模式: 计算机之间相互独立

在这里插入图片描述

网络互联: 多台计算机连接在一起, 完成数据共享;

在这里插入图片描述

局域网LAN: 计算机数量更多了, 通过交换机和路由器连接在一起;

在这里插入图片描述

广域网WAN: 将远隔千里的计算机都连在一起;

在这里插入图片描述

所谓 “局域网” 和 “广域网” 只是一个相对的概念. 比如, 我们有 “天朝特色” 的广域网, 也可以看做一个比较大的局域
网。

1.2 认识 “协议”

“协议” 是一种约定.
在这里插入图片描述

计算机之间的传输媒介是光信号和电信号. 通过 “频率” 和 “强弱” 来表示 0 和 1 这样的信息. 要想传递各种不同的信
息, 就需要约定好双方的数据格式。

思考: 只要通信的两台主机, 约定好协议就可以了么?

  • 计算机生产厂商有很多;
  • 计算机操作系统, 也有很多;
  • 计算机网络硬件设备, 还是有很多;
  • 如何让这些不同厂商之间生产的计算机能够相互顺畅的通信? 就需要有人站出来, 约定一个共同的标准,大家都来遵守, 这就是网络协议。

2. 网络协议初识

2.1 协议分层

我们以为什么要协议分层,引出以下两个问题:

  • 网络通信的时候,会有那些需求要解决(有哪些问题产生)?
  1. 长距离传输,数据异常的问题(丢失)

  2. 定位一台主机的问题

  3. 怎么进行数据转发,路径选择的问题(路由)

  4. 010101硬件级别的协议

  • 为什么会有这些问题呢?

    就是单纯的传输距离变长了

既然已经产生了问题,那么需求就出来了,需要提出对应的解决方案

  • 上面的问题,是有先后上下的关系的! 我们设计的时候将不同的功能模块设计成为不同的模块 — 低耦合
  • 不同性质的问题,不要把不相关的问题放在一起,要把相关的问题放在一起,做出解决方案 — 高内聚

于是基于低耦合,高内聚,将解决方案设计成为层状结构。

比如在打电话,人与人之间通信使用的是汉语,我们可以将其称为语言层;而电话和电话之间通信使用的是电话协议,我们可以将其称之为通信设备层

在这里插入图片描述

后来随着科技的发展,我们都用上了智能手机,此时我们下层使用的通信设备变了,或是这部电话卖到了其他国家,此时上层使用的通信语言变了,但我们仍然可以正常沟通。

在这里插入图片描述

在这个例子中, 我们的协议只有两层; 但是实际的网络通信会更加复杂, 需要分更多的层次。

分层最大的好处在于 “封装” ,在分层情况下,将某层的协议进行替换后,通信双方之间是不会受到影响的 。

软件分层之后,每一层都只关注自己同层的功能,只使用下层的接口,任何一层出现问题,都不会直接影响另一层,减少后期开发者的维护成本(高内聚,低耦合)

2.2 OSI七层模型

  • OSI(Open System Interconnection,开放系统互连)七层网络模型称为开放式系统互联参考模型,是一个逻辑上的定义和规范;
  • 把网络从逻辑上分为了7层. 每一层都有相关、相对应的物理设备,比如路由器,交换机;
  • OSI 七层模型是一种框架性的设计方法,其最主要的功能使就是帮助不同类型的主机实现数据传输;它的最大优点是将服务、接口和协议这三个概念明确地区分开来,概念清楚,理论也比较完整. 通过七个层次化的结构模型使不同的系统不同的网络之间实现可靠的通讯;
  • 但是, 它既复杂又不实用; 所以我们按照TCP/IP四层模型来讲解。
分层名称功能每层功能概览
7应用层针对特定应用的协议在这里插入图片描述
6表示层设备固有数据格式和网络标准数据格式的转换在这里插入图片描述
5会话层通信管理、负责建立和断开通信连接(数据流动的逻辑通路)、管理传输层以下的分层在这里插入图片描述
4传输层管理两个节点之间的数据传输、负责可靠性传输(确保数据被可靠地传送到目标地址)在这里插入图片描述
3网络层地址管理与路由选择在这里插入图片描述
2数据链路层互联设备之间传送和识别数据帧在这里插入图片描述
1物理层以0/1代表电压的高低以及灯光的闪灭、界定连接器和网线的规格在这里插入图片描述

2.3 TCP/IP五层(或四层)模型

TCP/IP是一组协议的代名词,它还包括许多协议,组成了TCP/IP协议簇。
TCP/IP通讯协议采用了5层的层级结构,每一层都呼叫它的下一层所提供的网络来完成自己的需求。

  • 物理层: 负责光/电信号的传递方式. 比如现在以太网通用的网线(双绞 线)、早期以太网采用的的同轴电缆(现在主要用于有线电视)、光纤, 现在的wifi无线网使用电磁波等都属于物理层的概念。物理层的能力决定了最大传输速率、传输距离、抗干扰性等. 集线器(Hub)工作在物理层。
  • 数据链路层: 负责设备之间的数据帧的传送和识别. 例如网卡设备的驱动、帧同步(就是说从网线上检测到什么信号算作新帧的开始)、冲突检测(如果检测到冲突就自动重发)、数据差错校验等工作. 有以太网、令牌环网, 无线LAN等标准. 交换机(Switch)工作在数据链路层。
  • 网络层: 负责地址管理和路由选择. 例如在IP协议中, 通过IP地址来标识一台主机, 并通过路由表的方式规划出两台主机之间的数据传输的线路(路由),路由器(Router)工作在网路层。
  • 传输层: 负责两台主机之间的数据传输,如传输控制协议(TCP), 能够确保数据可靠的从源主机发送到目标主机。
  • 应用层: 负责应用程序间沟通,如简单电子邮件传输(SMTP)、文件传输协议(FTP)、网络远程访问协议(Telnet)等。 我们的网络编程主要就是针对应用层。
  • 物理层我们考虑的比较少. 因此很多时候也可以称为 TCP/IP四层模型。

在这里插入图片描述

协议栈与OS的关系

OSI七层模型提出了一种标准,而TCP/IP五层模型是一种具体的解决方案。
TCP/IP五层模型中将OSI中的应用层,表示层,会话层合并成了一层 — 应用层。

  • 这就是具体的协议栈,那么这个协议栈在哪里呢?和OS有什么关系呢?

在这里插入图片描述

为什么叫TCP/IP四层模型?
传输层最具有代表性的协议:TCP协议,网络层最具有代表性的协议:IP协议,传输层和网络层都在OS中,所以TCP/IP协议栈占据核心地位。

一般而言

  • 对于一台主机, 它的操作系统内核实现了从传输层到物理层的内容;
  • 对于一台路由器, 它实现了从网络层到物理层;
  • 对于一台交换机, 它实现了从数据链路层到物理层;
  • 对于集线器, 它只实现了物理层;

但是并不绝对,很多交换机也实现了网络层的转发; 很多路由器也实现了部分传输层的内容(比如端口转发);

3. 网络传输基本流程

3.1 同一个局域网两台主机通信

同一个局域网两台主机可以直接通信吗?可以

数据在两台机器是如何流转的呢?

两个主机通信的本质:两个主机的OS与网络协议栈在通信

我们首先来介绍一种概念:报头

报头的本质是一种数据。比如你网购了某件物品,当你拿到快递后,你得到的实际是快递单+商品,你很可能只关心包裹里的商品,并不在意快递单本身,这里包裹上的快递订单就是一种报头。

向网络中发送数据报时,会添加报头,每一层协议都有自己的报头。

下面以用户发送"你好,吃了吗"为例,来讲解同一局域网中两台主机的通信过程:

在这里插入图片描述

结论:

  • 每一层,都会把上层交付给自己的数据,作为自己的有效载荷
  • 每一层,都有自己的协议报头
  • 对应的层,自己要发送的报文 = 报头 + 有效载荷 ==> 封装
  • 在逻辑上,同层协议,都认为自己在和对方的同层协议在通信
  • 同层协议,能够互相认识对方的报头
  • 几乎每层协议都要有ab这两个功能,未来,任何协议都要有两个基本功能: a. 将报头和有效载荷进行分离 b. 将有效载荷交付给上层的哪一个具体协议;这是一种公共功能,实现了数据报分用。

3.2 同一个路由器的两个子网通信

  • 路由器有3层的功能: 网络层,链路层,物理层
  • 路由器也是一台主机(节点)
  • 路由器至少要级联两个子网,路由器至少要有两个网络接口

局当域网采用的是不同的通信标准,比如局域网1采用的是以太网,而局域网2采用的却是令牌环网,如何进行通信呢?

由于以太网和令牌环网是不同的通信标准,它们给数据添加的报头也是不一样的,因此令牌环网当中的主机无法对以太网当中的数据帧进行解包,反过来也是如此。

这种情况实际是由路由器来处理的,路由器是工作在网络层的一个设备(路由器必须要有两个网络接口,因为路由器至少横跨两个网络)

数据要从局域网1发送到局域网2时,路由器收到局域网1的数据后,会先将以太网对应的报头进行解包,然后将剩下的有效载荷向上交付给网络层,在网络层进行一系列数据分析后,再将数据包进行再一次封装,再交付给链路层,此时在链路层当中就会给该数据包添加上令牌环对应的报头信息,然后再将该数据发送到局域网2当中,此时该数据就能够在令牌环网当中传输了。

上面的这种方式屏蔽了底层子网机制的差异,使IP协议及其以上的协议没有看到任何网络方面的差异;

怎么做到屏蔽了底层网络方面的差异?在 路由器 + IP协议

所以IP协议是全球网络的底层基础 => 变成了软件工程中的核心思路:

任何一个软硬件问题,都可以通过添加一层软件层来解决

在这里插入图片描述

3.3 数据包封装和分用

  • 不同的协议层对数据包有不同的称谓,在传输层叫做段(segment),在网络层叫做数据报 (datagram),在链路层叫做帧(frame)。
  • 应用层数据通过协议栈发到网络上时,每层协议都要加上一个数据首部(header),称为封装(Encapsulation).
  • 首部信息中包含了一些类似于首部有多长, 载荷(payload)有多长, 上层协议是什么等信息。
  • 数据封装成帧后发到传输介质上,到达目的主机后每层协议再剥掉相应的首部, 根据首部中的 “上层协议字段” 将数据交给对应的上层协议处理

下图为数据封装的过程:

在这里插入图片描述

下图为数据分用的过程:

在这里插入图片描述

4. 局域网通信原理(故事版)

和大家在教室上课相同

假设大家现在在教室上课,老师突然叫到了张三同学,问他为什么没写作业,那么其他同学听到这句话了吗,听到了,但其他同学的处理方式是: 这个数据包的报头是张三,有效载荷是你的作业为什么没做,大家先做报文的解包,叫报头和有效载荷分离了,报头是张三,其他人都知道自己不叫张三,那么每个人就会在自己的最底层(数据链路层)将这个报文丢弃了;这名叫做张三的同学站起来告诉老师自己作业昨天已经交了,当张三给老师发数据报时(给老师说话时),其他在教室的同学听到了吗?听到了,消息的报头是老师,有效载荷是作业交了,其他同学对比报头后发现不一致丢弃了,老师听到后告诉同学自己下来去批改他的作业。

  • 在此通信的过程中,老师认为自己和在张三单独通信吗?认为;张三认为自己在和老师单独通信吗?认为;老师和张三完成了一次信息交互,这就叫做以太网的局域网通信原理。

  • 你是班级里喜欢听别人说话的同学,听到别人的对话你会记到本子上,其他同学收到数据报丢弃了,你会把报文盒和效载荷分离后继续向上交付,你所做的就是局域网的抓包工作

  • 网卡设置为混杂模式,可以把收到所有的数据向上交付,这就是抓包工具的主要原理

  • 你是李四,很喜欢说话,在上课期间一会和张三聊天,一会和王五聊天,甚至告诉老师有讲错的知识点,这是一种扰乱课堂秩序的行为,叫做局域网通信中的数据碰撞

结论:

  1. 局域网中,任何时刻,只允许一个人在局域网中发消息
  2. 任何人要通信,需要有唯一的标识符,对于机器也是如此,对于计算机,每台计算机都配有网卡,网卡在出厂的时候就在网卡内部写入了网卡的sn号,即MAC地址,全球唯一

5. 网络中的地址管理

在网络中有两个常用的地址:IP地址和MAC地址

5.0 感性认识

在这里插入图片描述

5.1 认识IP地址

IP协议有两个版本, IPv4和IPv6.后序凡是提到IP协议, 没有特殊说明的, 默认都是指IPv4

  • IP地址是在IP协议中, 用来标识网络中不同主机的地址;
  • 对于IPv4来说, IP地址是一个4字节, 32位的整数;
  • 我们通常也使用 “点分十进制” 的字符串表示IP地址, 例如 192.168.0.1 ; 用点分割的每一个数字表示一个字节, 范围是 0 - 255;

还有另一个版本的IPv6的原因是:IPv4的IP地址不够用了,IPv6用128个比特位来标识IP地址,16字节

注:IPv4和IPv6不兼容

5.2 认识MAC地址

  • MAC地址用来识别数据链路层中相连的节点;
  • 长度为48位, 及6个字节. 一般用16进制数字加上冒号的形式来表示(例如: 08:00:27:03:fb:19)
  • 在网卡出厂时就确定了, 不能修改. mac地址通常是唯一的(虚拟机中的mac地址不是真实的mac地址, 可能会冲突; 也有些网卡支持用户配置mac地址)

我们可以用 ifconfig 命令,在Linux中显示和配置网络接口的信息

在这里插入图片描述

我们用到的大部分局域网都是以太网标准,其中 ether 对应就有”以太“的意思, ether后面跟的就是MAC地址

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值