《计算机网络》——应用层

2.1 应用层协议原理(P54)

研发网络应用的核心是写出能够运行在不同端系统和通过网络彼此交流的程序。

2.1.1 网络应用程序体系结构

两种主流的应用体系结构:客户-服务器体系结构、对等体系结构。

客户-服务器体系:服务器是一个总是打开的主机,它为称为客户的主机提供服务。服务器具有固定的、周知的IP地址。服务器往往有数据中心构成。最典型的例子是web应用。

P2P体系:应用程序在主机对之间直接通信。P2P体系结构具有自扩展性,每个对等方在享受服务的同时也为系统提供服务能力。

2.1.2 进程通信

2.1.2.1 客户和服务器进程

网络应用程序由成对的进程组成,这些进程通过网络相互发送报文。对每对通信的进程,通常将两个进程之一称为“客户”,另一个进程称为“服务器”。在P2P体系中,下载文件的进程称为“客户”,上传文件的称为“服务器”。

2.1.2.2 进程与计算机网络之间的接口

进程通过称为套接字的软件接口向网络发送报文和从网络接收报文。

套接字是主机内应用层与运输层之间的接口。

2.1.2.3 进程寻址

IP地址是一个能唯一标识主机的32比特的量。

发送进程必须指定运行在主机上的接收进程。

2.1.3 可供应用程序使用的运输服务

应用程序的服务要求大体有4类:可靠数据传输、吞吐量、定时和安全性。

可靠数据传输:将数据正确、完整地从一端传输到另一端。邮件、文件传输等需要可靠数据传输,多媒体应用一般不需要。

吞吐量:在波动的网络中保证吞吐量。

定时:控制发送方到接收方地延迟。

安全性

2.1.4 因特网提供地运输服务

因特网为应用程序提供了两个运输层协议:UDP、TCP。

2.1.4.1 TCP服务

TCP服务包括面向连接服务和可靠数据传输服务。

面向连接服务:在报文开始传输之前,TCP让客户和服务器交换运输层控制信息,称为“握手”。然后两个进程的套接字之间就建立了TCP联系。连接双方可以同时进行收发报文。应用程序结束报文发送后,TCP连接必须拆除。

可靠的数据传输服务:无差错、无冗余。

TCP协议还具有拥塞控制机制,当发送方和接收方之间出现网络拥塞时,TCP会抑制发送进程。

2.1.4.2 UDP服务

UCP服务仅提供最小服务,没有握手过程、不保证报文能送达接收进程、报文可能乱序到达、没有拥塞控制机制。

2.1.4.3 因特网运输协议所不提供的服务

因特网运输协议不保证吞吐量和定时。

2.1.5 应用层协议

应用层协议定义了运行在不同端系统上的应用程序进程如何相互传递报文。
应用层协议定义了:

  1. 交换报文的类型(请求报文or响应报文)
  2. 交换报文类型的语法
  3. 字段的语意
  4. 确定一个进程何时、如何发送报文、如何对报文进行响应的规则。

2.2 Web和HTTP(P64)

2.2.1 HTTP概况

Web的应用协议是超文本传输协议(HTTP)。HTTP由一个客户程序和一个服务器程序组成,HTTP定义了报文的结构和交换报文的方式。

