之前在开发中,有些后端服务处理非常慢,页面可能会出现504 Gateway time-out的提示,或者服务器还没返回数据,浏览器就关掉了。我们只是看到了浏览器关掉,但是服务器和客户端的状态都是什么样的呢?
问题
在浏览器上发送http请求到服务器 2. 服务器接受导请求开始处理数据 3. 在服务器返回结果前关闭了浏览器,那么服务器的数据还会继续返回么?客户端会是什么状态?
分析
当在浏览器上发送HTTP请求到服务器,并在服务器返回结果前关闭了浏览器,会发生以下情况:
1. 浏览器发送HTTP请求到服务器
当你在浏览器上点击某个链接或提交一个表单时,浏览器会通过HTTP协议发送一个请求到服务器。这个请求会建立一个TCP连接,并发送一个HTTP请求报文。
2. 服务器接受请求并开始处理数据
服务器接收到来自浏览器的HTTP请求后,开始处理请求中的数据。这可能包括查询数据库、执行业务逻辑等步骤。
3. 在服务器返回结果前关闭了浏览器
假设在服务器还没有完全返回结果之前,你关闭了浏览器。这时会发生以下变化:
服务器端
- 服务器继续处理请求:
- 服务器在检测到客户端断开连接之前,会继续处理请求。这包括执行任何相关的业务逻辑或数据库操作。
- 服务器检测到断开连接:
- 一旦服务器尝试向客户端发送响应数据时发现连接已经被断开,它通常会收到一个网络错误(如ConnectionReset异常),表明客户端已经关闭了连接。
- 服务器的响应:
- 服务器会停止尝试发送响应数据,并关闭连接。对于某些服务器实现,如果响应已经准备好但未能发送,可能会记录错误日志。
客户端(浏览器)
- 浏览器检测到断开连接:
- 浏览器会检测到连接被中断,并显示错误消息。通常情况下,浏览器会显示类似于"此页面无法加载"或"请求超时"的提示。
- 浏览器的状态:
- 浏览器不会接收到服务器的响应数据。由于浏览器已经被关闭,它无法接收任何进一步的信息或响应。
具体案例分析
使用HTTP/1.1协议
- 浏览器断开连接:
- 浏览器关闭后,TCP连接会被中断。
- 服务器检测到断开连接:
- 服务器尝试发送响应数据时会收到网络错误,例如ConnectionReset异常。
- 服务器的响应:
- 服务器通常会记录错误日志,并关闭连接。
使用HTTP/2协议
- 浏览器断开连接:
- 如果浏览器关闭,HTTP/2协议中的流(stream)也会被中断。
- 服务器检测到断开连接:
- 服务器在尝试通过流发送响应数据时会检测到流被中断。
- 服务器的响应:
- 服务器会停止发送响应数据,并可能关闭流或整个连接。
客户端的状态
- 浏览器检测到断开连接:
- 浏览器会检测到连接被中断,并显示错误消息。
- 浏览器的显示:
- 用户界面通常会显示一个错误页面或消息,表明请求无法完成或页面加载失败。
总结
当浏览器在服务器返回结果前关闭时,服务器通常会继续处理请求,直到它尝试发送响应数据时发现连接已被断开。这时,服务器会记录错误并关闭连接。浏览器会检测到连接中断,并显示相应的错误消息。具体的行为取决于使用的HTTP版本(HTTP/1.1 vs HTTP/2)以及服务器和浏览器的具体实现。