参考答案
HTTP协议
HTTP
是单向的,客户端发送请求,服务器发送响应。举例来说,当客户端向服务器发送请求时,该请求以HTTP
或HTTPS
的形式发送,在接收到请求后,服务器会将响应发送给客户端。
每个请求都与一个对应的响应相关联,在发送响应后客户端与服务器的连接会被关闭。每个HTTP
或HTTPS
请求每次都会新建与服务器的连接,并且在获得响应后,连接将自行终止。 HTTP
是在TCP
之上运行的无状态协议,TCP
是一种面向连接的协议,它使用三向握手方法保证数据包传输的传递并重新传输丢失的数据包。
HTTP
可以运行在任何可靠的面向连接的协议(例如TCP
,SCTP
)的上层。当客户端将HTTP
请求发送到服务器时,客户端和服务器之间将打开TCP
连接,并且在收到响应后,TCP
连接将终止,每个HTTP
请求都会建立单独的TCP
连接到服务器,例如如果客户端向服务器发送10个请求,则将打开10个单独的HTTP
连接。并在获得响应后关闭。
理解上面这段关于 HTTP
的描述时我觉得还要了解一下HTTP
长连接的概念,以及HTTP
与TCP
的关系,简单概括一下就是:
HTTP
协议的长连接和短连接,实质上是TCP
协议的长连接和短连接。- 每个
HTTP
连接完成后,其对应的TCP
连接并不是每次都会关闭。从HTTP/1.1
起,默认使用长连接,用以保持连接特性。使用长连接的HTTP
协议,会在响应头有加入这个头部字段:Connection:keep-alive
- 在使用长连接的情况下,当一个网页打开完成后,客户端和服务器之间用于传输
HTTP
数据的TCP
连接不会关闭,如果客户端再次访问这个服务器上的网页,会继续使用这一条已经建立的连接。Keep-Alive
不会永久保持连接,它有一个保持时间,可以在不同的服务器软件(如Apache
,Nginx
,Nginx
中这个默认时间是 75s)中设定这个时间。实现长连接要客户端和服务端都支持长连接。 HTTP
属于应用层协议,在传输层使用TCP
协议,在网络层使用IP
协议。IP
协议主要解决网络路由和寻址问题,TCP
协议主要解决如何在IP
层之上可靠的传递数据包,使在网络上的另一端收到发端发出的所有包,并且顺序与发出顺序一致。TCP
有可靠,面向连接的特点。
HTTP消息信息是用ASCII
编码的,每个HTTP
请求消息均包含HTTP
协议版本(HTTP/1.1
,HTTP/2
),HTTP
方法(GET
/POST
等),HTTP
标头(Content-Type
,Content-Length
),主机信息等。以及包含要传输到服务器的实际消息的正文(请求主体)。HTTP
标头的大小从200字节到2KB
不等,HTTP
标头的常见大小是700-800字节。当Web
应用程序在客户端使用更多cookie
和其他工具扩展代理的存储功能时,它将减少HTTP
标头的荷载。
WebSocket协议
WebSocket
是双向的,在客户端-服务器通信的场景中使用的全双工协议,与HTTP
不同,它以ws://
或wss://
开头。它是一个有状态协议,这意味着客户端和服务器之间的连接将保持活动状态,直到被任何一方(客户端或服务器)终止。在通过客户端和服务器中的任何一方关闭连接之后,连接将从两端终止。
让我们以客户端-服务器通信为例,每当我们启动客户端和服务器之间的连接时,客户端-服务器进行握手随后创建一个新的连接,该连接将保持活动状态,直到被他们中的任何一方终止。建立连接并保持活动状态后,客户端和服务器将使用相同的连接通道进行通信,直到连接终止。
新建的连接被称为WebSocket
。一旦通信链接建立和连接打开后,消息交换将以双向模式进行,客户端-服务器之间的连接会持续存在。如果其中任何一方(客户端服务器)宕掉或主动关闭连接,则双方均将关闭连接。套接字的工作方式与HTTP
的工作方式略有不同,状态代码101
表示WebSocket
中的交换协议。
何时使用WebSocket
- 即时
Web
应用程序:即时Web
应用程序使用一个Web
套接字在客户端显示数据,这些数据由后端服务器连续发送。在WebSocke
t中,数据被连续推送/传输到已经打开的同一连接中,这就是为什么WebSocket
更快并提高了应用程序性能的原因。 例如在交易网站或比特币交易中,这是最不稳定的事情,它用于显示价格波动,数据被后端服务器使用Web套接字通道连续推送到客户端。 - 游戏应用程序:在游戏应用程序中,你可能会注意到,服务器会持续接收数据,而不会刷新用户界面。屏幕上的用户界面会自动刷新,而且不需要建立新的连接,因此在
WebSocket
游戏应用程序中非常有帮助。 - 聊天应用程序:聊天应用程序仅使用
WebSocket
建立一次连接,便能在订阅户之间交换,发布和广播消息。它重复使用相同的WebSocket
连接,用于发送和接收消息以及一对一的消息传输。
不能使用WebSocket的场景
如果我们需要通过网络传输的任何实时更新或连续数据流,则可以使用WebSocket
。如果我们要获取旧数据,或者只想获取一次数据供应用程序使用,则应该使用HTTP
协议,不需要很频繁或仅获取一次的数据可以通过简单的HTTP
请求查询,因此在这种情况下最好不要使用WebSocket
。
注意:如果仅加载一次数据,则RESTful
Web
服务足以从服务器获取数据。