Web页面是由对象组成的。一个对象只是一个文件,如一个HTML文件、一个JPEG图形等,且它们可通过一个URL地址寻址。多数Web界面含有一个HTML基本文件和几个引用对象,HTML基本文件通过对象的URL地址引用页面中的其他对象。每个URL地址由两部分组成:存放对象的服务器主机名、对象的路径名(例如,http://www.someSchool.edu/someDepartment/picture.gif中,www.someSchool为主机名,/someDepartment/picture.gif为路径名)。

HTTP定义了Web客户向Web服务器请求Web页面的方式,以及服务器向客户传送Web页面的方式。
在这里插入图片描述
HTTP使用TCP作为它的支撑运输协议。HTTP客户首先发起一个与服务器的TCP连接,连接建立后,客户和服务器就可以通过自己的套接字发送和接受报文。

HTTP服务器不保存关于客户的任何信息,是一个无状态协议

2.2.2 非持续连接和持续连接

在许多因特网应用程序中,客户和服务器在一个相当长的时间内保持通信,客户在此期间会对服务器发出一系列请求。如果每个请求是经一个单独的TCP连接发送,则该应用程序称为使用非连续连接,如果所有请求经同一个TCP连接发送,称为持续连接

HTTP技能使用非持续连接也能使用持续连接,默认使用持续连接。

2.2.2.1 采用非持续连接的HTTP

在这里插入图片描述
在非持续连接中,每个TCP连接在服务器发送一个对象后关闭,每个TCP连接只传输一个请求报文和一个响应报文。

在这里插入图片描述
定义RRT(Round-Trip Time)为一个短分组从客户到服务器然后再返回客户所花费的时间。如上图所示,浏览器与服务器建立TCP连接涉及一次“三次握手”过程,即客户向服务器发送一个小TCP报文段,服务器用一个小TCP报文段做出确认和响应,最后客户向服务器返回确认。“三次握手”的前两次握手消耗了一个RRT时间,客户结合第三次握手向TCP连接发送一个HTTP请求报文,请求报文到达服务器后,服务器在该TCP连接上发送HTML文件。所以,总的响应时间为两个RRT时间加上服务器传输HTML文件的时间。

2.2.2.2 采用持续连接的HTTP

非持续连接有一些缺点:

  1. 必须为每一个对象建立和维护一个全新的连接,而客户和服务器需要为该连接分配TCP缓冲区和保持TCP变量,这给Web服务器带来了严重的负担。
  2. 每一个对象要经历两倍RTT时延。

在采用持续连接的情况下,服务器在发送响应后保持TCP连接打开,对对象的请求可以连续发出,不必等到响应(流水线)。一段时间未使用后,连接关闭。

2.2.3 HTTP报文格式

2.2.3.1 HTTP请求报文在这里插入图片描述

上图为一个典型的HTTP请求报文。该报文由ASCII文本书写,由5行组成,每行由一个回车和换行符结束(最后一行还有一个额外的回车和换行符)。HTTP请求报文的第一行称为请求行,后面的行称为首部行。请求行有3个字段:方法字段、URL字段和HTTP版本字段。

在这里插入图片描述
在这里插入图片描述
在GET方法中,“实体体”为空,使用POST方法时需要使用实体体。

2.2.3.2 HTTP响应报文

l在这里插入图片描述

2.2.4 用户与服务器的交互:cookie

HTTP使用cookie来允许站点对用户进行跟踪。
在这里插入图片描述
如上图所示,cookie有4个组件:HTTP响应报文中的一个cookie首部行、HTTP请求报文中的一个cookie首部行、客户端系统保留的cookie文件(由浏览器管理)、位于Web站点的一个后端数据库。假设Susan使用PC上的IE浏览器上网,她首次访问Amazon.com,当请求报文到达Amazon Web服务器时,该Web站点产生一个唯一的识别码,并以此索引后端数据库中的一个表项。然后,Amazon Web服务器用一个包含Set cookie:首部的HTTP响应报文对Susan的浏览器进行相应。Susan的浏览器收到响应报文时,它会根据Set cookie:首部的内容在特定cookie文件中添加一行,该行包括服务器主机名和cookie识别码。当Susan再次浏览Amazon网页时,浏览器会查询cookie文件并抽取她对这个网站的识别码,并放到HTTP报文的cookie:首部行中。这样,Amazon就可以跟踪Susan再Amazon站点的活动。

2.2.5 Web缓存

在这里插入图片描述
Web缓存器也叫代理服务器。Web服务器有自己的磁盘存储空间,保存着最近请求的对象的副本。Web缓存器既是客户也是服务器,由ISP购买并安装,可以减少客户请求的响应时间,减少机构的接入链路到因特网的通信量。

2.2.6 条件GET方法

2.3 因特网中的电子邮件(P75)

在这里插入图片描述
上图展示了电子邮件系统的总体情况。电子邮件系统由3部分组成:用户代理、邮件服务器、SMTP协议。

SMTP使用TCP可靠数据传输服务,由发送方的客户端和接收方的服务器端组成,每台邮件服务器上同时运行着客户端和服务器端。

2.3.1 SMTP协议

SMTP用于从发送方的邮件服务器发送报文到被发送方的邮件服务器。
在这里插入图片描述
SMTP一般不使用中间邮件服务器发送邮件。如果上图中,Bob的邮件服务器没有开机,发送出的报文会留在Alice的邮件服务器上并等待进行新的尝试。

客户SMTP在25号端口建立一个到服务器SMTP的TCP连接。连接建立后,进行SMTP的握手阶段,SMTP客户指示发送方的邮件地址和接收方的邮件地址。当客户和服务器彼此“介绍”之后,客户发送报文。如果另有报文发送,就在相同的TCP连接上重复这种处理,否则TCP连接关闭。

在这里插入图片描述

2.3.2 与HTTP的对比

相同点:持续连接。

不同点:

  1. HTTP是拉协议,TCP连接是由接收文件的一方发起的;SMTP是推协议,TCP连接是由发送文件的一方发起的。
  2. SMTP要求每个报文采用7比特ASCII码格式;HTTP无要求。
  3. 如果一个报文中同时包含图片和文本,HTTP会分别将每个对象封装到响应报文中,SMTP将所有对象放入一个报文之中。

2.3.3 邮件报文格式

邮件报文由首部行和报文体构成。每个首部必须包含From:To:首部行,首部行和报文体之间用空行分隔。
在这里插入图片描述

2.3.4 邮件访问协议

在这里插入图片描述
为什么不将报文由Alice的代理通过SMTP直接发送到Bob的邮件服务器呢?因为不通过Alice的邮件服务器进行中继,如果Bob的邮件服务器处于关闭状态,Alice的邮件将不能发送。采用Alice的邮件服务器作为中继后,Alice的服务器可以重复尝试向Bob的邮件服务器发送报文。

由于SMTP是推协议,所以Bob不能通过SMTP来获取邮件服务器上的邮件。

2.3.4.1 POP3

当用户代理打开了一个到邮件服务器110端口的TCP连接后,POP3开始工作。POP3的工作分为三个阶段:特许、事务处理、更新。特许阶段中,用户代理以明文发送用户名和口令;事务处理阶段中,用户代理取回报文,还可以对报文做删除标记、获取邮件的统计信息;更新阶段发生在客户发出quit命令后,这时,邮件服务器会删除那些有删除标记的报文。
在这里插入图片描述
服务器会对用户代理的命令做出回答(+OK-ERR)。
在这里插入图片描述
list命令要求邮件服务器列出所有存储的报文的长度。

使用“下载并删除”方式可能导致用户在一台设备上获取邮件后,不能再在其他的设备上获取邮件。

在用户代理和邮件服务器进行POP3会话期间,POP3服务器会保留一些状态信息(如哪些报文被标记删除)。但POP3服务器不会再会话过程中携带状态信息。

2.3.4.2 IMAP协议

在这里插入图片描述

2.4 DNS:因特网的目录服务(P83)

2.4.1 DNS提供服务

识别主机有两种方式:主机名、IP地址。DNS提供了主机名到IP地址转换的目录服务。DNS是一个由分层的DNS服务器实现的分布式数据库,是一个使得主机能够查询分布式数据库的应用层协议。DNS运行在UDP协议上,使用53号端口。

除了主机名到IP地址的转换外,DNS还提供了如下服务:

  1. 主机别名。
  2. 邮件服务器别名。
  3. 负载分配。繁忙的站点可能分布在多台服务器上,每台服务器运行在不同的端系统上,每个端系统有着不同的IP地址。因此,一个主机名可能对应了一个IP地址的集合,DNS在每个回答中循环这些地址的次序(客户总是向IP地址排在最前面的服务器发送HTTP请求报文)。

2.4.2 DNS工作机理概述

如果DNS服务器采用集中式设计,可能产生如下问题:

  1. 单点故障。
  2. 通信容量。
  3. 远距离的集中式数据库
  4. 维护。

2.4.2.1 分布式、层次数据库

有3种类型的DNS服务器:根服务器、顶级域(TLD)服务器、权威服务器。根服务器提供TLD服务器的IP地址,TLD服务器提供权威服务器的IP地址,权威服务器将主机名映射为IP地址。

本地DNS服务器起代理作用,负责将用户的DNS请求转发到DNS服务器层次结构中。
在这里插入图片描述
上图为“递归+迭代”模式,在实践中较为常用
在这里插入图片描述
上图为纯递归模式。

2.4.2.2 DNS缓存

当某个DNS服务器接收一个DNS回答时,它能将映射关系保存在本地。

2.4.3 DNS记录和报文

在这里插入图片描述

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

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

相关文章

计算机网络相关知识点

谈一谈对OSI七层模型和TCP/IP四层模型的理解? 这两种模型都是网络通信中重要的参考模型,他们的设计和功能有一些区别。 首先OSI,OSI七层模型,也被称为开放系统互联参考模型,是一种在国际标准化组织(ISO)中…

LabVIEW报表生成工具包时出现错误-41106

LabVIEW报表生成工具包时出现错误-41106 使用LabVIEW报表生成工具包创建Excel报告或Word文档时,收到以下错误:Error -41106 occurred at NI_Excel.lvclass:new report subVI.vi ->NI_report.lvclass:New Report.vi -> Export Report With JKI.vi …

ATFX汇市:为什么英央行维持利率不变,而不是加息25基点?

ATFX汇市:9月21日,英国央行9月利率决议宣布,维持5.25%的基准利率不变,此前市场预期英央行将会加息25基点。消息公布后,GBPUSD五分钟内从最高点1.2300下跌至1.2239,跌幅61基点。英国央行会议纪要中提到&…

Linux 作业

一. 题目 二.作业内容 第一题: 因老师要求上传安装后远程连接XShell截图,如下: 制作yum缓存:[rootRHEL8 ~]# yum makecache 安装gcc:[rootRHEL8 ~]# yum install gcc -y 制作快照:快照,初始 s…

各种存储性能瓶颈如何分析与优化?

【摘要】本文结合实践剖析存储系统的架构及运行原理,深入分析各种存储性能瓶颈场景,并提出相应的性能优化手段,希望对同行有一定的借鉴和参考价值。 【作者】陈萍春,现就职于保险行业,拥有多年的系统、存储以及数据备…

IntelliJ IDEA使用——Debug操作

文章目录 版本说明图标和快捷键查看变量计算表达式条件断点多线程调试 版本说明 当前的IntelliJ IDEA 的版本是2021.2.2(下载IntelliJ IDEA) ps:不同版本一些图标和设置位置可能会存在差异,但应该大部分都差不多。 图标和快捷键…

java内嵌浏览器CEF-JAVA、jcef、java chrome

java内嵌浏览器CEF-JAVA、jcef、java chrome jcef是老牌cef的chrome内嵌方案,可以进行java-chrome-h5-桌面开发,下面为最新版本(2023年9月22日10:33:07) JCEF(Java Chromium Embedded Framework)是一个基于…

版本控制系统git:一文了解git,以及它在生活中的应用,网站维护git代码,图导,自动化部署代码

目录 1.Git是什么 2.git在生活中的应用 2.1git自动化部署代码 3.网站维护git代码 3.1如何在Git代码托管平台等上创建一个仓库 3.2相关文章 4.ruby实现基础git 4.1.Git add 4.2 Git commit 4.3 Git log 1.Git是什么 Git是一个版本控制系统,它可以追踪文件的…

Vue.js的服务器端渲染(SSR):为什么和如何

🌷🍁 博主猫头虎(🐅🐾)带您 Go to New World✨🍁 🦄 博客首页——🐅🐾猫头虎的博客🎐 🐳 《面试题大全专栏》 🦕 文章图文…

golang 自动生成文件头

安装koroFileHeader控件 打开首选项,进入设置,配置文件头信息"fileheader.customMade": {"Author": "lmy","Date": "Do not edit", // 文件创建时间(不变)// 文件最后编辑者"LastEditors"…

【实用干货】5大自动化测试的Python框架!

自从2018年被评选为编程语言以来,Python在各大排行榜上一直都是名列前茅。 目前,它在Tiobe指数中排名第三个,仅次于Java和C。随着该编程语言的广泛使用,基于Python的自动化测试框架也应运而生,且不断发展与丰富。 因…

关于IDEA没有显示日志输出?IDEA控制台没有显示Tomcat Localhost Log和Catalina Log 怎么办?

问题描述: 原因是;CATALINA_BASE里面没有相关的文件配置。而之前学习IDEA的时候,把这个文件的位置改变了。导致,最后输出IDEA的时候,不会把日志也打印出来。 检查IDEA配置; D:\work_soft\tomcat_user\Tomcat10.0\bin 在此目录下&…