网络基础,协议,OSI分层,TCP/IP模型

网络的产生是数据交流的必然趋势,计算机之间的独立的个体,想要进行数据交互,一开始是使用磁盘进行数据拷贝,可是这样的数据拷贝效率很低,于是网络交互便出现了;

1.网络是什么

网络,顾名思义是一张网,这张网中包含了许多的计算机,每一张网都叫做局域网。而世界上所有的网络集合在一起就是世界上最大的广域网;这个大的网络就将世界各地的计算机连接在一起;

上面只是我对网络的大致理解;我们有网络,那我们是如何通网络进行交流的呢?我们知道人与人之间可以交流是人们有一套完整的语言体系,而网络虽然将不同的设备连接在一起了,可是不同设备的硬件还有操作系统等都是不同的;那如何可以让这些设备可以正常的交流呢?这就需要如人与人交流一般约定好某种交流方式,不同的设备之间也要约定好某种特定的交流方式,从而实现网络中不同设备的交流;这种约定好的交流方式就是协议

2.协议

2.1 协议是什么?

协议是一种约定;

以寄快递举例:我们发快递的时候,发的不仅仅是我们想要寄的东西,还要用包装盒把我们的物品包装起来,包装盒上还会有快递单号,快递的起始和送达地址等信息;我们和快递公司约定好了你们把我的物品包装成什么样送到某个位置,接收者在收快递的时候就可以通过包装还有包装上的信息确认这个快递是发给他的,从而拆掉包装获取到里面的物品;

所以这里协议的表现形式就是这个快递的包装!

而在计算机网络中,一个设备想要向想要向另一个设备发送信息,一样需要和对方机器约定好,我们将会把数据包装成什么样,使得接收方能够识别这个被包装的数据;从而解开包装,获得里面的信息;而在计算机中往往是使用结构体来作为包装的;

所以这里协议的表现方式是结构体!

约定好的行为是协议,而网络是一个非常庞大的体系,其中所涉及的问题一定非常广泛,并且世界上的设备很多,生产设备的厂家也有许多,想要让一个庞大的体系被全世界所广泛接收,从而全世界都使用这个协议进行交互,这个协议一定要非常优秀,这样的协议就叫做标准;

当一个协议被一部分人所接受,并且为这一部分人创建出红利时,就会有更多的人想加入这个协议,加入协议的人越来越多,这个协议足够优秀时,这个协议也就成为了大多数人所遵守的标准;同样的你想要享受这个协议带来的优惠,你就得遵守这套协议,大多数人遵守这套协议时,这套协议也就真正成为了标准;

在时代的发展下协议也是衍生出来了标准的,这套标准一定是非常优秀的,先辈们耗费无数心血所研发的:

2.2 协议如何定制?

2.2.1 分层的思想

先辈们在处理这个庞大的体系时,花费了很多精力将这个大的网络体系划分出了层次,通过解决一层层的小问题,从而完善整个网络协议;那在网络中的数据传递会有哪些问题呢:

1.在获得转递过来的被包装好的数据时,如何将数据转换为可使用数据?(应用层)

2.传递过程中如果出现数据丢失等意外情况,如何确保数据的安全传递?(传输层)

3.如何确认数据传递到哪一台机器上?(网络层)

4.如何包装好数据让数据可以成功传递呢?(数据链路层)

就如上面划分出的问题一般可以将数据的传递划分为一层层的问题,那么协议也会被划分成层次;

既然说这样划分出层次是有好处的,那究竟有什么好处呢?请看下面的讲解:

如果,我们将上面交流的过程划分为两个层次,我们就可以体会到,分层的好处:

所以将交流的体系划分层次,用高内聚低耦合的思想解决问题,让体系更好维护;使得层与层之间不会互相影响;

让人通过一个设备发送信息到另一个设备上从而让另一个人收到信息的过程,抽象为人与人交流,手机与手机交流;

在我们的C++中也有这样的分层:继承,继承时类中的数据虽然会越来越多,但每个类维护自己的数据,不会收到其他层次类的影响;

那么有了这样分层的思想,网络协议究竟是如何分层的呢?

网络协议的标准——OSI模型

2.3 OSI七层模型

网络这个庞大的体系需要一套好的标准来规范,让大多数人都遵守这样一套好的协议,从而形成标准,而OSI就是这样的标准;

上面的OSI七层模型就是整个网络模型的设计图,这个设计图非常全面,将层次划分的非常完整,所以这个模型就如知道思想一般,可以为网络的实际设计者们提供思路,从而设计出可靠的网络协议;也是如此实际使用的tcp\ip标准模型根据这个OSI参考设计了出来;

2.4 TCP/IP模型 

TCP/IP模型将参考模型OSI简化为了4层模型(一般PIC/IP模型只考虑上面四层,不考虑物理层),将会话层与表示层融合进入了应用层;

