网络封装分用

news/2024/9/19 8:50:41 标签: 网络, 服务器, java-ee

目录

1,交换机

2,IP

3,接口号

4,协议

分层协议的好处:

5,OSI七层网络模型.

6,TCP/IP五层网络模型(主流):

[站在发送方视角]

[接收方视角]


1,交换机

交换机和IP没有关系,相当于是对路由器接口的扩充,这时相当于主机都与路由器相连处于局域网中,把越来越多的路由器连接起来成一个非常复杂的网络,称为广域网(万维网就是指将世界上的所有路由器连接到一起)

2013年,移动互联网全面普及,"应用市场"的出现,可以将主机上的功能进行扩充

单机->局域网->广域网->移动互联网

2,IP

IP:描述了一台主机在互联网中所处的地址,用一个32为的整数来表示,使用"点分十进制"(方便人们阅读)这样的方式来描述IP

3,接口号

接口号:区分当前主机指定的应用程序(进程),一个主机上,使用网络的程序有很多,通过端口号进行区分,从而表示当前主机收到的信息是交给那个进程使用.接口号是一个两个字节的整数(0->65535),0->1023是有特殊的含义的,所以我们日常程序开发的时候,一般使用剩下的接口号

4,协议

协议:就是在约定通信双方,交互数据的规则.协议是一切通信的基础,通信至少有两个主机,发送方的数据需要让接收方可以读懂,也就是双方按照相同的规则来构造/解析数据.此时我们就将网络通信问题转换成如何使用通信协议的问题

网络上传输数据,一般是以光信号/电信号/电磁波...二进制数据.由于网络通信非常负责,如果使用协议就会使协议非常庞大,复杂.,所以对对协议进行拆分,让每个小协议专注解决一个/一类问题.协议布局:约定好协议之间不能随意交互,但是但是相邻的层之间可以相互交互,上层协议可以调用下层协议,下层协议给上层协议提供服务.我们称之为协议栈.

分层协议的好处:

1),降低了使用成本,使用某个协议不需要关注关注其他协议的实现.

2),降低了整个体系的耦合性,可以灵活的变更某个层次的协议

5,OSI七层网络模型.

6,TCP/IP五层网络模型(主流):

(用户)应用层(应用系统):

     ↓   传输层(操作系统):关注网络通信中的起点和终点,并不关心其中的细节

     ↓   网络层(操作系统):网络通信的路径规划"路由选择".负责地址管理

     ↓   数据链路层(硬件):在针对上述规划好的路径,进行具体实施

(硬件)物理层(硬件):描述的是硬件设备(网络这样的设备)需要满足的条件

驱动程序:操作系统和硬件通信,管理硬件,使用的软件程序(一般是由硬件厂商提供)

• 对于⼀台主机,它的操作系统内核实现了从传输层到物理层的内容,也即是TCP/IP五层模型的下四 层;

• 对于⼀台路由器,它实现了从⽹络层到物理层,也即是TCP/IP五层模型的下三层;

• 对于⼀台交换机,它实现了从数据链路层到物理层,也即是TCP/IP五层模型的下两层;

• 对于集线器,它只实现了物理层;

上述只是站在经典模型上来讨论的,但是现实是,交换机,也可能是工作在网络层,甚至是传输层/应用层

路由器,也有可能是工作在数据链路层,也有可能是传输层,也有可能是应用层

数据在网络通信的整体流程:分装和分用

[站在发送方视角]

1,用户在文本框中输入"hello"字样,然后点击发送,程序就会把这个数据从输入框读取到,构造成一个"应用层数据包".应用层网络协议就描述了这个数据包的构造,此处的应用层协议往往是程序员自行定义的.

进行网络传输数据,通常要把"结构化的数据"转化成一个"二进制字符串",这个过程称之为序列化,把二进制字符串转化成结构化数据这个过程称之为反序列化

举例:

应用层数据包:数据包格式:发送者;接受者;时间;内容\n

2,应用程序,就会调用操作系统提供的API(传输层给应用层通过API)

操作系统会提供一个类似于"发送数据"这样的的API,然后应用层会将上述准备好的应用层数据包作为参数传进来,于是应用层数据包就到了系统内核里进入到传输层的代码层面,到达传输层层面就会把上述应用层数据包再次封装成一个传输层数据包(传输层有诸多协议,但主要的是TCP和UDP)具体使用那种,看的是在应用层方面使用的是那种API就是使用的那种协议(不同的协议提供的API是不相同的)(计算机网络中的封装实际上就是字符串的拼接)

传输层数据包(这里假设使用的是UDP协议):

这时UDP报头里面就包含了UDP的相关信息,比如发送者的端口号和接受者的端口号...

