第二章—应用层
2.1、应用层原理
网络应用的体系结构
客服—服务器(C/S)体系结构
服务器
- 一直运行
- 固定的IP地址和周知的端口号
- 扩展性:服务器场,数据中心进行扩展、扩展性差
客户端
- 主动与服务器通信
- 与互联网有间歇性的连接
- 可能是动态IP地址
- 不能直接与其他客户端通信
对等体(P2P)体系结构
- 几乎没有一直运行的服务器
- 任意端系统之间可以进行通信
- 每个节点即是客户端又是服务器
- 参与主机间歇性连接且可以改变IP地址
C/S和P2P体系的混合结构
Napster
- 文件搜索:集中
- 文件传输:P2P
即时通信
- 在线检测:集中
- 两个客户聊天:P2P
进程通信
==进程==:在主机上运行的应用程序
- 在同一个主机内,使用==进程通信机制==通信(操作系统定义)
- 不同主机,通过交换==报文(Message)来通信
客户端进程:发起通信的进程
服务器进程:等待连接的进程
分布式进程通信需要解决的问题
进程标示和寻址问题(==服务用户==)
- 对进程进行编址
进程为了接受报文,必须有一个标识即:SAP
- 主机:唯一的32位==IP地址==
- 所采用的传输层协议:TCP/UDP
- 端口号(Port Numbers)
- 本质上,一对主机进程之间的通信由2个端节点构成
传输层-应用层提供服务是如何(==服务==)
- 位置:层间界面的SAP(TCP/IP:scoket)
- 形式:应用程序接口API(TCP/IP:scoket API)
层间接口必须要携带信息
- 要传输的报文
- 谁传的:对方的应用进程的标示:IP+TCP(UDP) 端口
- 传给谁:对方的应用进程的标示:对方的IP+TCP(UDP)端口号
传输层实体(tcp或者udp实体)根据这些信息进行TCP报文段(UDP数据包)的分装
- 源端口号,目标端口号,数据等
- 将IP地址往下交IP实体,用于封装IP数据报:源IP,目的IP
TCP scoket:
- TCP服务,两个进程之间的通信需要之前要建立连接
- 可以用一个整数表示两个应用实体之间的通信关系,本地标示
- TCP scoket:源IP、源端口、目标IP、目标端口
TCP的套接字
- 4元组:(源IP、源port、目标IP、目标port)
- 唯一的指定了一个会话(2个进程之间的会话关系)
- 应用使用这个标示,与远程的应用进程通信
UDP scoket:
- UDP服务,两个进程之间的通信需要之前无需建立连接:每个报文都是独立传输,前后报文可能分给不同的分布式进程
- UDP scoket:本IP,本端口
- 传输报文时:必须要提供对方IP,Port:传输报文时:传输层需要上传对方的IP,port
UDP套接字
- 2元组:IP,Port
- UDP套接字指定了应用所在的一个==端节点==
- 在发报文时,必须要指定对方的IP和UDP port
如何使用传输层提供的服务,实现应用进程之间的报文交换,实现应用(==用户使用服务==)
- 定义应用层协议:报文格式,解释,时序等
- 编制程序,使用OS提供的API,调用网络基础设施提供通信服务传报文
应用层协议
定义了:运行在不同的端系统上的应用进程如何相互交换报文
- 交换的报文类型:请求和应答报文
- 各种报文类型的语法:报文中的各个字段及其描述
- 字段的语义:即字段取值的含义
- 进程何时、如何发送报文及对报文进行响应的==规则==
应用层需要传输层提供什么样的服务?如何描述传输层的服务?
- 数据丢失率
- 吞吐
- 延迟
- 安全性:机密性、机密性、可认证性
Internet传输层提供的服务
TCP服务:
- 可靠的传输服务
- 流量控制:发送方不会淹没接受方
- 拥塞控制:当网络出现拥塞时,能抑制发送方
- 不能提供的服务:时间保证、最小吞吐保证和安全
- 面向连接:要求在客户端进程和服务器进程之间建立连接
UDP服务:
- 不可靠传输
- 不提供服务:可靠、拥塞控制、流量控制、时间、宽带保证、建立连接
UDP存在的必要性
- 能够区分不同的进程,而IP服务不能
- 无需建立连接,省去建立连接时间,适合事物性的应用
- 不做可靠性的工作
- 没有拥塞控制和流量控制,应用能够按照设定的速度发送数据
2.2、Web和HTTP
Web术语
Web页:由一些对象组成,对象可以是HTML文件,JPEG图像,Java程序等。其包含有一个==基本的HTML文件==该文件包含若干对象的链接
通过URL对每个对象进行引用
- 访问协议,用户名,口令字,端口等;
URL格式:
HTTP概况
==HTTP:超文本传输协议==
- Web的应用层协议
客户/服务模式
- 客户:请求、接收和显示Web对象的浏览器
- 服务器:对请求进行响应,发送对象的Web服务器
使用TCP
- 客户发起一个与服务器的TCP连接(建立套接字scoket),端口为80
- 服务器接受客户的TCP连接
- 在浏览器(HTTP客户端)与服务器(HTTP服务器server)交换HTTP报文(应用层协议报文)
- TCP连接关闭
HTTP是无状态的
- 无状态的意思是服务器并不会维护关于客户的任何信息(也就是客户发送什么请求,服务器端就给什么响应)
维护状态的协议和复杂
- 必须维护历史信息(状态)
- 如果服务器/客户机死机。他们的状态信息可能不一致,二者的信息是一致的
- 无状态的服务器能够支持更多的客户端
HTTP连接
非持久HTTP
- 最多只有一个对象在TCP连接上发送
- 下载多个对象需要多个TCP连接
- HTTP/1.0使用非持久连接
持久HTTP
- 多个对象可以在一个(客户端和服务器之间的)TCP连接上传输
- HTTP/1.1默认使用持久连接
响应时间模型
==往返时间RTT(round-triptime)==:一个小的分组从客户端到服务器,在回到客户端的时间(传输时间忽略)
==响应时间==:
- 一个RTT用来发起TCP连接
- 一个RTT用来HTTP请求并等待HTTP响应
- 文件传输时间
- 共:2RTT+传输时间
持久HTTP
非持久HTTP的缺点:
- 每个对象要2个RTT
- 操作系统必须为每个TCP连接分配资源,但浏览器通常打开并行TCP连接,以获取引用对象
持久HTTP
- 服务器在发送响应后,仍保持TCP连接
- 在相同客户端和服务器之间的后续请求和响应报文通过相同的连接进行传送、客户端在遇到一个引用对象的时候,就可以尽快发送对象的对象的请求
非流水方式的持久HTTP
- 客户端只能在收到前一个响应后才能发出新的请求
- 每个引用对象花费一个RTT
流水方式的持久HTTP
- HTTP/1.1的默认模式
- 客户端遇到一个引用对象就立即产生一个请求
- 所有引用(小)对象只花费一个RTT是可能的
HTTP请求报文
两种类型的HTP报文:==请求、响应==
HTTP请求报文:ASCII
在浏览器中输入www.baidu.com可以看到HTTP请求报文格式
HTTP请求报文:通用格式
HTTP有两类报文:
- 请求报文——从客户端向服务器发送请求报文
- 响应报文——从服务器到客户端的回答
提交表单输入
POST方式:网页通常包含表单输入、包含在实体主体(entity body)中的输入被提交到服务器
URL方式:方法:GET、输入通过请求行的URL字段上载
方法类型
- HTTP/1.0:GET、POST、HEAD(要求在服务器在响应报文中不包含请求对象——>故障跟踪)
- HTTP/1.1:GET、POST、HEAD、PUT(将实体主体中的文件上载到URL字段规定的路径)、DELETE(删除URL字段规定的文件)
HTTP响应状态码
- 200 OK:请求成功,请求对象包含在响应报文的后续部分
- 301 Moved Permanently:请求的对象已被永久转移了
- 400 Bad Request:一个通用的差错代码,表示请求不能被服务器解读(例如:在Java中前后端联调时接口写错)
- 404 Not Found:请求的文档在该服务上没有找到
- 505 HTTP Version Not Support:服务器错误
用户-服务器状态:cookies
大多数主要门户网站使用cookies,主要有4部分组成:
- 在HTTP响应报文中有一个cookies的首部行
- 在HTTP请求报文含有一个cookies的首部行
- 在用户端系统中保留有一个cookie文件,有用户浏览器管理
- 在Web站点有一个后端数据库
Web缓存(代理服务器)
目标:不访问原始服务器,就满足客户的请求
- 用户设置浏览器:通过缓存访问Web
浏览器将所有的HTTP请求发给缓存
- 在缓存中的对象:缓存直接返回对象
- 如果对象不在缓存,缓存请求原始服务器,然后再将对象返回个客户端
2.3、FTP
FTP:文件传输协议
- 向远程主机上传输文件或从远程主机接收文件
客户/服务器模式
- 客户端:发起传输的一方
- 服务器:远程主机
- FTP服务器:端口号21
FTP:控制连接与数据连接分开
- FTP客户端与FTP服务器通过端口21连接,并使用TCP为传输协议
- 客户端通过控制连接获得身份确认
- 客户端通过控制连接发送命令浏览远程目录,收到文件传输命令时,服务器打开一个客户端的数据连接
- 一个文件传输完成后,服务器关闭连接,服务器打开第二个TCP数据连接用来传输另一个文件
- ==FTP服务器维护用户状态信息==:当前路径、用户账户与控制连接对应状态
FTP命令、响应
命令样例:
- 在控制连接上以ASCII文本方式传送
- USER username PASS password
- LIST:请服务器返回远程主机当前目录的文件列表
- PETR filename:从远程主机当前目录检索文件
- STOR filename:向远程主机的当前目录存放文件