通过上面的图片,我们可以知道,通过每层都有自己的协议,通过相同的协议层与层之间可以进行,交流,从而形成数据传输的形式; 

我们看到了一个设备如果想要进行网络交互,就要形成上面的模型,而拥有这样的网络模型的设备是什么样的呢?接下来我们将实际的设备与上面的模型进行相对应的讲解:

1.硬件层(物理层)(PIC/IP模型一般不包括这层)

想要让数据进行传递,那么就得通过某种物品进行传递,我们生活中常见的物品有光纤,无线网络,这样的载体,光纤传输光信号,而无线网络传输无线电波;那么这些信号进行传输也是需要约定好什么样的光和电磁波是什么样的信号(这也是硬件层的协议),这样数据才能正常安全的传递,硬件层也不仅仅只有如传输载体这样的硬件,还会存在很多不一样形式的硬件,他们负责将我们的数据进行传递;

所以物理层负责实际的数据传输;

2.数据链路层

这层是负责将数据处理为帧的形式,负责校验数据的正确性,处理底层硬件层不会处理的错误检测和纠正,让数据正常的传递;我们的硬件网卡,无线网卡,就是起到这样的作用将数据处理好后再将数据转化为底层硬件层所需要的信号类型,从而保证数据传递;

数据链路层负责将数据进行检查与纠错提供给物理层;

3.网络层

每个机器都会有自己的ip地址,通过ip地址可以找到接收者的机器从而成功让信息到达目的地,也是通过ip地址才可以划分出这样一条路由的路线;当数据传输跨局域网时,就得通过路由器来定位路线;

网络层是对数据传输路线的确定;

4.传输层 

对传输来的数据进行检查和对发送的数据进行验证是否发送成功;

确保数据成功的进行了传递

5.应用层 

对成功传输的数据进行某种处理,解析出数据真正的含义,这样的解析是需要通过相同的协议进行处理的;

通过相同协议解析出真正的数据;

那么我们知道了网络模型是这么设计的之后,我们来看看这样设计的模型到底是如何进行数据传输的; 

3.数据的流动过程

TCP/IP是我们网络协议的一个标准模型,所以想要使用网络的设备都需要遵守这个标准都应该具有这个模型的特征,下面我们讲讲设备进行数据传递的过程:

我们可以看到,数据从我们用户从向底层不断加载的过程就是不断封装的过程,通过协议不断封装,数据到达目标设备后会通过协议不断的解包;通过这样就可以实现逻辑上层与层之间的直接通信,但实际上还是数据贯穿网络栈的过程;

所以我们可以总结出这些结论:

1.任何层的协议都具有将报头与有效载荷分离的能力

2.任何层的协议都包含了上一层使用的协议标识字段,帮助上一层解包

我们现在知道了数据是如何流动的,那下面继续抛出问题,数据是如何在网络中进行传递的呢?

4.数据如何在网络中传递

刚刚我们只是考虑到了数据的流动,而设备是分离的,网络究竟是如何做到让数据成功跨设备进行交互的呢?

4.1 局域网数据传递

我们首先举这样一个例子:

在一个班级中老师叫某个同学回答问题,所有人都会听到老师提出的问题,但是其他人都不会回答,只有哪个被老师喊到名字的人会和老师进行交流,因为这只是老师和被喊道名字的人的通讯;

其实局域网也是这样的:

在一个局域网中,当一台设备发送信息时,整个局域网中的设备都会收到这条信息,但是这条信息中包装了许多层协议,局域网中的设备会对这条信息解包,如果发现这条信息不是发送给自己的,则会直接丢弃,如果某个设备发现这条信息正好是发送给直接的,那么就会继续向上解包;

 那么局域网中的设备是如何识别这条信息确实是发送给它的呢?

通过上面的过程,我们也不难会产生一些疑惑,这些疑惑也确实是存在的问题:

1.碰撞问题 

在一个局域网中,如果每个设备都同时发送信息到局域网中,这个那么如此多的消息进行碰撞,会不会导致发生消息丢失或者错误的问题呢?这个问题确实是存在的,因为网络的承载能力是有限的,但是设计者们早就知道了这个问题,为此设计了碰撞避免算法,让局域网中一次只能发送一条信息,避免了信息的碰撞;

这个避免碰撞算法也说明了网络是临界资源,使用网络的设备具有互斥性;

其次如果一个局域网中设备过多的话,会使用交换机来引导数据的流向,进行局域网的划分,减少数据冲突的可能;

 2.安全问题

