iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >怎么使用Performance监控前端性能
  • 607
分享到

怎么使用Performance监控前端性能

2023-06-17 04:06:58 607人浏览 独家记忆
摘要

这篇文章主要介绍“怎么使用PerfORMance监控前端性能”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么使用Performance监控前端性能”文章能帮助大家解决问题。Performance.

这篇文章主要介绍“怎么使用PerfORMance监控前端性能”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么使用Performance监控前端性能”文章能帮助大家解决问题。

Performance.now

Performance是一个做前端性能监控离不开的api,最好在页面完全加载完成之后再使用,因为很多值必须在页面完全加载之后才能得到。最简单的办法是在window.onload事件中读取各种数据。

performance.now()方法返回一个精确到毫秒的 DOMHighResTimeStamp 。

根据 MDN :

这个时间戳实际上并不是高精度的。为了降低像Spectre这样的安全威胁,各类浏览器对该类型的值做了不同程度上的四舍五入处理。(Firefox从Firefox  59开始四舍五入到2毫秒精度)一些浏览器还可能对这个值作稍微的随机化处理。这个值的精度在未来的版本中可能会再次改善;浏览器开发者还在调查这些时间测定攻击和如何更好的缓解这些攻击。

因为,要计算一个函数的执行时间,分别比较函数执行前和执行后的两次 performance.now()的值即可,如下所示:

