网络编程-网络分层的意义

网络

  • 我们生活在一个网络无处不在的一个虚拟世界中,网络中的每一个设备都是一个节点。大多是我们的计算机,但是他还可以连接其他设备,例如打印机,路由器,网关,你的手机,智能家居等。我们可以使用java与计算机交互,每个网络节点都有自己的地址,这是唯一识别节点的一个字节序列。
  • 不同网络的地址信息会以不同方式分配,以太网(Ethernet)地址与物理以太网硬件相关。在硬件生产的时候,厂家就需要确保硬件地址与其他厂家的硬件地址不冲突。不过一个组织运行选择的地址由改组织的internet服务供应商ISP分配,ISP从四个区域Internet注册机构之一获得IP地址,而这四个机构的IP地址由互联网名称与数学地址分配机构分配,这其实就是IP地址。

网络分层

  • 通过网络发送数据指令是一个比较复杂的过程,我们发送出去的指令需要转成电信号,或者wifi,或者光纤中光信号,传输,之后还得在转回成我们发送出去的指令信息。这个过程必须咨询协调网络的物理特性以及所发送数据的逻辑特征。通过网络发送数据的软件必须了解如何避免数据包的冲突,将数字数据转为模拟信号,检查和修正错误,将数据包从一台主机路由到另外一台主机等。
  • 为了对应用开发人员和最终用户屏蔽这种复杂性,网络通信的不同方面被分解为多个层,每一层标识为物理硬件(即线缆和电流)与传输信息之间的不同抽象层次(相当于将字节信息与电信号光信号转换),每一层都只与紧挨着的上下层进行数据交互。将网络分层,这样就可以修改,替换某一层的软件,只要层与层之间的接口保持不变,就不会影响其他层。
  • 以下图显示网络中可能存在的一些协议栈。虽然现在的Internet上中间层现已相当稳定,但是上层,下层的协议变化还是比较大的,邮箱主机用Ethernet,有些是Wifi等,但是这并不影响其他层协议,因为他们都按规范实现统一的接口,每层都按规范实现,完成数据上的交互,这样分层模型实现了应用协议与网络硬件的物理特征,以及网络连接拓扑结构的解耦。

在这里插入图片描述

  • 分层模型还是有多种的,分别适合特定类型的网络,我们用最典型的Internet标准TCP/IP四层模型来讲解。如下图。
    在这里插入图片描述

  • 上图模型中,应用程序例如Chrom,FireFox,运行在应用层,只与传输层进行交互。传输层只与应用层,网际层交互,网际层只与主机网络层,传输层交互,绝不会跨层级交互。主机网络层通过电缆,光纤或者其他媒介将数据移动到远程系统的主机网络层,然后在通过上述各层将数据逐级上移传输到远程系统的应用层。

  • 拿Chrom浏览器来举例

    • 当浏览器输入网址,向Web服务器发送获取网页的请求时候,浏览器实际上只是与本地客户机器的传输层在对话。

    • 传输层将请求分解为TCP片,向数据添加序列号和校验号,然后将请求传递给本地网际层

    • 网际层根据本地网络所需的大小将TCP片分成IP数据报,并床底到主机网络层以便通过线缆或光线传输数据

    • 主机网络层将数字数据编码为适合特定物理介质的模拟信号(光,电)将请求发送到线缆,光纤,

    • 目标地址的远程系统的主机网络层可以由此读取请求。

    • 远程系统的主机网络层将模拟信号解码为数字数据,将生产的IO数据报床底给服务器的网际层

    • 网际层简单的检查IP数据报是否被破坏,如果已经分片则重组数据,然后传递给服务器传输层

    • 传输层检查是否所有数据都已到达,对于丢失或者破坏的部分则要求重传(在来一次以上过程,对应用层透明),此时当传输层接收到足够多的链接顺序数据报,就将其重组写入一个流,由服务器应用层上运行的Web服务器读取,

    • 服务器响应这个请求,在通过服务器系统的各个分层发回消息,通过Internet进行传输并发给web客户端。