在一个局域网中,一条信息发送,所有设备都会收到,那么所有设备都会收到的话,如果有设备对这条信息进行抓取,那么会不会存在安全问题呢?这个问题其实也是存在;设备的网卡有普通模式与混杂模式,当网卡的混杂模式开启时,获得的所有数据即使解包后发现mac目的地址不是自己也会先将数据保留,如果此时有人想读取这条数据,那么就可以对这条数据向上继续进行解包从而获得最后的数据;但是这个问题随着时代的发展,人们可以在应用层就对数据进行加密处理,这样即使有是被对数据进行了抓取,他们也无法解析出这个加密的数据;

现在我们知道了数据究竟是如何流通与数据如何在网络中进行传递的;接下来我们得引入更大的网络广域网,当数据想要跳出局域网传递到更远的网络中,应该如何传递呢?

4.2 跨局域网数据传递

 在最前面的1.网络是什么中,我们就说了不同局域网之间需要通过路由器进行连接,那么究竟是如何通过路由器进行连接的呢?

还是一样举一个小例子:

我们的网络也是可以这么理解的:

当设备1想要跨局域网传递给设备2的时候,设备1肯定无法之间将数据传递给设备2,因为他们无法直接建立联系,但是发送信息的设备可以通过路由器作为中转站来传递信息,每个路由器就像上面例子中的小目标,小目标不断发生改变传递到永远不变的大目标设备2上;那么这个过程究竟是怎么进行的呢?

传递过程: 

 首先,每个设备在网络层都会有自己的唯一标识IP地址,每个设备的网卡数据链路层也有自己的唯一标识mac地址;那么设备传输数据需要把数据封装为最后的数据帧,这其中IP地址的起始地址与目的地IP地址也会封装在数据报中(包含在数据帧中),那么设备如果需要跨局域网进行数据传递,封装的数据帧中的mac地址目的地就得是路由器(得通过路由器作为中转站),这个路由器的mac地址目的地就是不断改变的小目标;在一个局域网中的路由器接收到了这个数据帧后,通过网络号找到目标设备的局域网再将mac地址修改为目标局域网中的目标设备的mac地址;目标局域网中的设备都接收到了这条数据帧,但是只有目标设备会对这条数据帧进行解包,获取数据;这个过程中IP地址就是永远不变的大目标,而mac地址就是不断发生改变的小目标

ipv4:32位4个字节,每个字节以.分开,每个点分开的数都是10进制数

例如:193.123.11.12 

mac地址:48位6个字节, 每个自己以:分开,每个:分开的数是16进制数

例如:12:13:14:15:0f

ipv6:128位16个字节; 

IP地址实现了全球主机的虚拟层,实现了一切皆IP报文;

总结:

数据的传输一定是基于硬件层面的,无论数据如何跳转,如何传递,都必须贯穿网络栈传递;

最后再说两个命令:

linux中查ip地址:        "ifconfig"

windows中查ip地址: "ipconfig"

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/428335.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

oracle数据库启动

文章目录 背景一、步骤1.登录oracle用户2.启动监听服务3.启动数据库 背景 oracle数据库启动 一、步骤 1.登录oracle用户 代码如下(示例): su - oracle2.启动监听服务 代码如下(示例): lsnrctl start成…

生信初学者教程(四):软件

文章目录 RRstudioLinux系统其他软件本书是使用R语言编写的教程,用户需要下载R和RStudio软件用于进行分析。 版权归生信学习者所有,禁止商业和盗版使用,侵权必究 R R语言是一种免费的统计计算和图形化编程语言,是一种用于数据分析和统计建模的强大工具。它具有丰富的统计…

C++11——lambda

