首页 > 其他分享 >【学习笔记】透视HTTP协议(六):发起请求后,处理流程是怎么样子的?

【学习笔记】透视HTTP协议(六):发起请求后,处理流程是怎么样子的?

时间:2024-06-14 21:32:40浏览次数:23  
标签:缓存 浏览器 请求 透视 笔记 域名 服务器 HTTP

  本文是一篇学习笔记,学习的课程是极客时间的《透视HTTP协议》。

透视HTTP协议_HTTP_HTTPS-极客时间 (geekbang.org)

本文主要描述发起请求后,具体的处理过程。

目录

一、简述浏览器HTTP请求过程

二、详述浏览器HTTP请求过程


一、简述浏览器HTTP请求过程

示例:在Chrome浏览器的地址栏里输入“http://127.0.0.1/”,再按下回车键。

  1. 浏览器从地址栏的输入中获得服务器的IP地址和端口号;

  2. 浏览器用TCP的三次握手与服务器建立连接;

  3. 浏览器向服务器发送拼好的报文;

  4. 服务器收到报文后处理请求,同样拼好报文再发给浏览器;

  5. 浏览器解析报文,渲染输出页面。

注意:第1个步骤中,如果地址栏输入的是域名,浏览器会发起域名解析动作,通过访问一系列的域名解析服务器,试图把这个域名翻译成TCP/IP协议里的IP地址。

域名解析的过程可以看上一篇文章。

二、详述浏览器HTTP请求过程

真实的互联网世界是怎么样子的?可以看下面这张图:

网络处理过程如下:

1、如果上网用的是电脑台式机,那么可能会使用带水晶头的双绞线连上网口,由交换机接入固定网络;如果上网用的是手机、平板电脑,那么可能会通过蜂窝网络、WiFi,由电信基站、无线热点接入移动网络。

2、接入网络的同时,网络运行商会给上网的设备分配一个IP地址,这个地址可能是静态分配的,也可能是动态分配的。静态IP就始终不变,动态IP可能下次上网就变了。

3、假设要访问的是Apple网站,在浏览器里使用域名“www.apple.com”访问,这时浏览器会发起域名解析动作。

4、DNS协议开始从操作系统、本地DNS、根DNS、顶级DNS、权威DNS的层层解析,当然这中间有缓存,可能不需要层层解析就可以拿到IP地址。

5、但是互联网上还有另外一个重要的角色CDN,它也会在DNS的解析过程中“插上一脚”。DNS解析可能会给出CDN服务器的IP地址,这样拿到的就会是CDN服务器而不是目标网站的实际地址。因为CDN会缓存网站的大部分资源,比如图片、CSS样式表,所以有的HTTP请求就不需要再发到Apple,CDN就可以直接响应你的请求,把数据发给你。

6、但是由于PHP、Java等后台服务动态生成的页面属于“动态资源”,CDN无法缓存,只能从目标网站获取。于是你发出的HTTP请求就要开始在互联网上的“漫长跋涉”,经过无数的路由器、网关、代理,最后到达目的地:目标服务器。

7、目标网站的服务器对外表现的是一个IP地址,但为了能够扛住高并发,在内部也是一套复杂的架构。通常在服务器的入口是负载均衡设备,例如四层的LVS或者七层的Nginx,在后面是许多的服务器,构成一个更强更稳定的集群。

8、负载均衡设备会先访问系统里的缓存服务器,通常有memory级缓存Redis和disk级缓存Varnish,它们的作用与CDN类似,不过是工作在内部网络里,把最频繁访问的数据缓存几秒钟或几分钟,减轻后端应用服务器的压力。

9、如果缓存服务器里也没有,那么负载均衡设备就要把请求转发给应用服务器了。这里就是各种开发框架大显神通的地方了,例如Java的Tomcat/Netty/Jetty,Python的Django,还有PHP、Node.js、Golang等等。它们又会再访问后面的MySQL、PostgreSQL、MongoDB等数据库服务,实现用户登录、商品查询、购物下单、扣款支付等业务操作,然后把执行的结果返回给负载均衡设备,同时也可能给缓存服务器里也放一份。

10、应用服务器的输出到了负载均衡设备这里,请求的处理就算是完成了,就要按照原路再走回去,还是要经过许多的路由器、网关、代理。如果这个资源允许缓存,那么经过CDN的时候它也会做缓存,这样下次同样的请求就不会到达源站了。

11、最后网站的响应数据回到了你的设备,它可能是HTML、JSON、图片或者其他格式的数据,需要由浏览器解析处理才能显示出来,如果数据里面还有超链接,指向别的资源,那么就又要重走一遍整个流程,直到所有的资源都下载完。

敲黑板:

建立TCP连接后会顺序收发数据,请求方和应答方都必须依据HTTP规范构建和解析报文;

为了减少响应时间,整个过程中的每一个环节都会有缓存,能够实现“短路”操作;

题外话:

