监控工具 performance

2024-08-23 01:38
文章标签 工具 监控 performance

本文主要是介绍监控工具 performance,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

监控工具 performance

performance是W3C引入的web API。接口可以获取当前页面中与性能相关的信息。

可以获取的信息:

  1. 白屏时间:从打开网站到有内容渲染出来的时间节点
  2. 首屏时间:首屏内容渲染完毕的时间节点
  3. 用户可操作的时间节点:domready触发节点
  4. 页面总下载时间:window.onload的触发节点
  5. DNS查询时间
  6. TCP链接时间

使用:

  • 可以通过只读属性window.performance获得
  • 可以通过浏览器开发者工具使用

window.performance 属性

查看window.performance,有3个属性:

在这里插入图片描述

memory 内存

包含此刻内存占用的情况,包含3个属性

  • jsHeapSizeLimit 上下文可用堆内存的上限(最大体积,已字节计算)
  • totalJSHeapSize 已分配的堆内存大小(可使用的内存)
  • usedJSHeapSize 当前JS活动对象占用的内存,如果大于totalJSHeapSize可能存在了内存泄漏,所以不允许大于totalJSHeapSize

MDN:“它是 Chrome 添加的一个非标准扩展,这个属性提供了一个可以获取到基本内存使用情况的对象。不应该使用这个非标准的 API。”

navigation 页面的来源信息

提供了在指定的时间段里发生的操作相关信息,包括页面是加载还是刷新、发生了多少次重定向等等

只有两个属性:

  • type 标志页面导航类型
type常数枚举值描述
TYPE_NAVIGATE0普通进入,包括:点击链接、在地址栏中输入 URL、表单提交、或者通过除下表中 TYPE_RELOAD 和 TYPE_BACK_FORWARD 的方式初始化脚本。
TYPE_RELOAD1通过刷新进入,包括:浏览器的刷新按钮、快捷键刷新、location.reload()等方法。
TYPE_BACK_FORWARD2通过操作历史记录进入,包括:浏览器的前进后退按钮、快捷键操作、history.forward()、history.back()、history.go(num)。
TYPE_UNDEFINED255其他非以上类型的方式进入。
  • redirectCount 表示到达最终页面前,重定向的次数,但是这个接口有同源策略限制,即仅能检测同源的重定向。

timing 关键时间点

包含延迟相关的性能信息

从输入url到用户可以使用页面的全过程时间统计,会返回一个PerformanceTiming对象,单位均为毫秒

在这里插入图片描述

w3c 文档

  • navigationStart:浏览器 unload 前一个页面文档(document)的开始时间节点。如果没有之前的页面,此属性的值等于 fetchStart

    例如当前在浏览baidu.com,在地址栏输入google.com并回车

    浏览器执行的动作依次为:unload 当前文档(baidu.com) -> 请求下一个文档(google.com)

    navigationStart 的值就是触发unload当前文档的时间节点。

  • redirectStartredirectEnd: 如果在导航时存在HTTP重定向或等效内容(页面由redirect而来),并且所有重定向或等效内容都来自同一个原点,则 redirectStartredirectEnd 分别代表redirect开始和结束的时间节点,否则值为0。

  • unloadEventStartunloadEventEnd:如果先前文档和当前文档具有相同的来源(同一个域),则 unloadEventStartunloadEventEnd 分别代表浏览器unload先前文档的开始和结束时间节点。否则两者都等于0。

  • fetchStart:是指在浏览器发起任何请求之前的时间值。在fetchStartdomainLookupStart 之间,浏览器会检查当前文档的缓存。

  • domainLookupStartdomainLookupEnd:分别代表DNS查询的开始和结束时间节点。如果浏览器没有进行DNS查询(比如使用了cache),则两者的值都等于 fetchStart

  • connectStartconnectEnd:分别代表TCP建立连接和连接成功的时间节点。如果浏览器没有进行TCP连接(比如使用持久化连接 webscoket、使用缓存或本地资源),则两者都等于 domainLookupEnd

  • secureConnectionStart:可选。如果页面使用HTTPS,它的值是安全连接握手之前的时刻。如果该属性不可用,则返回 undefined。如果该属性可用,但没有使用HTTPS,则返回0。

  • requestStart:代表浏览器发起请求的时间节点,请求的方式可以是请求服务器、缓存、本地资源等。如果发送请求后传输连接失败,并且浏览器重新打开连接并重新发送请求,则 requestStart 返回新请求的值。

  • responseStartresponseEnd:分别代表浏览器收到从服务器端(或缓存、本地资源)收到响应的第一个字节 和 最后一个字节数据(或关闭传输连接之前,以先到者为准)的时刻。

  • domLoading:当浏览器将 document.readyState 设置为 loading 的时间节点,也就是浏览器开始解析html文档的时间节点。

  • domInteractive:当浏览器将 document.readyState 设置为 interactive 的时间节点。domInteractive 并非 DOMReady,它早于 DOMReady 触发,代表html文档解析完毕(即dom tree创建完成)但是内嵌资源(比如外链css、js等)还未加载的时间点。

  • domContentLoadedEventStart:代表 DOMContentLoaded 事件触发的时间节点。

    MDN:当初始的 HTML 文档被完全加载和解析完成之后,DOMContentLoaded 事件被触发,而无需等待样式表、图像和子框架的完全加载。

  • domContentLoadedEventEnd:代表 DOMContentLoaded 事件完成的时间节点,此刻用户可以对页面进行操作,也就是jQuery中的domready时间。

  • domComplete:html文档完全解析完毕的时间节点。

  • loadEventStartloadEventEnd:分别代表 load 事件触发和结束的时间节点。当未触发load 事件时,值为 0,当未完成 load 事件时 loadEventEnd 为 0 。