lambda lambda的介绍lambda的使用lambda的细节->捕捉列表 lambda的介绍 lambda是匿名函数,再适合的场景去使用可以提高代码的可读性。 场景: 假设有一个Goods类需要进行按照价格、数量排序 class Goods {string name;size_t _price;//价格int num;/…

【IoTDB 线上小课 07】多类写入接口,快速易懂的“说明书”!

【IoTDB 视频小课】稳定更新中!第七期来啦~ 关于 IoTDB,关于物联网,关于时序数据库,关于开源... 一个问题重点,3-5 分钟,我们讲给你听: 一条视频了解写入接口 了解我们的友友们,应该…

我的AI工具箱Tauri版-VideoClipMixingCut视频批量混剪

本教程基于自研的AI工具箱Tauri版进行VideoClipMixingCut视频批量混剪。 VideoClipMixingCut视频批量混剪 是自研AI工具箱Tauri版中的一款强大工具,专为自动化视频批量混剪设计。该模块通过将预设的解说文稿与视频素材进行自动拼接生成混剪视频,适合需要…

关于http的206状态码和416状态码的意义、断点续传以及CORS使用Access-Control-Allow-Origin来允许跨域请求

一、关于http的206状态码和416状态码的意义及断点续传 HTTP 2xx范围内的状态码表明客户端发送的请求已经被服务器接受并且被成功处理了,HTTP/1.1 206状态码表示客户端通过发送范围请求头Range抓取到了资源的部分数据,一般用来解决大文件下载问题,一般CDN…

小小扑克牌算法

1.定义一个扑克牌类Card: package democard; public class Card {public String suit;//表示花色public int rank;//表示牌点数Overridepublic String toString() {return "{"suit rank"}";}//实例方法,初始化牌的点数和花色public…

Xinstall助力App推广,下载自动绑定提升转化率

在App推广和运营的过程中,我们经常会遇到一些痛点。比如,用户下载App后需要手动进行一系列繁琐的操作才能完成注册和绑定,这不仅影响了用户体验,还降低了转化率。那么,有没有一种方法能够简化这个过程,提升…

Vue使用axios实现Ajax请求

1、什么是 axios 在实际开发过程中,浏览器通常需要和服务器端进行数据交互。而 Vue.js 并未提供与服务器端通信的接口。从 Vue.js 2.0 版本之后,官方推荐使用 axios 来实现 Ajax 请求。axios 是一个基于 promise 的 HTTP 客户端。 关于 promise 的介绍…

开源 AI 智能名片小程序:开启内容营销新境界

摘要:本文深入探讨了在当今数字化时代,内容营销的重要性以及如何实现让用户主动找你的最佳效果。通过引入开源 AI 智能名片小程序这一创新工具,阐述了其在明确目标用户群体、迎合用户需求痛点和打造风格特色方面的独特优势,为企业…

达梦数据库踩坑

提示:第一次接触达梦,是真的不好用,各种报错不提示详细信息,吐槽归吐槽,还是需要学习使用的。 前言 题主刚接触达梦数据库时,本来是想下载官网的连接工具进行数据库连接的,但是谁曾想&#xff…

sql中的union与union all区别

sql中的union与union all区别 1、 区别2、效率3、使用建议 💖The Begin💖点点关注,收藏不迷路💖 1、 区别 union: 功能:合并多个查询结果集,并自动去除重复行。特点:结果集中不包含重…

linux如何对c++进行内存分析

linux如何对c进行内存分析 背景分析方法以及原理原理分析结果以及重点关注 背景 在工作中,我遇到一个问题,需要将c写的进程部署到MCU上。由于MCU上可用的RAM 非常有限,所以在部署时就需要考虑到使用内存大小。所以为了搞清楚,内存…

计算机网络29——Linux基本命令vim,gcc编译命令

1、创建新用户 2、给用户设置密码 3、切换到新用户 切换到root用户 4、删除用户 5、查看ip 6、ping 查看物理上两台主机是否联通 7、netstatus 8、nslookup 查看网址的地址 9、负载均衡与容灾备份 负载均衡:指将负载(工作任务)进行平衡、分…

STM32如何修改外部晶振频率和主频

对于STM32F10x系列的单片机,除了STM32F10x_CL单片机,其它的单片机一般外部晶振HSE的时钟频率都默认是8MHz。如果我们使用的外部晶振为12Mhz,那么可以把上图绿色标记改为:12000000 72MHz的主频8MHz的外部晶振HSE*倍频系数9。当然如果像上面把外…

什么是HTTP DDOS,如何防护

在当今高度互联的网络世界中,网络安全威胁日益严峻,其中HTTP DDoS(Distributed Denial of Service,分布式拒绝服务)攻击作为一种常见的网络攻击手段,给企业和个人用户带来了巨大的挑战。今天我们就来详细介…

STM32与51单片机的区别:是否应该直接学习STM32?

STM32与51单片机的区别:是否应该直接学习STM32? 在单片机的世界里,STM32和51单片机都是非常重要的角色。对于初学者来说,是否可以直接跳过51单片机,直接学习STM32,这个问题一直存在争议。让我们深入探讨这…

Linux 文件权限详解与管理

文章目录 前言一、文件权限概述1. 权限表示格式2. 权限组合值 二、查看文件权限三、修改文件所有者与所属组1. 使用 chown 修改文件所有者2. 使用 chgrp 修改文件所属组3. 添加所有者 四、修改文件权限1. 符号方式2. 八进制方式3. 实际修改 总结 前言 在 Linux 系统中&#xf…

2024 新手指南:轻松掌握 Win10 的录屏操作

之前为了节约成本我们公司都采用录制软件操作都方式来为异地的同事进行远程操作培训的。所以我们尝试了不少的录屏工具,这里我就分享下win10怎么录屏的操作过程。 1.福昕录屏大师 链接:www.foxitsoftware.cn/REC/ 这款录屏工具是初学者的理想之选&…

网关登录校验(2)----网关如何将用户信息传递给微服务

1.微服务获取用户信息 现在,网关已经可以完成登录校验并获取登录用户身份信息。但是当网关将请求转发到微服务时,微服务又该如何获取用户身份呢? 由于网关发送请求到微服务依然采用的是Http请求,因此我们可以将用户信息以请求头…