这一节课里讲的都是正常的请求处理流程,如果是一个不存在的域名,那么浏览器的工作流程会是怎么样的呢?

  1. 用户输入与URL检查:用户在地址栏按下回车,浏览器检查输入的字符串是否符合URL规则,并尝试组装完整的URL
  2. 查找缓存:浏览器首先会检查自身的缓存,看看是否有之前对该域名的解析记录。如果没有,则会继续查找系统缓存,然后是hosts文件等。
  3. 域名解析
    • 如果在缓存中没有找到对应的记录,浏览器会开始域名解析过程。
    • 本地域名服务器会先查询本地的缓存,如果没有该纪录项,则会把请求发给根域名服务器[2]。
    • 逐级查询,直到找到正确的纪录或确定该域名不存在。
  4. 返回错误信息:如果经过上述步骤后,浏览器确定域名不存在,它通常会返回一个错误页面。在Chrome浏览器中,这个错误通常是“ERR_CONNECTION_ABORTED”。

这个过程可能会因为网络状况、浏览器设置、缓存情况等因素而有所不同。此外,对于不存在的域名,浏览器可能还会执行一些额外的操作,比如尝试重定向、触发某些安全策略等。

标签:缓存,浏览器,请求,透视,笔记,域名,服务器,HTTP
From: https://blog.csdn.net/MAOZI8/article/details/139652074

相关文章

  • java多线程学习笔记——“并发提高效率”
    java的内存分配与管理如果要学习多线程,我们必须先对java的内存分配和管理有一定的了解java的分区包括:程序计数器、Java虚拟机栈、本地方法栈、Java堆、方法区、运行时常量池这几个部分。栈区栈区有以下几个特点:1、线程私有,每个线程都会拥有自己的栈2、每个方法在被调用......
  • JDBC学习笔记
    本质由于每一个数据库的底层实现都是不同的,有不同的实现方法,使用起来会比较麻烦。于是就有了SUN公司开发的这一套jdbc的问世。简而言之,jbdc(Java连接数据库)的本质就是接口,让程序员不用关心数据库的具体实现类,只需要针对该接口进行开发即可,接口存在的目的就是解耦合,提高程序的......
  • 利用某些平台(聚合API、百度AI、科大讯飞API)的API接口,利用HTTP协议向服务器发送请求,并
    要使用C语言通过HTTP协议向服务器发送请求并接收响应,你可以使用如libcurl这样的库来发送HTTP请求。libcurl是一个免费且易于使用的客户端URL传输库,支持多种协议,包括HTTP。同时,为了解析服务器响应中的JSON数据,你可以使用cJSON库,这是一个轻量级的JSON解析库。以下是一个简单的示例......
  • http和https的区别是什么
    HTTP(超文本传输协议)和HTTPS(安全超文本传输协议)是互联网上用于传输数据的两种主要协议。它们的主要区别在于数据传输的安全性。1.安全性:-HTTP:不加密,数据以明文形式传输,容易被截获和篡改,因此存在安全风险。-HTTPS:在HTTP的基础上增加了SSL/TLS协议,对数据进行加密,确保数......
  • nginx配置https访问
    1、配置文件内容如下:worker_processes1;events{worker_connections1024;}error_log/tmp/error.loginfo;http{includemime.types;default_typeapplication/octet-stream;log_formatmain'$remote_addr-$remote_user[$time_local]&qu......
  • 计网笔记-第四章:网络层
    第四章重点五类IP地址划分的表格(Ctrl+F查找wiki)例题1:子网划分(查找1111)例题2:子网划分与CIDR(查找2222)链路状态路由(全局路由):Dijkstra(查找Dijkstra)距离向量路由(分布式路由算法):DV(查找4.5.2)第四章复习大纲路由器的结构IP协议(重点)IP报文格式IPv4寻址ICMPDHCP......
  • Dubbo3 服务原生支持 http 访问,兼具高性能与易用性
    作者:刘军作为一款rpc框架,Dubbo的优势是后端服务的高性能的通信、面向接口的易用性,而它带来的弊端则是rpc接口的测试与前端流量接入成本较高,我们需要专门的工具或协议转换才能实现后端服务调用。这个现状在Dubbo3中得到了彻底解决,Dubbo3.3版本的最新triple协议,在持续提......
  • 04《android studio开发实战(第三版)》第七到十章阅读笔记
    第七章:持久化存储本章介绍了SharedPreferences的使用方法,它是一种轻量级的存储方案,用于保存简单的键值对数据,如用户设置和配置。 学习了如何创建SharedPreferences对象,使用getSharedPreferences()方法读取和写入数据,以及如何使用apply()和commit()提交修改。了解了如何在Andro......
  • 硬件开发笔记(十八):核心板与底板之间的连接方式介绍说明:板对板连接器
    前言  核心板与底板之间的连接方式至少就有四种以上,包括且不限于:DIP直插、板对板连接器、邮票孔和金手指。 常用连方式介绍DIP直插  DIP就是以前的元器件封装,直接DIP插入焊接,宿便找了个,如下图:    可以定制自己的,一般来说,没有高速电路问题不大,但是这种方......
  • HTML5笔记
    1.HTML:超文本标记语言3.双标签:成对出现的标签单标签:只有开始标签,没有结束标签edg:换行:水平线:4.VSCode快速生成html骨架:!(英文)+Enter/Tab5.标签之间的两种关系:(1)父子关系(嵌套)(2)兄弟关系(并列)6.标题标签:~特点:(1)独占一行(2)文字加粗(3)字号逐渐减小 ......