相关时间计算

  • DNS查询耗时 = domainLookupEnd - domainLookupStart
  • TCP链接耗时 = connectEnd - connectStart
  • request请求耗时 = responseEnd - responseStart
  • 解析dom树耗时 = domComplete - domInteractive
  • 白屏时间 = domloading - fetchStart
  • domready可操作时间 = domContentLoadedEventEnd - fetchStart
  • onload总下载时间 = loadEventEnd - fetchStart

window.performance API

window.performance 的原型 Performance 提供了一些API。MDN 文档

getEntrires()

window.performance.getEntries() 可以用来统计静态资源相关的时间信息。

它返回一个 PerformanceEntry 对象列表。

每个 PerformanceEntry 对象代表 performance 时间列表中的单个指标数据(performance metric),例如静态资源加载信息。

PerformanceEntry 可以在应用运行过程中通过手动创建(例如调用performance.mark()),此外在加载资源(例如图片、script、css等)时,也会被动生成。

PerformanceEntry 属性:

  • name:该 PerformanceEntry 的名字
    • 如果是加载资源(PerformanceResourceTiming)生成的,就是资源url
    • 或者是调用performance.mark(name)传入的名字
  • entryType:类型,PerformanceEntry 的类型及对应的entryType:
    • PerformanceNavigationTiming -> navigation
    • PerformancePaintTiming -> paint
    • PerformanceResourceTiming -> resource
    • PerformanceMark -> mark
    • PerformanceFrameTiming -> frame
    • PerformanceMeasure -> measure
  • startTime:指标上报时的时间
  • duration:请求花费的时间
  • 以及其他与 window.performance.timing 一样的属性(PerformancePaintTiming除外)

这篇关于监控工具 performance的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1097985

相关文章

基于Python开发Windows自动更新控制工具

《基于Python开发Windows自动更新控制工具》在当今数字化时代,操作系统更新已成为计算机维护的重要组成部分,本文介绍一款基于Python和PyQt5的Windows自动更新控制工具,有需要的可... 目录设计原理与技术实现系统架构概述数学建模工具界面完整代码实现技术深度分析多层级控制理论服务层控制注

基于Go语言开发一个 IP 归属地查询接口工具

《基于Go语言开发一个IP归属地查询接口工具》在日常开发中,IP地址归属地查询是一个常见需求,本文将带大家使用Go语言快速开发一个IP归属地查询接口服务,有需要的小伙伴可以了解下... 目录功能目标技术栈项目结构核心代码(main.go)使用方法扩展功能总结在日常开发中,IP 地址归属地查询是一个常见需求:

使用python制作一款文件粉碎工具

《使用python制作一款文件粉碎工具》这篇文章主要为大家详细介绍了如何使用python制作一款文件粉碎工具,能够有效粉碎密码文件和机密Excel表格等,感兴趣的小伙伴可以了解一下... 文件粉碎工具:适用于粉碎密码文件和机密的escel表格等等,主要作用就是防止 别人用数据恢复大师把你刚删除的机密的文件恢

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

springboot2.1.3 hystrix集成及hystrix-dashboard监控详解

《springboot2.1.3hystrix集成及hystrix-dashboard监控详解》Hystrix是Netflix开源的微服务容错工具,通过线程池隔离和熔断机制防止服务崩溃,支持降级、监... 目录Hystrix是Netflix开源技术www.chinasem.cn栈中的又一员猛将Hystrix熔

MySQL慢查询工具的使用小结

《MySQL慢查询工具的使用小结》使用MySQL的慢查询工具可以帮助开发者识别和优化性能不佳的SQL查询,本文就来介绍一下MySQL的慢查询工具,具有一定的参考价值,感兴趣的可以了解一下... 目录一、启用慢查询日志1.1 编辑mysql配置文件1.2 重启MySQL服务二、配置动态参数(可选)三、分析慢查

基于Python实现进阶版PDF合并/拆分工具

《基于Python实现进阶版PDF合并/拆分工具》在数字化时代,PDF文件已成为日常工作和学习中不可或缺的一部分,本文将详细介绍一款简单易用的PDF工具,帮助用户轻松完成PDF文件的合并与拆分操作... 目录工具概述环境准备界面说明合并PDF文件拆分PDF文件高级技巧常见问题完整源代码总结在数字化时代,PD

Python按照24个实用大方向精选的上千种工具库汇总整理

《Python按照24个实用大方向精选的上千种工具库汇总整理》本文整理了Python生态中近千个库,涵盖数据处理、图像处理、网络开发、Web框架、人工智能、科学计算、GUI工具、测试框架、环境管理等多... 目录1、数据处理文本处理特殊文本处理html/XML 解析文件处理配置文件处理文档相关日志管理日期和

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi