【JavaEE初阶】网络原理|认识协议|协议分层|TCP/IP模型|封装和分用

一、认识协议

1.概念

简单来说:就是一种通信双方,对于通信规则的约定(标准),一定是通信双方都认可

但是这个协议不一定是认可面非常广的,即使是两个人之间的也可叫做协议

就好⽐⻅⽹友,彼此协商胸⼝插⽀玫瑰花⻅⾯,这就是⼀种提前的约定,也可以称之为协议

2.作用(为什么需要协议?)

两个用来通信的主机设备有着不同的硬件,不同的操作系统,不同的应用程序,有了协议,即使上述内容不同,通信也能正常进行

进行网络通信的时候,通信协议是非常关键的环节


二、协议分层

1.为什么需要⽹络协议的分层?

网络通信是一个非常复杂的事情,这个过程涉及到很多细节问题

如果你使用一个协议来约定上述所以的细节,这个协议就会非常的庞大,非常的复杂

——>拆分:为了管理复杂程度,不要让这个东西太复杂,每个部分负责一个功能

这样一个功能复杂的协议,就拆分成多个功能更单一的协议了

但是拆出来的协议太多了,就要对这个协议进行分类,甚至要“分层”

2. 协议分层是什么

协议分层:把很多的协议,按照功能分成不同的层级,每个层级都有对应的主线任务(目标/要解决的问题),上层协议会调用下层协议的功能,下层协议会给上次协议提供服务

注意:不能“越级调用”

3.分层带来的好处

好处主要有两个方面:

(1)封装的效果:某层协议,不必知道其他层协议的细节,降低学习使用成本

eg:只要会说汉语,不需要理解电话的工作原理,就能打电话;

        设计电话的人,可能是老外,不必懂汉语,也不妨碍他设计开发电话

(2)任意层次的协议,都是可以灵活替换的(也就是解耦合),这样就给整个网络体系,升级迭代,带来了很大的便利

eg:将电话机协议改为无线电协议:站在使用者的角度,完全感知不到任何的区别,电话该咋打还是咋打;

        将汉语协议改为英语协议:虽然语言变了,电话这一层,没有任何影响,设计电话的人不需要针对“英语”做任何的改变和特殊处理


当前网络的现状,就是有很多的协议,这些协议就是按照一定的分层规则组织起来的,业内普遍的分层方式有两种:

(1)OSI七层模型

只是存在于教科书上,实际客观世界中并不存在,因为它搞得有点复杂(这里就不作介绍了)

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

可以认为是OSI的简化版本,就是真实世界采取的网络分成模型,目前接触到的网络,大部分都是TCP/IP模型的(电脑上网),当然,也有不是的,eg:4G/5G通信,就是一套专门的模型协议(手机流量上网)

三、TCP/IP五层(或四层)模型

(1)物理层

硬件层面上的相关约定,网线,网口

eg:金工实习,8根铜线穿到一起,接上水晶头,这样的一些接线规则

下面(2)(3)(4)以快递为例介绍 

(2)数据链路层

关注的是通信过程中,两个相邻节点之间的通信

eg:快递具体运输的,这是快递员自行进行确定的

例如,当前路线:
上海 -> 苏州 -> 南京 -> 西安
上海 -> 苏州大卡车 就运过去,有一个开着打开车的快递小哥
苏州 ->南京轮船,沿着长江,一路逆流而上,有一个开着船的快递小哥,
南京 ->西安 铁路 装上火车
西安 ->我家门口 电三轮

每个节点之间的运输方式,就相当于数据链路层

(3)网络层

关注的是通信中,通信路径的规划,规划出的路径就决定了,数据要经过哪些节点“点到点的传输

eg:商家发货,就会把快递交给快递小哥,就会拿到快递公司,
快递公司,就会对这些包衷,进行分拣~~根据快递的目的地,分配到不同的运输线路上
发货地点是在 上海.如果收件地点是在西安
上海 -> 南京 ->西安
上海 -> 无锡 ->西安
上海 -> 徐州 ->西安
快递公司,就会把路线规划好,包裏就会按照这样的既定路线进行传输

(4)传输层

关注的是通信双方的“起点”和“终点”,“端到端的传输

eg:我和商家,我们俩只关注,发件人信息,和收件人信息(也就相当于起点和终点)

(5)应用层

和具体应用程序直接相关,传输的数据是干啥用的,如何用的,有啥意义

eg:我在淘宝上还是买了个东西,买了个床刷子~~
我拿着这个床刷子要干啥~~ 就是我需要关心的, 快递公司/商家,都是不关心的~~当我拿到刷子之后,用来刷床,还是用来刷沙发, 还是用来打儿子~~就是我自己来决定了~

 也有人把上述通信协议分层的模型,称为TCP/IP四层(没算物理层)