主机网络层
  • 主机网络层处在最高的位置,他离java程序员最远的一个层级,在基于IP的internet标准参考模型中,网络中隐藏不是属于主机网络层(也称为数据链路层),主机网络层定义了特定的网络接口(以太网,WIFI等)如何通过物理连接向本地网络或者时间其他地方发送IP数据报,他由连接不同计算机的硬件(光纤,电缆,无线电)组成的部分有时称为网络的物理层,开发人员无需担心这一层除非网线断了,对开发人员透明。
网际层
  • 网络的下一次,这是开发需要考虑的第一层,在OSI模型中,网际层还称为网络层,定义了数据位和字节如何组织成为更大的分组,叫他包,还定义了寻址机制,不同计算机按照固定算法去查找对方。网际协议(IP)就是现在使用最广泛的网络层协议,也是java唯一理解的网络层协议。这个协议是两个:
    • IPV4,使用32位地址
    • IPV6,使用128位地址
  • IPV4,IPV6中,数据按包在网际层传输,这些包称为数据报datagram。每个IPV4数据报包含一个长度20~60字节的首部,以及一个包含65515字节的数据的有效荷载(payload)。实际上每个IPV4都比较小,从几十字节到8K字节不等,IPV6则包含更大的首部,数据可以达到4G字节
  • 下图展示各个部分IPV4数据报中是如何排列的,所有位和字节都采用big-endian方式,由左到右为高位到低位:
    在这里插入图片描述
  • 网际层除了路由与寻址,网际层第二个左右是支持不同类型主机网络层互相对话。Internet路由器会完成WIRI和Ethernet, Ethernet和DSL, DSL和光纤往返等协议直接的转换,如果没有网际层,或者类似的分层,子每个计算机只能与同一类网络上的其他计算机对话。
  • 网际层负责使用同构协议将异构网络相互连接
传输层
  • 因为原始数据报有一定缺陷。比如不保证可靠创术,即使能传送也可能被破坏。首部校验只能检测首部的破坏情况,而不能检测数据报中的数据部分。最后即使数据能够到大,不被破坏,也不一定是按照我们预定的顺序到大。各个数据报进过的路由过程完全不一样的,即使先发送也不一定先到。
  • 传输层(transport layer)负责确保各个包以发送顺序接受,并保证没有数据丢失或者被破坏,如果丢包,传输层请求重发。为实现这个目标,IP网络会给每个数据报添加一个附加首部,其中包含有更多信息。这一层协议有两个:
    • 传输控制协议(Transmission Control Protocol TCP),这个是一个开销高的协议,支持对丢失或者破坏的数据进行重传,并且按照发送的顺序进行传送
    • 用户数据报协议(User Datagram Protocol, UDP),允许接收方检测被破坏的包,但不保证这些包以正确的顺序床送(或者包有可能更本没有传送)
  • UDP比TCP快,TCP称为可靠的协议,UDP不可靠协议。
应用层
  • 这个才是程序员关注的关键部分,向用户传送数据的层称为应用层(application layer)。他下面的三层共同定义了数据如何从一台机器到另外一台机器。应用层确定了数据传输后的操作。例如,我们应用层协议HTTP可以确保Web浏览器将图像显示为图片,而不是一堆二进制数据。程序中有关网络的部分大多都是在应用层来实现的。应用层还有其他很多协议,主要取决于应用层具体作用:
    • 用于web的HTTP
    • 用于电子邮件的SMTP,POP,IMAP
    • 用于文件传输FTP,FSP, TFTP
    • 用于文件访问的NFS
HTTP,IP, TCP, UDP

下一篇 网络编程-TCP/IP协议栈

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

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

相关文章

网络编程-TCP/IP协议栈-IP协议

