Chrome 网络调试程序 谷歌网络调试 network

目录

  • 1.网络面板总览
  • 2.概况了解
  • 3.Waterfall接口排队等待时间
  • 4.关注请求接口的Size,可能是占据内存溢出的接口
  • 5.过滤器一栏 fetch/xhr 什么意思
  • 6. Stalled 什么意思
  • 7.Queueing 什么意思
  • 8.Queueing和Stalled之间什么关系
  • 9.为什么会有阻塞状态
  • 10.Time列是pending 什么意思

1.网络面板总览

网络面板包括如下5个窗口:

  1. 控件 使用这些功能控制网络面板的展示和功能
  2. 过滤器 使用过滤器可以控制要在列表中显示哪些网络请求。摁住Cmd(Mac)或者Ctrl(Window)键,可以同时选择多个筛选条件。
  3. 概览 此图表显示了资源加载的时间线。如果在垂直方向上很多时间线重合,说明加载这些资源是同时进行的,有时序上的重叠。
  4. 请求列表 请求列表列举了捕获到的所有网络请求,默认以时间排序,最近的请求在最上面。点击请求的名字会显示网络请求的详情。在列表头上右击,可以添加或者删除要显示的列。
  5. 概要 该窗口显示请求的总数,数据传输量以及加载时间
    在这里插入图片描述

2.概况了解

在这里插入图片描述

3.Waterfall接口排队等待时间

在这里插入图片描述

4.关注请求接口的Size,可能是占据内存溢出的接口

在这里插入图片描述

5.过滤器一栏 fetch/xhr 什么意思

在前端浏览器调试的过程中,“Network”(网络)面板是一个非常重要的工具,它用于监视浏览器与服务器之间的网络通信。在这个面板中,你会看到各种类型的网络请求,包括 fetch 请求和 XHR 请求。

  1. XHR 请求:XHR(XMLHttpRequest)是一种用于在浏览器和服务器之间发送 HTTP 请求和接收响应的技术。XHR 请求通常由 JavaScript 代码触发,它们可以是同步或异步的,用来获取数据或更新页面的部分内容。在 “Network” 面板中,XHR 请求会以 XHR 类型显示,你可以查看请求的详细信息,包括请求方法、URL、请求头、响应状态等。

  2. Fetch 请求:Fetch API 是一种现代的 Web API,用于在浏览器中发起网络请求。它提供了更灵活和强大的方式来处理网络请求和响应。Fetch 请求通常由 JavaScript 代码触发,用来获取数据、发送表单、上传文件等。在 “Network” 面板中,Fetch 请求会以 fetch 类型显示,你可以查看请求的详细信息,包括请求方法、URL、请求头、响应状态等。

通过查看 “Network” 面板中的 fetch 和 XHR 请求,你可以分析网页的性能、调试网络问题、监视资源加载情况,以及分析网站的行为。

6. Stalled 什么意思

“Stalled”(阻塞)是指网络请求在某个阶段被阻塞而无法继续进行的状态。在网络调试工具的 Waterfall 视图中,当一个请求处于 Stalled 状态时,意味着该请求在某个阶段被阻塞,无法继续执行,直到解除阻塞为止。

常见导致请求被阻塞的原因包括:

  1. 网络连接问题:例如网络延迟、网络拥塞等,导致请求无法及时发送或接收。

  2. 服务器响应缓慢:服务器处理请求的时间过长,导致响应延迟,请求处于等待响应阶段。

  3. 资源竞争:当浏览器同时发起多个请求,而服务器资源有限时,可能导致部分请求被阻塞等待处理。

  4. 同一域名并发连接限制:浏览器对于同一域名下的并发连接数有限制,当已有连接数达到限制时,后续请求可能被阻塞等待。

当请求处于 Stalled 状态时,通常需要进一步分析具体原因,并采取相应措施来解决问题,以提高页面加载速度和性能。