站在程序员的角度,物理层是纯硬件,其余的四层还是软件

但是物理层又和数据链路层联系紧密,所以有时也算五层

对于OSI模型:只是将TCP/IP模型中的应用层细分为应用层+表示层+会话层 

上图中:网络层==互联网层 ;数据链路层==网卡层;物理层==(硬件)只是名称不同而已

关注上图的侧面:分别涉及应用程序,操作系统(内核),设备驱动程序与网络接口

对于Java程序员,重点关注应用层+传输层(应用层是需要调用传输层提供的接口(api)来进行一些功能实现的),这些和日常开发息息相关,其他层简单了解即可


笔试题(选择题):

路由器是工作在上述协议中的哪一层

交换机是工作在上述协议中的哪一层

如果出现:这里的”路由器"和”交换机“就是"经典的路由器交换机"(课本上的)

路由器就是工作在网络层(三层转发)

交换机就是工作在数据链路层(二层转发) (稍后详细介绍)

但是真实的情况:现在的路由器和交换机功能越来越多,界限越来越模糊

eg:有些路由器/交换机可以工作在应用层,你通过wx发个信息,路由器/交换机就能感知到,你发的这个信息内容是啥(信息内容,属于应用层的范畴)


四、封装和分用(协议的层和层之间是如何配合工作的?)

上层协议调用下层协议,下层协议给上层协议提供服务

下面以A通过QQ给B发送hello为例分别介绍封装和分用

首先QQ里面就会有一个应用层网络协议,这个协议约定了数据按照什么样的格式来组织

这种数据的格式:本质上是(二进制的)字符串(更准确的说是二进制的bit流),因此要传输的发送人,接收人,消息时间,消息内容...就要组织到一个字符串中,组织的时候要按照一定的格式来

不同的协议,数据组织的格式是不同的

序列化和反序列化

序列化:把结构化数据(包含很多属性,很多字段) ——>字符串/二进制字符串

反序列化: 把字符串/二进制字符串——>结构化数据

发送和接收的过程中就进行了一个序列化和反序列化

1.封装(和Java面向对象的封装,不是一个封装)

A的在聊天窗口里,输入hello,点击发送,那么QQ应用程序就要负责实现上述逻辑,而这些逻辑都要通过网络来传输

(1)QQ应用程序首先就会把上述要传递的内容,组织成“应用层数据包”

假设QQ的应用层协议是这样的:发送人的qq号,接收人的qq号,发送时间,消息正文\n

(2)应用层数据包已经有了,QQ程序就要调用系统的api来进行传输

QQ 程序,就要调用系统的 api, 来进行传输.

应用层接下来要把数据交给,传输层.

怎么交给传输层?传输层(操作系统内核) 提供了 api,让应用程序去调用.

调用这样的 api, 就会把刚才的应用层数据交给传输层.(进入到系统内核了),称为 socket api

传输层拿到应用层数据包之后,就会把这个数据包进行进一步的封装,构造成 传输层数据包在传输层

典型协议有两个,TCP,UDP

此处假设使用 UDP 来作为传输层协议

整个是UDP数据包,前面是UDP报头,后面是UDP数据包的载荷(payload)

报头里放着一些UDP相关的属性(比如发件人和收件人的端口号就在UDP报头中)