3,传输层构造成数据之后,就会继续使用网络层是API进一步把数据交给网络层,网络层也有诸多协议,其中最主要的就是IPv4协议,简称(IP协议),IP协议就会把上述拿到的传输层数据包构造成网络层数据包

网络层数据包:

此时IP报头里面包含了很多信息,主要是发送方的IP地址,和接收方的IP地址

4,网络层继续调用数据链路层的API,把数据交给数据链路层处理,数据链路层的常见协议是以太网协议

网络传输数据的基本单位:1,数据包,2数据报3,数据段4,数据帧>>>这几个术语之间是有差别的,但是在日常交流中不会过分去区分

5,上述得到的数据,需要进一步交给物理层(硬件设备)网卡会针对上述的二进制数据,进行真正的传输操作,就需要将上述的00101这样的信号转换成光信号/电信号/电磁波...

[接收方视角]

1,接收方接受的是光信号/电信号,把这样的信号还原成10101这样的二进制字符串数据.

2,物理层转换回来的数据,会交给数据链路层,以太网拿到这个数据包,就会对这个数据包进行分析,拿出这里的报头和荷载,根据报头的信息决定这个数据包是丢弃还是转发,还是自己保留(将载荷交给上层协议)

3,网络层拿到解析好的数据包,然后根据IP协议,对这个数据包进行解析,取出IP报头和荷载,根据报头的信息进行处理(丢弃/转发/保留[交给上层协议])

4,传输层UDP协议也要针对数据进行解析,取出UDP报头和载荷,此处也需要将载荷交给应用层协议

5,数据就到了应用程序这里,这时程序就会针对数据进行"反序列化",针对这里的数据就要进行下一步逻辑(显示到屏幕上或者声音提醒)

两台主机之间往往不仅只有一根网线,而是有诸多的交换机和路由器连接完成数据的转发的

中间的交换机和路由器都涉及到了封装和分用,交换机的分装和分用到了数据链路层,就可以决定数据是丢弃还是继续进行转发,不用再继续进行分用

路由器是分装分用到了网络层,就可以决定数据是否丢弃还是继续转发了,不用在继续进行分用


http://www.niftyadmin.cn/n/5665283.html

相关文章

SAP HANA 高性能内存计算平台 - 简述

一、概念 SAP HANA是一个高性能的内存计算平台,它通过一系列的创新技术来实现其高速数据处理和实时分析的能力。以下是SAP HANA实现原理的几个关键方面: 内存计算:SAP HANA将所有数据存储在内存中,而不是传统的基于磁盘的存储。这…

硬件看门狗导致MCU启动时间慢

最近,在项目交付过程中,我们遇到了一个有趣的问题,与大家分享一下。 客户的需求是:在KL15电压上电后,MCU需要在200ms内发送出第一包CAN报文数据。然而,实际测试结果显示,软件需要360ms才能发送…

解密与推广IAB/MRC零售媒体测量指南

微软零售媒体(由 PromoteIQ 提供支持)如何帮助零售商和广告商遵守数据透明性、准确性、隐私和安全性。 近年来,零售媒体发展迅猛。根据eMarketer的预测,仅在美国,到2024年零售媒体广告支出将达到600亿美元&#xff0c…

Java入门第02篇之数据库操作相关

目录 前言 一、JPA是什么? 二、使用步骤 1.开发环境说明 2.引入依赖 3.配置数据库连接 4.实体类 5.仓储类 6.多个字段组合查询 7.数据更新 8.服务类 9.其他注意 三、总结 前言 项目上最近遇到了需要数据同步的地方,已有项目代码是Java开发…

neo4j:ubuntu环境下的安装与使用

一、neo4j安装 1. 下载安装包 进入网站:https://neo4j.com/deployment-center/#community 在上图中选择下载即可(社区版免费) 注意:neo4j的版本要和电脑安装的jdk版本对应,jdk版本使用java --version查看:…

“更上几层楼”的编程软件

在日益繁忙的工作环境中,选择合适的编程工具已成为提升开发者工作效率的关键。不同的工具能够帮助我们简化代码编写、自动化任务、提升调试速度,甚至让团队协作更加顺畅。那么,哪款编程工具让你的工作效率翻倍?是智能的代码编辑器…

代理模式---静态代理和动态代理

代理模式 代理模式:给某一个对象提供一个代理,并由代理对象来控制对真实对象的访问。代理模式是一种结构型设计模式。 代理模式角色分为 3 种: Subject(抽象主题角色):定义代理类和真实主题的公共对外方法…

2024短剧系统开发,付费短剧小程序app源码教程,分销功能讲解搭建上线

短剧系统技术栈 前端:vue3uniapp 后端: php 数据库:mysql 服务器环境: centos7.6 宝塔 php7.4 MySQL5.7 一、短剧系统功能 短剧用户端: 小程序、抖音小程序、快手小程序、APP、 z付宝小程序 系统用户端详细功能&…