协议 协议就是约定的一种规则&#xff0c;例如扑克游戏中约定好的各种规则&#xff0c;2<3<4<5<…等&#xff0c;以此作为游戏规则。当所有人都遵循这个规则&#xff0c;那么久可以不需要任何多余的交流就可以进行游戏&#xff0c;这个方式形成的约定就是一种协议…

.NET项目升级手记:可为空引用

c# 8引入了新特性&#xff1a;“可为空引用”&#xff08;详情&#xff09;&#xff0c;这个功能个人觉得挺好的&#xff0c;能够非常明确的表现程序设计者的意图&#xff0c;编译器能够进行检查&#xff0c;尽最大可能减小NullReferenceException错误。如果是新项目&#xff0…

.NET与鲲鹏共展翅,昇腾九万里(一)

2019年1月7日&#xff0c;华为推出鲲鹏920处理器&#xff0c;便宣告了构建鲲鹏生态系统的开始。据官方介绍&#xff0c;鲲鹏是一个包含了鲲鹏计算单元、AI处理单元、智能管理、智能网卡的片上系统SoC&#xff0c;在此之上加上服务器操作系统&#xff0c;从而形成一个生态的闭环…

网络编程-TCP/IP协议栈-TCP协议

TCP协议 TCP协议作用 TCP协议位于协议栈的传输层。当应用层向TCP层发送用于网间传输的&#xff0c;用8字节表示的数据流&#xff0c;TCP则吧数据流分割成适当长度的报文段&#xff0c;最大传输段大小&#xff08;MSS&#xff09;通常受到改计算机连接的网络数据链路层的最大传…

互联网10年,激战如梦

— 1 —1969年&#xff0c;美国国防部研究计划署第一次将互联网应用于军事连接。随后美国西南部四所名校的四台计算机通过这项技术连接起来。谁也没想到&#xff0c;这项计划会对人类的命运产生如此重大影响。1993年&#xff0c;互联网真正诞生。美国白宫宣布开始提供「在线服务…

网络编程-TCP/IP协议栈-UDP/HTTP协议

UDP协议 UDP协议全称是用户数据报协议&#xff0c;在网络中她与TCP协议一样用于处理数据包&#xff0c;两个协议同处于协议栈的传输层&#xff0c;和TCP不同的是&#xff0c;UDP是一种无连接的协议栈。 因为UDP是无连接的&#xff0c;所以相对来说&#xff0c;UDP的报头比TCP要…

十问十答 Ms-PL 许可证

Microsoft 公共许可证&#xff08;The Microsoft Public License&#xff09;是微软为释出开源项目而编写和发布的自由开源软件许可证。如果你用 .NET 开发&#xff0c;你会经常碰见 Ms-PL。在微软的自由开源项目托管地 Codeplex&#xff08;已寿终正寝&#xff0c;微软已战略转…

网络编程-HTTPS协议的实现原理

HTTP传输协议缺点 之前几篇文章中详细讲解了TCP/IP协议栈中的几个协议&#xff0c;其中个就有对HTTP做了一个比较详细的讲解。HTTP是基于TCP进行传输的&#xff0c;其中传输的内容都是明文报文数据&#xff0c;如果我是一个黑客&#xff0c;我会想办法获取这个HTTP消息体&…

从案例角度解析建模平台动态规则引擎

源宝导读&#xff1a;明源云ERP建模平台提供了强大的页面联动规则引擎&#xff0c;原来需要编写代码完成的联动控制逻辑&#xff0c;现在只需要点点鼠标&#xff0c;通过配置完成。本文从实际案例的角度出发&#xff0c;介绍原始的代码逻辑如何转化为引擎规则的过程。一、背景明…

想基于K8s按需扩展应用程序,可从这几方面入手

马修赫瑟&#xff08;Matthew Heusser&#xff09;在花费了十年时间进行编程&#xff0c;测试和项目管理之后&#xff0c;Matt Heusser于2011年创立了自己的公司Excelon Development。该协会前董事会成员Matt还是软件测试人员&#xff0c;是德国波茨坦最具影响力的敏捷测试专业…

windows环境下ELK平台搭建