const t0 = performance.now(); for (let i = 0; i < array.length; i++)  {   // some code } const t1 = performance.now(); console.log(t1 - t0, 'milliseconds');

怎么使用Performance监控前端性能

在这里,我们可以看到 Firefox 中的结果与 Chrome 完全不同。这是因为从版本60开始,Firefox 将performance  API的精度降低到2ms。

performance API 不当当只有返回时间戳这个功能,还有很多实用方法,大家可以根据需要到 MDN 查询相关的文档。

然而,对于我们的用例,我们只想计算单个函数的性能,因此时间戳就足够了。

performance.now() 和 Date.now一样吗?

你可能会想,嘿,我也可以使用Date.now来做?

是的,你可以,但这有缺点。

Date.now返回自Unix纪元(1970-01-01T00:00:00Z)以来经过的时间(以毫秒为单位),并取决于系统时钟。这不仅意味着它不够精确,而且还不总是递增。WEBKit工程师(Tony  Gentilcore)的解释如下:

基于系统时间的日期可能不太会被采用,对于实际的用户监视也不是理想的选择。大多数系统运行一个守护程序,该守护程序定期同步时间。通常每15至20分钟将时钟调整几毫秒。以该速率,大约10秒间隔的1%将是不准确的。

Performance.mark 和  Performance.measure

除了Performance.now函数外,还有一些函数可以让我们度量代码不同部分的时间,并将它们作为性能测试工具(如Webpagetest)中的自定义度量。

Performance.mark

先来看看MDN中关于mark方法的定义:

  • The mark() method creates a timestamp in the browser's performance entry  buffer with the given name.

这段话可以分解出三个关键词。首先timestamp,这里的timestamp指的是高精度时间戳(千分之一毫秒),其次是performance entry  buffer。

performance entry buffer指的是存储performance实例对象的区域,初始值为空。

最后就是given name,表示生成的每一个timestamp都有相应的名称。

所以这句话就可以理解成,在浏览器的performance entry  buffer中,根据名称生成高精度时间戳。也就是很多人说过的**“打点”**。

就像Performance.now一样,此函数的精度分数高达5&micro;s。

performance.mark('name');

标记 的 performance entry将具有以下属性值:

  • entryType - 设置为 "mark".

  • name - 设置为mark被创建时给出的 "name"

  • startTime - 设置为 mark() 方法被调用时的 timestamp 。

  • duration - 设置为 "0" (标记没有持续时间).

Performance.measure

同样先来看看 MDN 上关于 measure 的定义:

这段定义和上面 mark 的定义有些类似,其最核心的不同点在于这句话 between two specified  marks。所以measure是指定两个mark点之间的时间戳。如果说mark可以理解为**"打点"的话,measure就可以理解为"连线"**。

performance.measure(name, startMark, endMark);

计算两个mark之间的时长,创建一个DOMHighResTimeStamp保存在资源缓存数据中,可通过performance.getEntries()等相关接口获取。

  • entryType 为字符串 measure

  • name 为创建时设置的值

  • startTime为调用 measure 时的时间

  • duration为两个 mark 之间的时长

从导航开始测量

performance.measure('measure name');

导航开始到标记

performance.measure('measure name', undefined, 'mark-2');

从标记到标记

performance.measure('measure name', 'mark-1', 'mark-2');

资源性能数据

从 performance entry buffer 获取数据

在上面的函数中,总是提到结果存储在performance entry buffer,但是如何访问其中的内容呢?

performance API有3个函数可以用来访问该数据:

performance.getEntries()

获取一组当前页面已经加载的资源PerformanceEntry对象。接收一个可选的参数options进行过滤,options支持的属性有name,entryType,initiatorType。

let entries = window.performance.getEntries();

performance.getEntriesByName

根据参数name,type获取一组当前页面已经加载的资源数据。name的取值对应到资源数据中的name字段,type取值对应到资源数据中的entryType字段。

let entries = window.performance.getEntriesByName(name, type);

performance.getEntriesByType

根据参数type获取一组当前页面已经加载的资源数据。type取值对应到资源数据中的entryType字段。

var entries = window.performance.getEntriesByType(type);

结合事例:

performance.mark('mark-1'); // some code performance.mark('mark-2') performance.measure('test', 'mark-1', 'mark-2') console.log(performance.getEntriesByName('test')[0].duration);

Console.time

这个  API确实易于使用。当需要统计一段代码的执行时间时,可以使用console.time方法与console.timeEnd方法,其中console.time方法用于标记开始时间,console.timeEnd方法用于标记结束时间,并且将结束时间与开始时间之间经过的毫秒数在控制台中输出。这两个方法的使用方法如下所示。

console.time('test'); for (let i = 0; i < array.length; i++) {   // some code } console.timeEnd('test');

怎么使用Performance监控前端性能

输出的结果与Performance API非常相似。

console.time的优点是易于使用,因为它不需要手动计算两个时间戳之间的差。

减少时间精度

如果在不同的浏览器中使用上面提到的 api 测量函数,你可能会注意到结果是不同的。

这是由于浏览器试图保护用户免受时序攻击(timing attack)和指纹采集(Fingerprinting  ),如果时间戳过于准确,黑客可以使用它们来识别用户。

例如,Firefox等浏览器试图通过将精度降低到2ms(版本60)来防止这种情况发生。

注意事项

现在,我们已经知道了要测量javascript函数的速度所需方法。但是,最好还要避免一些陷阱:

分而治之

开发过程中,我们可能会我发现有些模块执行速度很慢,但是我们不知道具体问题出在哪里。解决一个方法是,使用上面提到的这些函数来测量它,而不是胡乱猜测代码的哪一部分比较慢。

要对其进行跟踪,首先将console.time语句放在执行比较慢的代码块周围。然后测量它们不同部分的表现。如果一个比另一个慢,那就继续往下走,直到发现问题所在。

注意输入值

在实际应用中,给定函数的输入值可能会发生很大变化。仅针对任意随机值测量函数的速度并不能提供我们可以实际使用的任何有价值的数据。

确保使用相同的输入值运行代码。

多次运行该函数

假设你有一个函数,它的功是遍历一个数组,对数组的每个值进行一些计算,然后返回一个带有结果的数组。你想知道是forEach循环还是简单的for循环性能更好。

function testForEach(x) {   console.time('test-forEach');   const res = [];   x.forEach((value, index) => {     res.push(value / 1.2 * 0.1);   });    console.timeEnd('test-forEach')   return res; }  function testFor(x) {   console.time('test-for');   const res = [];   for (let i = 0; i < x.length; i ++) {     res.push(x[i] / 1.2 * 0.1);   }    console.timeEnd('test-for')   return res; }

然后这样测试它们:

const x = new Array(100000).fill(Math.random()); testForEach(x); testFor(x);

如果在 Firefox 中运行上述函数,结果:

怎么使用Performance监控前端性能

看起来forEach慢多了,对吧?

那如果是相同的输入,运行两次呢:

testForEach(x); testForEach(x); testFor(x); testFor(x);

怎么使用Performance监控前端性能

如果我们第二次调用forEach测试,它的执行效果和for循环一样好。考虑到初始值较慢,在一些性能要求极高的项目,可能就不适合使用forEach。

在多个浏览器中测试

如果我们在Chrome中运行上述代码,结果又会不一样:

怎么使用Performance监控前端性能

这是因为Chrome和Firefox具有不同的JavaScript引擎,它们具有不同类型的性能优化

在本例中,Firefox 在对相同输入的forEach进行优化方面做得更好。

for在两个引擎上的性能都更好,因此在一些性能要求极高的项目就需要使用for循环。

这是为什么要在多个引擎中进行测量的一个很好的例子。如果仅使用Chrome进行测量,你可能会得出结论,与for相比,forEach并不那么糟糕。

限制的 CPU

我们在本地测试值是不能代表用户在浏览器使用的情况,因为 我们开发的电脑一般都会比大部分的用户好很多。

浏览器有一个特性可以限制CPU性能,我们通过设置可以更贴切一些真实情况。

关于“怎么使用Performance监控前端性能”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网精选频道,小编每天都会为大家更新不同的知识点。

--结束END--

本文标题: 怎么使用Performance监控前端性能

本文链接: https://www.lsjlt.com/news/287165.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么使用Performance监控前端性能
    这篇文章主要介绍“怎么使用Performance监控前端性能”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么使用Performance监控前端性能”文章能帮助大家解决问题。Performance....
    99+
    2023-06-17
  • ASP Performance Monitor:助您监控系统性能,提升应用效率
    ASP Performance Monitor 是一个用于监控 ASP.NET 应用程序性能的工具,它可以帮助您识别瓶颈并提高应用程序的效率。ASP Performance Monitor 可以监控应用程序的各种性能指标,包括:请求率响应时...
    99+
    2024-02-02
    ASP.NET 性能监控 瓶颈 效率提升
  • Performance内存监控使用技巧详解
    目录Performance介绍使⽤内存问题的具体体现监控内存的⼏种⽅式TimeLinePerformance 介绍 为什么使⽤Performance呢?GC 的⽬的是为了实现内存空间...
    99+
    2024-04-02
  • 怎么使用jmeter监控服务器性能
    要使用JMeter监控服务器性能,可以按照以下步骤操作: 下载和安装JMeter软件,并打开JMeter界面。 添加一个线程...
    99+
    2024-05-08
    jmeter
  • 如何使用linux系统性能监控工具KSysguard监控远端主机
    小编给大家分享一下如何使用linux系统性能监控工具KSysguard监控远端主机,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!KDE System Guard默...
    99+
    2023-06-13
  • 怎么解决的前端异常监控
    这篇文章主要讲解了“怎么解决的前端异常监控”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么解决的前端异常监控”吧!前端监控包括行为监控、异常监控、性能监控...
    99+
    2024-04-02
  • 怎么监控CDN的性能
    监控CDN的性能是十分重要的,可以通过以下方式进行监控: 使用监控工具:可以使用专门的监控工具来监控CDN的性能,例如Pingd...
    99+
    2024-04-24
    CDN
  • js前端埋点监控是什么
    这篇文章主要介绍“js前端埋点监控是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“js前端埋点监控是什么”文章能帮助大家解决问题。一、为什么需要埋点&监控在开始正文之前,我们先想想为什么...
    99+
    2023-07-02
  • Linux性能监控命令free怎么用
    这篇文章将为大家详细讲解有关Linux性能监控命令free怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在Linux系统中可以使用ree命令来定位IO瓶颈,内存使用率高,cpu使用率高等问题,fre...
    99+
    2023-06-28
  • Redis怎么实现性能监控
    本篇内容介绍了“Redis怎么实现性能监控”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!目录redis_exporterprometheus...
    99+
    2023-06-20
  • 怎么优化前端性能
    这篇文章主要讲解了“怎么优化前端性能”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么优化前端性能”吧!一 引发性能问题原因引发性能问题的原因通常不是单方面...
    99+
    2024-04-02
  • 使用Grafana+Prometheus监控mysql服务性能
    Prometheus(也叫普罗米修斯)官网:https://prometheus.io/docs/introduction/overview/ Grafana官网:https://grafana.com/e...
    99+
    2024-04-02
  • stats.js使用性能监控源码解读
    目录1.性能监控2.fps 计算3.ms 每个渲染帧运行需要多少毫秒4.memory 内存占用5.画 Canvas 的板面6.创建 Stats 板面7.使用 Stats总结1.性能监...
    99+
    2023-05-18
    stats.js 性能监控 stats.js源码解读
  • OpenStack高性能监控工具Monasca怎么用
    小编给大家分享一下OpenStack高性能监控工具Monasca怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!介绍Monasca 是一个多租户监控即服务工具...
    99+
    2023-06-17
  • mysql性能测试慢怎么用sql监控
    在MySQL中,可以使用SQL监控工具来监控和诊断性能问题。下面是一些常见的方法:1. 使用MySQL的内置工具:MySQL提供了一...
    99+
    2023-10-23
    mysql sql
  • Linux性能监控之io怎么看
    这篇文章给大家分享的是有关Linux性能监控之io怎么看的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Linux性能监控情况1:同一时间进行大量的I/O操作在这种情况时我们会发现CPU的wa时间百分比会上升,证明...
    99+
    2023-06-16
  • zabbix怎么监控linux磁盘性能
    本篇内容主要讲解“zabbix怎么监控linux磁盘性能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“zabbix怎么监控linux磁盘性能”吧!Zabbix 是一个企业级分布式开源监控解决方案...
    99+
    2023-06-28
  • jmeter怎么监控服务器性能
    要使用JMeter监控服务器性能,可以通过以下步骤来实现: 创建一个JMeter测试计划(Test Plan):在JMeter中...
    99+
    2024-05-08
    jmeter
  • 怎么监控Linux的系统性能
    本篇内容主要讲解“怎么监控Linux的系统性能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么监控Linux的系统性能”吧!Nmon(得名于 Nigel 的监控器)是IBM的员工 Nigel ...
    99+
    2023-06-16
  • 怎么实现一个前端监控回放系统
    本篇内容主要讲解“怎么实现一个前端监控回放系统”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么实现一个前端监控回放系统”吧!1 / 实现方案思路要想给用户的访...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作