应用层协议概述ppt课件.ppt
《应用层协议概述ppt课件.ppt》由会员分享,可在线阅读,更多相关《应用层协议概述ppt课件.ppt(86页珍藏版)》请在三一办公上搜索。
1、应用层,1,应用层,本讲目标: 网络应用层的概念和实现客户端-服务器范式服务模型通过对常用应用层协议的探讨和分析来学习网络协议,深层次目标 特定协议: dnshttpftpsmtppop,应用层,2,应用层协议,应用层负责的是进程与进程之间的通信应用层协议:应用层的一个“组成部分”定义应用程序需交换的报文 和所需采取的动作位于最高层使用较低层次所提供的通信服务 (TCP, UDP),应用层,3,网络应用程序: 一些术语,进程(Process): 主机中运行中的程序.在某些主机中, 两个进程使用进程间通信 (由 OS管理).而运行在不同主机上的进程则使用应用层协议进行通信,用户代理(User a
2、gent): 软件进程, 是介于用户( above )和网络( below )之间的接口实现应用级协议Web: 浏览器E-mail: OE、Foxmail流媒体: media player,应用层,4,客户端-服务器模式,典型的网络应用都是由两个部分组成: 客户端 和 服务器,客户端:发起同服务器的联系 (“speaks first”)一般都从服务器请求服务, Web: 客户端由浏览器实现; e-mail: 通过OE、Foxmial实现,服务器:向客户端提供所请求的服务e.g., Web 服务器发送被请求的 Web 页面, 邮件服务器传递 e-mail,应用层,5,应用层协议(续),应用程序接
3、口(API: application programming interface)定义应用层和传输层间的接口插口(socket: Internet API)两个进程间的通信, 将数据送入 socket, 或从socket 读出数据,Q: 某个进程如何“标识”另一个 需要与之通信的进程?(SOCKET 套接字)IP 地址-运行另一个进程的主机所拥有的“端口号(PORT #)” 允许接收主机来确定的一个标识,本地进程将报文发送给它SOCKETIP+PORT,应用层,6,关于端口的说明,端口是应用进程的标识,本质上是一个存放在传输层首部的一个字段的值,如TCP端口,UDP端口。端口可以看作传输层对于
4、应用层的SAP端口占两个字节,范围是065535保留使用的端口01023 http:80. Dns:53. Smtp:25 pop:110用户可以使用的端口102465535问题:为什么不使用操作系统的进程号来标识进程。,应用层,7,应用进程需要怎样的传输服务?,数据丢失(Data loss)某些应用 (e.g., audio) 可以容忍某种程度上的数据丢失其他应用 (e.g., 文件传输, telnet) 要求 100% 可靠的数据传输,实时性(Timing)某些应用(e.g., IP 电话, 交互式游戏) 要求较低的时延,带宽(Bandwidth)某些应用(e.g., 多媒体) 对最低带宽
5、有要求其他应用(“弹性应用”) 则可灵活应用所能得到的带宽,应用层,8,常用应用程序对传输功能的要求,应用程序文件传输e-mailWeb 网页实时音频/视频存储音频/视频交互式游戏金融应用,数据丢失不丢失不丢失不丢失允许丢失允许丢失允许丢失允许丢失不丢失,带宽弹性弹性弹性音频: 5Kb-1Mb视频:10Kb-5Mb同上 几 Kb/s 以上弹性,实时性无无无100s msecfew secs100s msecyes and no,应用层,9,Internet 的传输协议服务,TCP 服务:面向连接: 在客户端和服务器进程之间需要建立连接(setup )可靠传输 : 在发送和接受进程之间流量控制:
6、 发送数据的速度决不超过接收的速度 拥塞控制: 当网络超负荷时,束紧发送端口,减缓发送速度不提供: 实时性, 最小带宽承诺,UDP服务:在客户端和服务器进程之间实现“不可靠的”数据传输不提供:连接建立, 可靠性保证,流量控制,拥塞控制,实时性, 最小带宽承诺Q: 既生喻,何生亮? Why is there a UDP?,应用层,10,Internet应用: 应用, 传输协议,应用e-mail远程终端访问Web 文件传输流媒体远程文件服务器IP电话,应用协议smtp RFC 821telnet RFC 854http RFC 2068ftp RFC 959专有协议(e.g. RealNetwor
7、ks)NSF专有协议(e.g., Vocaltec),所依赖的传输协议TCPTCPTCPTCPTCP or UDPTCP or UDPtypically UDP,应用层,11,在IE中输入网址后,首先域名解析DNS,浏览器和DNS服务器交互其次采用http协议,浏览器和Web服务器交互,应用层,12,DNS: 域名系统,自然人: 诸多定义:身份证, 姓名, 护照 #因特网主机, 路由器:IP 地址 (32 bit) 用于数据报寻址“域名”, e.g., 帮助记忆Q: IP 地址和域名之间如何映射(转换) ?,Domain Name System:分布式数据库:由许多域名服务器按层次构成 DNS
8、透明的解决了IP地址和域名的转换问题DNS传输一般使用UDP,端口53。,应用层,13,因特网的域名结构,因特网采用了层次树状结构的命名方法。任何一个连接在因特网上的主机或路由器,都有一个惟一的层次结构的名字,即域名。域名的结构由若干个分量组成,各分量之间用点隔开: .三级域名.二级域名.顶级域名各分量分别代表不同级别的域名。,应用层,14,顶级域名 TLD (Top Level Domain),(1) 国家顶级域名 nTLD:如: .cn 表示中国,.us 表示美国,.uk 表示英国,等等。(2) 国际顶级域名 iTLD:采用.int。国际性的组织可在 .int 下注册。(3) 通用顶级域名
9、 gTLD:最早的顶级域名是: .com 表示公司企业 .net 表示网络服务机构 .org 表示非赢利性组织 .edu 表示教育机构(美国专用) .gov 表示政府部门(美国专用) .mil 表示军事部门(美国专用),因特网的名字空间,com,net,org,edu,gov,mil,coop,biz,info,aero,int,cn,uk,hk,js,sh,bj,org,net,gov,edu,com,ac,pku,fudan,sjtu,tsinghua,树根,cctv,ibm,hp,mot,顶级域名,二级域名,三级域名,mail,ep,四级域名,mail,csnetl,seu,应用层,16
10、,DNS name servers,没有服务器能够保存所有 Name-to-IP 地址的映射本地域名服务器:每个 ISP, 企业可拥有 本地(默认) 域名服务器主机的 DNS 查询首先发往本地域名服务器授权域名服务器:每台主机必须在授权服务器上注册登记可完成域名/地址的转换,为什么不搞集中的DNS?单点失败的问题数据的流通量远程集中式的数据库维护问题难以与时俱进,跟不上发展!,应用层,17,DNS: 根域名服务器,当本地域名服务器不能解析时,就向根域名服务器查询根域名服务器:如果域名映射未知,则向授权域名服务器查询取得映射将映射返回本地域名服务器,遍布世界各地的13个根域名服务器,递归查询,递
11、归与迭代相结合的查询,应用层,20,DNS: 缓存和更新纪录,一旦 (任何) 域名服务器得知了某个映射, 就将其 缓存在一定的时间间隔后缓存的条目将会过期(自动消除)更新/通知 机制由 IETF负责设计RFC 2136http:/www.ietf.org/html.charters/dnsind-charter.html,应用层,21,DNS 纪录,DNS: 存储资源纪录 (RR)的分布式数据库,Type=NSname = 域 (e.g. )value =该域授权域名服务器的 IP 地址,Type=Aname = 主机名value = IP 地址,Type=CNAMEName= 别名 is r
12、eally value =真名,Type=MXvalue = 与 name相关的邮件服务器域名,应用层,22,DNS 协议报文格式,DNS 协议 : 查询和应答报文, 二者格式相同,报文首部identification: 16 bit # 用于查询, 应答报文使用同样的 #flags:查询 或 应答希望递归 可以递归授权应答,应用层,23,DNS 协议报文格式,Name, type fields 查询报文,RRs 响应,来自授权服务器的纪录,其他“帮助”信息,应用层,24,万维网 WWW概述,万维网 WWW (World Wide Web)并非某种特殊的计算机网络。万维网是一个大规模的、联机式
13、的信息储藏所。万维网用链接的方法能非常方便地从因特网上的一个站点访问另一个站点,从而主动地按需获取丰富的信息。这种访问方式称为“链接”。,应用层,25,万维网提供分布式服务,万维网站点 A,万维网站点 C,万维网站点 E,万维网站点 D,万维网站点 B,应用层,26,超媒体与超文本,万维网是分布式超媒体(hypermedia)系统,它是超文本(hypertext)系统的扩充。一个超文本由多个信息源链接成。利用一个链接可使用户找到另一个文档。这些文档可以位于世界上任何一个接在因特网上的超文本系统中。超文本是万维网的基础。超媒体与超文本的区别是文档内容不同。超文本文档仅包含文本信息,而超媒体文档还
14、包含其他表示方式的信息,如图形、图像、声音、动画,甚至活动视频图像。,应用层,27,万维网的工作方式,万维网以客户服务器方式工作。浏览器就是在用户计算机上的万维网客户程序。万维网文档所驻留的计算机则运行服务器程序,因此这个计算机也称为万维网服务器。客户程序向服务器程序发出请求,服务器程序向客户程序送回客户所要的万维网文档。在一个客户程序主窗口上显示出的万维网文档称为页面(page)。,应用层,28,万维网必须解决的问题,(1) 怎样标志分布在整个因特网上的万维网文档? 使用统一资源定位符 URL (Uniform Resource Locator)来标志万维网上的各种文档。使每一个文档在整个因
15、特网的范围内具有惟一的标识符 URL。 (2) 用何协议实现万维网上各种超链的链接? 在万维网客户程序与万维网服务器程序之间进行交互所使用的协议,是超文本传送协议 HTTP (HyperText Transfer Protocol)。HTTP 是一个应用层协议,它使用 TCP 连接进行可靠的传送。,应用层,29,万维网必须解决的问题,(3) 怎样使各种万维网文档都能在因特网上的各种计算机上显示出来,同时使用户清楚地知道在什么地方存在着超链? 超文本标记语言 HTML (HyperText Markup Language)使得万维网页面的设计者可以很方便地用一个超链从本页面的某处链接到因特网上的
16、任何一个万维网页面,并且能够在自己的计算机屏幕上将这些页面显示出来。(4) 怎样使用户能够很方便地找到所需的信息? 为了在万维网上方便地查找信息,用户可使用各种的搜索工具(即搜索引擎)。,应用层,30,统一资源定位符 URL(uniform resourse location),统一资源定位符 URL 是对可以从因特网上得到的资源的位置和访问方法的一种简洁的表示。URL 给资源的位置提供一种抽象的识别方法,并用这种方法给资源定位。URL 相当于一个文件名在网络范围的扩展。因此 URL 是与因特网相连的机器上的任何可访问对象的一个指针。,应用层,31,URL 的一般形式,由以冒号隔开的两大部分组
17、成,并且在 URL 中的字符对大写或小写没有要求。URL 的一般形式是:,:/:/ (8-2),应用层,32,URL 的一般形式,由以冒号隔开的两大部分组成,并且在 URL 中的字符对大写或小写没有要求。URL 的一般形式是:,:/:/ (8-2),应用层,33,URL 的一般形式,由以冒号隔开的两大部分组成,并且在 URL 中的字符对大写或小写没有要求。URL 的一般形式是:,:/:/ (8-2),应用层,34,使用 HTTP 的 URL,使用 HTTP 的 URL 的一般形式 http:/:/,应用层,35,使用 HTTP 的 URL,使用 HTTP 的 URL 的一般形式 http:/:
18、/,冒号和两个斜线是规定的格式,应用层,36,使用 HTTP 的 URL,使用 HTTP 的 URL 的一般形式 http:/:/,这里写主机的域名,应用层,37,使用 HTTP 的 URL,使用 HTTP 的 URL 的一般形式 http:/:/,HTTP 的默认端口号是 80,通常可省略,应用层,38,使用 HTTP 的 URL,使用 HTTP 的 URL 的一般形式 http:/:/,若再省略文件的项,则 URL 就指到因特网上的某个主页(home page)。,应用层,39,http 协议,http: TCP 传输服务:客户端启动TCP连接(创建插口) 到服务器, 端口 80服务器接受
19、来自客户端的 TCP 连接http 报文(应用层协议报文) 在浏览器 (http client) 和Web服务器(http server)之间进行交换关闭TCP 连接,http 是 “无状态(stateless)”的服务器不保留任何访问过的请求信息,保留状态的协议很复杂哟!过去的历史 (状态) 需要保留一旦浏览器/服务器崩溃, 它们各自的状态视图就会发生分歧,还需要重新核对,小评论,应用层,40,Web: http 协议,超文本传输协议(http: hypertext transfer protocol)万维网应用协议客户端/服务器模式客户端: 浏览器请求、接收、展示 Web对象( objec
20、ts)服务器: Web 服务器发送对象对请求进行响应http1.0: RFC 1945http1.1: RFC 2068,PC runningExplorer,Server runningNCSA Webserver,Mac runningNavigator,http request,http request,http response,http response,应用层,41,http 举例,假设用户键入了一个 URL www.someSchool.edu/someDepartment/home.index,1a. http 客户端启动 TCP 连接到www.someSchool.edu上的
21、http 服务器 (进程). Port 80 是 http 服务器的默认端口.,2. http客户端发送 http 请求报文 (包括URL) 进入 TCP 连接插口(socket),1b. 在www.someSchool.edu 上的http 服务器在 port 80 等待 TCP 的连接请求. “接受” 连接并通知客户端,3. http 服务器接收到请求报文, 形成 响应报文( 包含了所请求的对象 ,someDepartment/home.index), 将报文送入插口( socket),time,(该网页包含文本并引用了10 jpeg 图片),应用层,42,http 举例 (续.),5.
22、http 客户端接收到了包含html文件的响应报文。 分析 html 文件, 发现 10 个引用的 jpeg 对象,6. 对10 jpeg objects 逐个重复1-5 步,4. http 服务器关闭 TCP 连接.,time,应用层,43,非持续和持续连接,(非持续连接)Non-persistenthttp/1.0: 服务器分析请求、响应、关闭 TCP 连接取对象需要2 RTTsTCP 连接对象请求/传送每次传送都要受到TCP连接初始化时的慢启动影响许多浏览器同时打开多个并行的连接来改善性能,(持续连接)Persistenthttp/1.1的默认设置在同一TCP 连接上: 服务器分析请求、
23、响应请求,分析新的请求、.客户端一旦下载到了基本的html文件( base HTML )马上发送对所有引用对象的请求.较少的 RTTs, 较少的慢启动.,应用层,44,流水线和非流水线方式,流水线方式指没有收到上一个请求的对象就发送新的对象的请求非流水线方式指必须要等到上一个请求的对象到达之后再发送新的对象的请求,应用层,45,http 报文格式: request(请求),two types of http报文: request, responsehttp 请求报文:ASCII (可读格式),应用层,46,http 请求报文格式:Request,请求报文的类型是由它所采用的方法决定的。,应用层
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 应用 协议 概述 ppt 课件
链接地址:https://www.31ppt.com/p-1934014.html