背景 日志系统主要包括系统日志&#xff0c;应用程序日志和安全日志。系统运维和开发人员可以通过日志了解服务器的软件&#xff0c;硬件信息&#xff0c;检查配置过程中的错误以及错误发生的原因。通常分析日志可以了解服务器的负荷&#xff0c;性能安全性&#xff0c;从而及时…

EntityFramework Core 3.x上下文构造函数可以注入实例呢?

今天讨论的话题来自一位微信好友遇到问题后请求我的帮助&#xff0c;当然他的意图并不是本文标题&#xff0c;只是我将其根本原因进行了一个概括&#xff0c;接下来我们一起来探索标题的问号最终的答案是怎样的呢&#xff1f;老规矩&#xff0c;首先我们定义如下上下文public c…

SpringCloud常见问题总结(一)

Eureka常见问题 Eureka注册服务慢 默认情况&#xff0c;服务注册到Eureka Server 的过程比较慢。在开发或者测试时候&#xff0c;如果能够加速注册的过程&#xff0c;从而提升工作效率。Spring Cloud官方文档详细描述了该问题的原因并提供了解决方案&#xff1a; //原文 Why…

[剑指offer]面试题21:包含min函数的栈

面试题21&#xff1a;包含min函数的栈 题目&#xff1a;定义栈的数据结构&#xff0c;请在该类型中实现一个能够得到栈的最小元素的min函数。在该栈中&#xff0c;调用min、push及pop的时间复杂度都是O&#xff08;1&#xff09;。 栈内压入3、4、2、1之后接连两次弹出栈顶数字…

IO 模型知多少

1. 引言同步异步I/O&#xff0c;阻塞非阻塞I/O是程序员老生常谈的话题了&#xff0c;也是自己一直以来懵懵懂懂的一个话题。比如&#xff1a;何为同步异步&#xff1f;何为阻塞与非阻塞&#xff1f;二者的区别在哪里&#xff1f;阻塞在何处&#xff1f;为什么会有多种IO模型&am…

[剑指offer]面试题22:栈的压入、弹出序列

面试题22&#xff1a;栈的压入、弹出序列 题目&#xff1a;输入两个整数序列&#xff0c;第一个序列表示栈的压入顺序&#xff0c;请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如序列1、2、3、4、5 是某栈的压栈序列&#xff0c;序列4、5、3、2、1…

Ubuntu上安装使用Docker

Docker简介 Docker是一个开源的容器引擎&#xff0c;他有助于更快的交付应用。Docker可以将应用程序和基础设施层做隔离&#xff0c;并且能将基础设施当做程序一样进行管理。使用Docker&#xff0c;可以更快的打包&#xff0c;测试以及部署应用程序&#xff0c;并且可以缩短从…

让 .NET 轻松构建中间件模式代码

让 .NET 轻松构建中间件模式代码Intro在 asp.net core 中中间件的设计令人叹为观止&#xff0c;如此高大上的设计何不集成到自己的代码里呢。于是就有了封装了一个简单通用的中间件模板的想法&#xff0c;以后有需要的时候就可以拿来即用。接口定义这里按执行的委托是同步还是异…

[剑指offer]面试题26:复杂链表的复制

面试题26&#xff1a;复杂链表的复制 题目&#xff1a;请实现函数ComplexListNodeClone&#xff08;ComplexListNodepHead&#xff09;&#xff0c;复制一个复杂链表。在复杂链表中&#xff0c;每个结点除了有一个m_pNext指针指向下一个结点外&#xff0c;还有一个m_pSibling 指…

SpringCloud + Docker

Dockerfile构建Docker 镜像 注意这里说的Dockerfile是指的一个文本文件&#xff0c;类似txt&#xff0c;只不过名字是Dockerfile&#xff0c;里面编辑Docker的一些指令&#xff0c;指令作用在于描述构建镜像的细节。如下一个简单的案例&#xff0c;用上一节中下载的nginx镜像来…