> 文章列表 > HTTP请求知识

HTTP请求知识

HTTP请求知识

一次完整的HTTP请求所经历的步骤

1:首先进行DNS域名解析(本地浏览器缓存,操作系统缓存或者DNS服务器),首先会搜索浏览器自身的DNS缓存(缓存时间比较短,大概只有1分钟,且只能容纳1000条缓存)

      如果浏览器自身的缓存里面没有找到,那么浏览器会搜索系统自身的DNS缓存

      如果还没有找到,那么尝试从hosts文件里面去找

      在前面三个过程都没有获取到的情况下,就去域名服务器查找

2:三次握手建立TCP连接

      在HTTP工作开始之前,客户端首先要通过网络与服务器建立连接,HTTP连接是通过TCP来完成的。HTTP是比TCP更高层次的应用层协议,根据规则,只有低层协议建立之后,才能进行高层协议的连接,因此首先要建立TCP连接,一般TCP连接的端口是80

3:客户端发起HTTP请求

4:服务器响应HTTP请求

5:客户端解析html代码,并请求html代码中的资源

      浏览器拿到html文件后,就开始解析其中的html代码,遇到js/css/image等静态资源时,就向服务器端去请求下载

6:客户端渲染展示内容

7:关闭TCP连接

      一般情况下,一旦服务器向客户端返回了请求数据,它就要关闭TCP连接,然后如果客户端或者服务器在其头信息加入了Connection:keep-alive,TCP连接在发送后将仍然保持打开状态,于是客户端可以继续通过相同的连接发送请求。即3-6步骤可以反复进行。保持连接节省了为每个请求建立连接所需的时间,节约了网络带宽。
 

RPC(Remote Procedure Call 远程过程调用),是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络的技术

一次完整的RPC同步调用流程

1:服务消费方(client)以本地调用方式调用客户端存根

2:客户端存根:远程方法在本地模拟对象,一样的也有方法名,方法参数client stub接收到调用后负责将方法名,方法参数等包装,并将包装后的信息通过网络发送到服务端

3:服务端收到消息后,交给代理存根在服务器的部分后进行解码为实际的方法名和参数

4:server stub根据解码结果调用服务器上本地的实际服务

5:本地服务执行并将结果返回给server stub

6:server stub将返回结果打包成消息并发送至消费方

7:client stub接收到消息,并进行解码

8:服务消费方得到最终结果

RPC框架的目标就是要中间步骤都封装起来。让远程方法调用的时候感觉到就像在本地调用一样

Dubbo是一个典型的RPC运用

服务容器负责启动,加载,运行服务提供者

服务提供者在启动时,向注册中心注册自己提供的服务

服务消费者在启动时,向注册中心订阅自己所需的服务

注册中心返回服务提供者地址列表给消费者,如果有变更注册中心将基于长连接推送变更数据给消费者

服务消费者从提供者地址列中,基于负载均衡算法,选一台提供者进行调用,如果调用失败,再选另一条调用

服务消费者和提供者,在内存中累计调用次数和调用时间,定时每分钟发送一次统计数据到监控中心