7.Queueing 什么意思

“Queueing”(排队)是指网络请求在等待发送或处理时被放置在队列中的状态。在网络调试工具的 Waterfall 视图中,当一个请求处于 Queueing 状态时,意味着该请求已经准备就绪,但由于某些原因(通常是因为浏览器并发连接数限制或服务器处理能力限制),无法立即发送或处理,而是被放置在请求队列中等待执行。

常见导致请求被放置在队列中的原因包括:

  1. 并发连接数限制:浏览器对于同一域名或同一服务器的并发连接数有限制,当已有连接数达到限制时,后续请求就会被放置在队列中等待。

  2. 服务器处理能力限制:服务器在处理请求时可能存在处理能力限制,当服务器已经处理的请求达到其处理能力上限时,后续请求就会被放置在队列中等待处理。

  3. 请求优先级:一些请求可能会被设置为优先级较低,因此会被放置在队列中等待更高优先级的请求处理完成后再执行。

  4. TCP 连接复用:在 HTTP/1.1 中,浏览器可能会通过 TCP 连接复用来发送多个请求,而在某些情况下,请求需要等待上一个请求的 TCP 连接空闲时才能发送。

当请求处于 Queueing 状态时,可能会导致页面加载速度变慢,因此需要进一步分析和优化,以提高请求的发送和处理效率。

8.Queueing和Stalled之间什么关系

“Queueing”(排队)和"Stalled"(阻塞)是网络请求在加载过程中可能出现的两种状态,它们之间有一定的关系:

  1. 队列和阻塞之间的关系

    • 当一个请求处于"Queueing"状态时,意味着该请求已经准备就绪,但由于某些原因无法立即发送或处理,而是被放置在请求队列中等待执行。
    • 如果在请求处于排队状态时,遇到了一些无法继续执行的问题,比如网络连接问题、服务器响应缓慢等,那么该请求可能会从队列状态转变为"Stalled"状态,表示请求在某个阶段被阻塞,无法继续执行。
  2. 排队可能导致阻塞

    • 当有大量请求被放置在队列中等待发送或处理时,可能会导致服务器响应缓慢或浏览器并发连接数限制,从而使得一些请求在队列中等待的时间过长,最终进入阻塞状态。
    • 因此,排队和阻塞之间存在一种因果关系,即长时间的排队可能会导致请求的阻塞。
  3. 解决方法

    • 对于排队状态的请求,可以通过优化资源加载顺序、减少资源大小、增加服务器处理能力等方式来缩短排队时间,从而减少阻塞的可能性。
    • 对于阻塞状态的请求,需要进一步分析具体原因,并采取相应的措施来解决,以提高请求的发送和处理效率,从而缩短请求的阻塞时间。

综上所述,排队和阻塞是网络请求在加载过程中常见的两种状态,它们之间存在一定的关系,但又有一些区别,需要根据具体情况进行分析和处理。

9.为什么会有阻塞状态

在实际情况中,当一个请求在排队状态下等待发送或处理的时间超过一定阈值时,可能会转变为阻塞状态,直到满足发送或处理的条件才能继续执行。这种转变通常是由于排队时间过长导致请求无法及时得到响应或处理而造成的。

一旦请求处于阻塞状态,它需要等待唤醒或满足某些条件(比如网络连接恢复、服务器响应就绪等)才能继续发送或处理。一旦条件得到满足,请求就会被唤醒并继续执行,从而结束阻塞状态。

因此,排队时间过长可能会导致请求进入阻塞状态,而这种阻塞状态会一直持续到满足发送或处理条件为止。优化请求的排队时间和处理速度,可以有效减少请求进入阻塞状态的可能性,提高网络性能和用户体验。

10.Time列是pending 什么意思

当时间(Time)列显示为"pending"时,通常表示该请求正在等待被处理或执行,但尚未完成。这意味着请求已经发送给服务器或正在服务器上执行,但还没有返回结果或完成处理。