传输层 构造好数据包之后,就会继续把数据包,交给网络层,(传输层会调用网络层提供的 api,这个调用的过程
都是系统内核,自行负责了,咱们程序员感知不到

(3)网络层 典型的协议IP协议

整个是IP数据包,前面是IP数据包的报头,后面是IP数据包的载荷(IP协议不关心后面的载荷里头是啥,只关心IP报头里的数据)

IP报头中就包含收件人的IP地址和发件人的IP地址

又进一步的调用数据链路层的 api, 把上述 IP 数据包,交给数据链路层的协议.

同样也是系统内核负责完成的.程序员感知不到了,

这里的 api 往往是 网卡 的驱动程序提供的.

硬件厂商,发布硬件的时候,提供配套的软件(驱动程序)通过驱动程序,可以让操作系统实现对硬件的精细控制

(4)数据链路层 典型协议 以太网

以太在物理中是光在真空中传输的介质,此处传输网络数据,也需要介质所以引入这个词

电脑, 通过有线网, 传输数据, 走的就是"以太网"协议~~

咱们电脑上插的网线,也叫做"以太网线

以太网,也有自己的数据包格式,就会拿到上述 IP 数据包,进一步的封装

上述数据已经进入到网卡驱动中了,接下来就是要真正的发送出去了 

(5)物理层:上述的以太网数据帧,本质上还是0101二进制数据

硬件设备,要把上述的二进制数据,转为光信号/电信号/电磁波才会真正的进行发射

上述层层包装数据,不停的加数据报头的过程,称为”封装“ ,类似包装快递

2.分用

上述数据,并非直接到达B,而是要先到和A连接的交换机/路由器,数据经过交换机/路由器的一系列转发之后,最终到达B

当数据到达B之后,又要做哪些事情呢? 就是上述过程的“逆过程”(拆快递)

(1)物理层

收到一系列光电信号,把这些信号转为0101二进制数据,交给数据链路层

(2)数据链路层

按照以太网协议,对数据进行解析(解析报头中的关键信息,为后续的传输/转发打下基础,还需要拿到载荷数据)

解析出来的载荷数据,是要交给上层(网络层)

(3)网络层 IP协议

IP协议拿到IP数据包,按照协议格式进一步解析,解析报头中的关键信息,取出载荷

把载荷再进一步交给上层(传输层)

(4)传输层  UDP

拿着UDP数据包,按照UDP格式进一步解析,解析出关键的信息(要交给哪个端口号对应的进程),以及解析成载荷数据

 

再把载荷交给对应的应用程序

(5)应用层

QQ程序拿到了应用数据包

QQ按照自己的协议格式,进行解析,拿到这里的结构化数据(反序列化),显示到界面上

这个过程就是分用,就相当于拆快递


中间的路由器,交换机,也要进行封装分用,也是上述的过程

只不过,交换机,封装分用到数据链路层,即可知道下一步如何转发(工作在数据链路层

路由器,封装分用到,网络层,即可知道下一步如何转发(工作在网络层

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Docker搭建项目管理软件禅道

文章目录 一、简介二、部署三、使用 一、简介 禅道是以项目管理为核心的协作平台,旨在帮助团队高效地进行项目管理和协作。 禅道提供了项目管理、任务管理、团队协作、文档管理、报告统计等功能。 禅道官网 二、部署 操作系统:22.04.4 创建文件夹 …

Linux驱动开发——(三)并发与竞争

目录 一、并发与竞争简介 二、原子操作 2.1 原子操作简介 2.2 原子整形操作API 2.3 原子位操作API 2.4 原子操作驱动代码 三、自旋锁 3.1 自旋锁简介 3.2 自旋锁API 3.3 自旋锁驱动代码 四、信号量 4.1 信号量简介 4.2 信号量API 4.3 信号量驱动代码 一、并发与…

Redis-cluster集群架构

一、集群架构 上述集群架构师一个由多个主从节点群组成的分布式服务器,具有复制、高可用和分片的特性。Redis集群不需要sentine哨兵也能完成节点移除和故障转移。官方文档称可以扩展上万个节点。推荐不超过1000个;从节点只担任备份的角色,不承…

JavaWeb过滤器

Javaweb过滤器是一种用于在Servlet处理请求之前或之后对请求进行预处理或后处理的组件。过滤器可以用于拦截请求、修改请求参数、过滤响应内容等操作。其主要作用包括: 拦截请求:过滤器可以拦截客户端请求,对请求进行验证、过滤或修改&#x…

STL-list的使用及其模拟实现

在C标准库中,list 是一个双向链表容器,用于存储一系列元素。与 vector 和 deque 等容器不同,list 使用带头双向循环链表的数据结构来组织元素,因此list插入删除的效率非常高。 list的使用 list的构造函数 list迭代器 list的成员函…

【Interconnection Networks 互连网络】Dragonfly Topology 蜻蜓网络拓扑

蜻蜓拓扑 Dragonfly Topology 1. 拓扑参数2. Topology Description 拓扑描述3. Topology Variations 拓扑变体 蜻蜓拓扑 Dragonfly Topology 1. 拓扑参数 Dragonfly拓扑参数: N N N: 网络中终端(terminal)的总数量 p p p: 连接到每个路由器的终端数量 a a a: 每…

Go语言并发控制

channel // cancelFn 数据通道关闭通知退出 func cancelFn(dataChan chan int) {for {select {case val, ok : <-dataChan:// 关闭data通道时&#xff0c;通知退出// 一个可选是判断data指定值时退出if !ok {fmt.Printf("Channel closed &#xff01;&#xff01;&…

Rest接口/Nginx日志记录和采集

文章目录 一、Rest接口日志二、Nginx日志三、采集日志四、夜莺查看Nginx日志五、夜莺查看Rest接口日志 一、Rest接口日志 记录日志字典定义 接口URL接口名称,类别,入参全记录,出参全记录,入参字段1:中文名1/入参字段2:中文名2,出参字段1:中文名1/test/api/login账户登录,登录…

java-单列集合List详解

一、List概述 ​​​​​​​List 接口继承自 Collection 接口。这意味着所有 List 类型的对象都是 Collection 类型的对象&#xff0c;它们共享 Collection 接口中定义的所有方法。 List集合的特点&#xff1a; 1、有序&#xff1a;存和取得元素顺序一致 2、有索引&#xf…

Java- Object根父类

在java中&#xff0c;所有的类都有一个公共的父类&#xff0c;这个java.lang.Object类 * * * Object所有类的根&#xff0c;成为超类。 1.证明Object是根 public class A_Object01 {public static void main(String[] args) {//证明Object是根//基本数据类型int a 0;Object…

【硬十宝典】——1.4【基础知识】电源完整性——理解与设计

定义&#xff1a; 电源完整性&#xff08;Power integrity&#xff09;简称PI&#xff0c;是确认电源来源及目的端的电压及电流是否符合需求。 电源完整性在现今的电子产品中相当重要。有几个有关电源完整性的层面&#xff1a;芯片层面、芯片封装层面、电路板层面及系统层面。…

18-Echarts 配置系列之:数据集 dataset

简介&#xff1a; 数据集&#xff08;dataset&#xff09;是专门用来管理数据的组件。简化在每一个系列中设置数据&#xff0c;这一个配置是在Echarts4 中开始支持。 通过数据集配置&#xff0c;避免为每一个系列创建一个数据&#xff0c;避免格式转化的痛苦。 简单举例&…

开启智慧之旅,AI与机器学习驱动的微服务设计模式探索

​&#x1f308; 个人主页&#xff1a;danci_ &#x1f525; 系列专栏&#xff1a;《设计模式》 &#x1f4aa;&#x1f3fb; 制定明确可量化的目标&#xff0c;坚持默默的做事。 &#x1f680; 转载自热榜文章&#x1f525;&#xff1a;探索设计模式的魅力&#xff1a;开启智慧…

2024年腾讯云免费服务器最新申请入口链接

腾讯云免费服务器申请入口 txybk.com/go/free 免费服务器可选轻量应用服务器和云服务器CVM&#xff0c;轻量配置可选2核2G3M、2核8G7M和4核8G12M&#xff0c;CVM云服务器可选2核2G3M和2核4G3M配置&#xff0c;腾讯云百科txybk.com分享2024年最新腾讯云免费服务器申请入口、限制…

YOLOv8操作指南-下载+配置环境

下载&#xff1a;github&#xff0c;进入搜索YOLOv8 就这个&#xff0c;点开 下载就可以了&#xff0c;然后解压一下 配置环境&#xff1a; 安装Pytorch 先看一下这个&#xff1a; 如果电脑有GPU的话&#xff1a; 判断自己电脑GPU&#xff1a;打开任务管理器 我的是英伟达3…

sherpa + ncnn 离线语音识别

目录结构 前言音视频格式转为wavsherpa-ncnn编译LinuxWindowswindows编译中遇到的问题问题“nmake -? failed with: no such file or directory”编译失败原因 成功编译截图 可执行程序说明模型下载语言识别测试LinuxWindows 参考文献 前言 小编需要实现离线音视频语言部分识…

vulfocus靶场couchdb 权限绕过 (CVE-2017-12635)

Apache CouchDB是一个开源数据库&#xff0c;专注于易用性和成为"完全拥抱web的数据库"。它是一个使用JSON作为存储格式&#xff0c;JavaScript作为查询语言&#xff0c;MapReduce和HTTP作为API的NoSQL数据库。应用广泛&#xff0c;如BBC用在其动态内容展示平台&…

完结撒花! java算法day60 | 84.柱状图中最大的矩形

84.柱状图中最大的矩形 思路&#xff1a; 这道题和接雨水很像&#xff0c;不过有两点差别&#xff1a; 这道题需要找到一个位置前一个比他小的数和后一个比他小的数&#xff0c;而接雨水是找到前一个和后一个比他大的数。需要在原数组前后各补上0&#xff0c;防止忽略一些边缘…

Excel数据处理:高级筛选、查找定位、查找函数(VLOOKUP)

高级筛选 先去选中筛选区域 如果筛选的条件在同一行那么就是且的关系 如果筛选的条件不在同一行那么就是或的关系 查找定位空值 使用VLOOKUP函数

C语言中, 文件包含处理,#include< > 与 #include ““的区别

文件包含处理 指一个源文件可以将另外一个文件的全部内容包含进来 &#xff23;语言提供了#include命令用来实现文件包含的操作 #include< > 与 #include ""的区别 <> 表示系统直接按系统指定的目录检索 "" 表示系统先在 "" 指定…