在这种情况下,"pending"表示请求处于一个中间状态,正在等待系统或服务器的进一步响应或处理。可能的原因包括网络延迟、服务器负载、资源竞争等。

一般情况下,一段时间后,"pending"状态会转变为已完成(completed)或者出现错误(error),具体取决于请求的执行结果。如果请求长时间处于"pending"状态,可能需要进一步检查网络连接、服务器状态以及请求本身是否存在问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/2980146.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

实现Spring底层机制(二)

文章目录 阶段2—封装bean定义信息到Map1.代码框架图2.代码实现1.文件目录2.新增注解Scope存储单例或多例信息Scope.java3.修改MonsterService.java指定多例注解4.新增bean定义对象存储bean定义信息BeanDefinition.java5.修改pom.xml增加依赖6.修改容器实现bean定义信息扫描Sun…

基于Vue+ElementPlus自定义带历史记录的搜索框组件

前言 基于Vue2.5ElementPlus实现的一个自定义带历史记录的搜索框组件 效果如图: 基本样式: 获取焦点后: 这里的历史记录默认最大存储10条,同时右侧的清空按钮可以清空所有历史记录。 同时搜索记录也支持点击搜索,按…

Linux给磁盘扩容(LVM方式)

Linux给磁盘扩容(LVM方式) 最近测试性能,在本地打数据时,发现磁盘空间不足,于是想手动给/挂载点添加空间。这里介绍通过LVM方式快速给磁盘扩容。 LVM:是一种技术,方便管理磁盘。如果不用LVM,那…

springboot2集成东方通tongweb嵌入式版

由于最近项目需要国产化信创改造,引入东方通tongweb 联系东方通厂家 ,将依赖导入到maven仓库,并获取嵌入式版license文件修改pom.xml,引入依赖,注意springboot版本,这里以springboot2举例 首先移除springb…

Xinlinx FPGA内的存储器BRAM全解

目录 一、总体概述1.7系列FPGA的BRAM特点2.资源情况 二、BRAM分类1.单端口RAM2.简单双端口RAM3.真双端口RAM 三、BRAM的读写1、Primitives Output Registers读操作注意事项2.三种写数据模式(1)Write_First(2)Read_First&#xff0…

【学习】软件测试自动化,是未来的趋势还是当前的必需

在当今快速迭代的软件开发周期中,速度和质量成为了企业生存的关键。随着DevOps实践的普及和持续集成/持续部署(CI/CD)流程的标准化,软件测试自动化已经从未来的趋势转变为当前的必要性。本文将探讨自动化测试的现状、必要性以及其…

大模型训练及推理【硬件选型指南】及 GPU 通识

我们在做大模型应用部署时(如训练、微调、RAG),往往需要在前期就分析好硬件选型指标,或者我们给客户报方案之前,可能你已经有了一个方案,但是由于实践经验缺乏,不知道在硬件上该如何评估并上报。…

invidia-smi占用显存,无法显示PID

如果是动用了子线程创建进程,比如利用accelerate训练脚本,那么大概率可以通过这种方式解决:nvidia-smi没有进程,但是显存占用_nvidia-smi有的卡是0%-CSDN博客 如果这种方法不可用,请尝试直接查询所有python进程&#x…

react v18 项目初始化

按照以下命令进行傻瓜式操作即可: 全局安装脚手架工具: npm install -g create-react-app创建项目my-react-app: create-react-app my-react-app安装 antd: yarn add antd安装 react-router-dom: yarn add react-router-dom启动项…

[Qt的学习日常]--初识Qt

前言 作者:小蜗牛向前冲 名言:我可以接受失败,但我不能接受放弃 如果觉的博主的文章还不错的话,还请点赞,收藏,关注👀支持博主。如果发现有问题的地方欢迎❀大家在评论区指正 目录 一、Qt的基本…

鸿蒙(HarmonyOS)性能优化实战-多线程共享内存

概述 在应用开发中,为了避免主线程阻塞,提高应用性能,需要将一些耗时操作放在子线程中执行。此时,子线程就需要访问主线程中的数据。ArkTS采用了基于消息通信的Actor并发模型,具有内存隔离的特性,所以跨线…

4.23日总结(项目总结)

1.项目: 今日项目通过一个在登录界面的一个静态变量,完成了区分老师和学生,能够分开老师和学生,并且不同身份的人进去会有不同的显示,以及登录链接主界面,还有学生和老师的不同的表,其次就是创…

葡萄书--关系图卷积神经网络

异质图和知识图谱 同质图与异质图 同质图指的是图中的节点类型和关系类型都仅有一种 异质图是指图中的节点类型或关系类型多于一种 知识图谱 知识图谱包含实体和实体之间的关系&#xff0c;并以三元组的形式存储&#xff08;<头实体, 关系, 尾实体>&#xff0c;即异…

用Excel做一个功能完备的仓库管理系统

1 基本设计思路 用到的Excel技术&#xff1a;sumif, vlookup, 表格(table)。基本思路&#xff1a;在有基础的商品、仓库等信息的情况下&#xff0c;对商品的每一个操作都有对应的单据&#xff0c;然后再汇总统计。标识&#xff1a;为了在不同的维度统计数量&#xff0c;各单据…

Abaqus2024 安装教程(附免费安装包资源)

鼠标右击软件压缩包&#xff0c;选择“解压到Abaqus2024”。 鼠标右击“此电脑”&#xff0c;选择“属性”。 点击“高级系统设置”。 点击“环境变量”。 点击“新建”。 变量名输入&#xff1a;NOLICENSECHECK 变量值输入&#xff1a;true 然后点击“确定”。 点击“确定”。…

羊大师解析,夏日消暑羊奶来帮忙

羊大师解析&#xff0c;夏日消暑羊奶来帮忙 炎炎夏日&#xff0c;烈日当空&#xff0c;人们总是寻找各种方式来消暑降温。除了常见的冷饮、空调等&#xff0c;其实还有一种天然、健康的饮品可以帮助我们度过酷暑——那就是羊奶。 羊奶作为一种营养丰富的天然饮品&#xff0c;不…

【git】多仓库开发

通常我们习惯了在单个仓库下多分支开发&#xff0c;最近用了多仓库开发&#xff0c;我拿一个开源项目举例&#xff0c;总结一下基本流程。 1.fork项目到自己仓库 2.把自己仓库项目pull到本地 3.在本地新建开发分支 git checkout -b dev 4.修改/添加分支对应的远程仓库 修…

小案例:ToolBar+选项菜单

使用选项菜单&#xff0c;一般是用于做单选&#xff0c;需要重写方法&#xff1a; public boolean onCreateOptionsMenu(Menu menu) 如果想要实现事件监听&#xff0c;则采用基于回调的事件监听机制&#xff0c;可以监听到具体是哪一项被选中。即重写方法&#xff1a; publi…

Kafka学习笔记(二、linux和docker安装及使用demo)

1.安装启动 1.1.下载解压 官网下载地址将下载的tar包上传到服务器一个目录&#xff0c;然后解压$ tar -xzf kafka_2.13-3.7.0.tgz $ cd kafka_2.13-3.7.01.2. 启动环境 需安装Jdk8&#xff0c;Kafka可以使用ZooKeeper或KRaft启动。 ZooKeeper启动 运行如下命令&#xff0c;…

windows系统下python开发工具安装

一. 简介 前一篇文章学习了安装 python解释器&#xff0c;文章如下&#xff1a; windows系统下python解释器安装-CSDN博客 本文来学习如何下载安装 python开发工具 PyCharm。 二. python开发工具 PyCharm下载安装 1. PyCharm官网 PyCharm开发工具 PyCharm为 python代码…