CN114117289A - 浏览器运行数据的获取方法、装置及电子设备 - Google Patents

浏览器运行数据的获取方法、装置及电子设备 Download PDF

Info

Publication number
CN114117289A
CN114117289A CN202111248539.5A CN202111248539A CN114117289A CN 114117289 A CN114117289 A CN 114117289A CN 202111248539 A CN202111248539 A CN 202111248539A CN 114117289 A CN114117289 A CN 114117289A
Authority
CN
China
Prior art keywords
event
executed
browser
under
bound
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN202111248539.5A
Other languages
English (en)
Inventor
谢郁
侯园梅
王勇
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Beijing Baidu Netcom Science and Technology Co Ltd
Original Assignee
Beijing Baidu Netcom Science and Technology Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Beijing Baidu Netcom Science and Technology Co Ltd filed Critical Beijing Baidu Netcom Science and Technology Co Ltd
Priority to CN202111248539.5A priority Critical patent/CN114117289A/zh
Publication of CN114117289A publication Critical patent/CN114117289A/zh
Priority to EP22203836.6A priority patent/EP4160421A1/en
Priority to US18/049,721 priority patent/US20230065492A1/en
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/542Event management; Broadcasting; Multicasting; Notifications
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/958Organisation or management of web site content, e.g. publishing, maintaining pages or automatic linking
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3409Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment
    • G06F11/3419Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment by assessing time
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/3003Monitoring arrangements specially adapted to the computing system or computing system component being monitored
    • G06F11/3006Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system is distributed, e.g. networked systems, clusters, multiprocessor systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/3003Monitoring arrangements specially adapted to the computing system or computing system component being monitored
    • G06F11/302Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system component is a software system
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3409Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment
    • G06F11/3419Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment by assessing time
    • G06F11/3423Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment for performance assessment by assessing time where the assessed time is active or idle time
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3466Performance evaluation by tracing or monitoring
    • G06F11/3495Performance evaluation by tracing or monitoring for systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2201/00Indexing scheme relating to error detection, to error correction, and to monitoring
    • G06F2201/81Threshold
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2201/00Indexing scheme relating to error detection, to error correction, and to monitoring
    • G06F2201/835Timestamp
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2201/00Indexing scheme relating to error detection, to error correction, and to monitoring
    • G06F2201/86Event-based monitoring
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2201/00Indexing scheme relating to error detection, to error correction, and to monitoring
    • G06F2201/865Monitoring of software

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Quality & Reliability (AREA)
  • Computing Systems (AREA)
  • Computer Hardware Design (AREA)
  • Mathematical Physics (AREA)
  • Software Systems (AREA)
  • Databases & Information Systems (AREA)
  • Multimedia (AREA)
  • Data Mining & Analysis (AREA)
  • Debugging And Monitoring (AREA)

Abstract

本公开提供了浏览器运行数据的获取方法,涉及数据处理技术领域,尤其涉及大数据、信息流等领域。具体实现方案为:接收到事件触发请求后,在确定待执行的事件与回调函数绑定的情况下,将待执行的事件与预设的事件监控函数绑定,之后,在获取执行事件监控函数的第二时刻后,即可根据第二时刻与第一时刻间的时间间隔,确定浏览器在待执行的事件下的响应时长。由此,通过将待执行的事件与事件监控函数进行绑定,从而提升了对各个页面事件的执行时长进行监控的准确性,进而提升了对浏览器性能监控的准确性,通过对待执行事件进行监控,增加了对浏览器监控的场景,从而增加了对浏览器性能监控的全面性。

Description

浏览器运行数据的获取方法、装置及电子设备
技术领域
本公开涉及数据处理技术领域,尤其涉及大数据、信息流、云服务等领域,具体涉及浏览器运行数据的获取方法、装置及电子设备。
背景技术
随着计算机技术和互联网技术的发展,人们对互联网产品的性能要求越来越高。相关技术中,通常是基于浏览器的加载速度,来衡量浏览器性能,但是这种衡量浏览器性能的方式,依据的运行数据单一,因此,如何准确确定浏览器的性能是亟待解决的问题。
发明内容
本公开提供了一种浏览器运行数据的获取方法和装置。
根据本公开的一方面,提供了一种浏览器运行数据的获取方法,包括:
接收事件触发请求,其中,所述触发请求中包括待执行的事件及所述触发请求对应的第一时刻;
在将所述待执行的事件与回调函数绑定的情况下,将所述待执行的事件与预设的事件监控函数绑定;
获取执行所述事件监控函数的第二时刻;
根据所述第二时刻与所述第一时刻间的时间间隔,确定所述浏览器在所述待执行的事件下的响应时长。
根据本公开的另一方面,提供了一种浏览器运行数据的获取装置,包括:
接收模块,用于接收事件触发请求,其中,所述触发请求中包括待执行的事件及所述触发请求对应的第一时刻;
绑定模块,用于在将所述待执行的事件与回调函数绑定的情况下,将所述待执行的事件与预设的事件监控函数绑定;
获取模块,用于获取执行所述事件监控函数的第二时刻;
第一确定模块,用于根据所述第二时刻与所述第一时刻间的时间间隔,确定所述浏览器在所述待执行的事件下的响应时长。
根据本公开的另一方面,提供了一种电子设备,包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行上述实施例所述的方法。
根据本公开的另一方面,提供了一种存储有计算机指令的非瞬时计算机可读存储介质,其中,所述计算机指令用于使所述计算机执行根据上述实施例所述的方法。
根据本公开的另一方面,提供了一种计算机程序产品,包括计算机程序,所述计算机程序在被处理器执行时实现上述实施例所述方法的步骤。
应当理解,本部分所描述的内容并非旨在标识本公开的实施例的关键或重要特征,也不用于限制本公开的范围。本公开的其它特征将通过以下的说明书而变得容易理解。
附图说明
附图用于更好地理解本方案,不构成对本公开的限定。其中:
图1为本公开实施例提供的一种浏览器运行数据的获取方法的流程示意图;
图2为本公开实施例提供的一种页面运行数据获取过程示意图;
图3为本公开实施例提供的另一种浏览器运行数据的获取方法的流程示意图;
图4为本公开实施例提供的另一种浏览器运行数据的获取方法的流程示意图;
图5为本公开实施例提供的另一种浏览器运行数据的获取装置的流程示意图;
图6是用来实现本公开实施例的浏览器运行数据的获取方法的电子设备的框图;
具体实施方式
以下结合附图对本公开的示范性实施例做出说明,其中包括本公开实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本公开的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
下面参考附图,对本公开实施例的浏览器运行数据的获取方法、装置、电子设备和存储介质进行详细说明。
图1为本公开实施例提供的一种浏览器运行数据的获取方法的流程示意图。
如图1所示,该方法包括:
步骤101,接收事件触发请求,其中,触发请求中包括待执行的事件及触发请求对应的第一时刻。
其中,待执行的事件,可以用户在对浏览器页面进行操控时,触发的事件。比如,对于Web应用来说,代表性的事件有单击事件、双击事件、移动鼠标事件等等。第一时刻可以为请求触发的时间点。
本公开中,可以在浏览器客户端通过键盘输入、鼠标点击等操作,触发待执行的事件,之后,浏览器客户端会获取触发时刻的时间戳,作为触发请求对应的第一时刻,并确定被触发的事件为待执行事件。
比如,通过鼠标点击浏览器页面上广告窗口中“打开”按钮,即可触发该“打开”按钮对应的点击事件请求,浏览器客户端接收到请求时,可以获取该时刻的时间戳,作为触发请求对应的第一时刻,并且可以将此点击事件,确定为待执行的事件。
步骤102,在将待执行的事件与回调函数绑定的情况下,将待执行的事件与预设的事件监控函数绑定。
其中,回调函数可以为用于实现该待执行的事件对应的程序代码。通常,浏览器中不同的页面事件需要绑定对应的回调函数,通过执行该回调函数,即可完成该页面事件。
另外,预设的事件监控函数可以为只具有获取时间戳的功能,用于监控浏览器运行的各回调函数的结束时刻。本公开中在确定待执行的事件与回调函数已绑定的情况下,即可再将该事件与预设的事件监控函数绑定,从而即可获取各个事件的执行结束时刻。
本公开中,可以在页面加载过程中,通过对页面脚本进行解析,以确定各个页面元素对应的回调函数,进而通过调用事件绑定API,进行回调函数绑定,并在已绑定回调函数的情况下,再调用事件绑定API,完成事件监控函数与事件的绑定。或者,也可以在事件被触发时,再调用事件绑定AP I,完成监控函数与待执行事件的绑定。
可以理解的是,待执行事件可以被绑定多个回调函数,最内层被绑定的回调函数可以为业务功能对应的回调函数(以下简称业务回调函数),最外层被绑定的回调函数为事件监控函数,用于获取该待执行事件的完成时刻。
步骤103,获取执行事件监控函数的第二时刻。
其中,执行事件监控函数的第二时刻,也即业务回调函数对应的结束时刻,本公开中通过利用事件监控函数,即可获取各个事件的完成时刻。
本公开中,当任一事件被触发后,浏览器客户端即可根据该事件绑定的回调函数的顺序,通过依次执行回调函数,来完成该事件。
需要说明的是,当浏览器主线程为空闲状态时,任一事件被触发后,可立即按其对应的回调函数绑定顺序,执行各个回调函数。而当浏览器主线程有其它任务在执行时,需要将该待执行事件加入执行栈中,之后按照执行栈中各个任务的顺序,依次执行各个任务,再执行到该待执行事件时,即可按其对应的回调函数绑定顺序,依次执行各回调函数,以获取执行事件监控函数的第二时刻。
比如,图2为本公开提供的一种页面运行数据获取过程示意图。如图2所示,在栈中有两个任务在等待执行的情况下,当点击事件发生在执行任务1的过程中时,浏览器可以先将任务1执行完毕,再执行栈中的任务2,之后,执行点击事件绑定的业务回调函数,然后,再执行事件监控函数,以获取执行事件监控函数时刻的时间戳,即第二时刻。
步骤104,根据第二时刻与第一时刻间的时间间隔,确定浏览器在待执行的事件下的响应时长。
本公开中,可以确定第二时刻与第一时刻的时间差,然后,将此时间差作为浏览器在待执行的事件下的响应时长。
比如,如图2所示,当点击事件发生在执行栈中的任务1过程中时,浏览器对点击事件的响应时间可以为点击事件触发时刻(即第一时刻),到业务回调函数执行结束时刻的时间差。由于事件检测函数耗时非常短,可忽略不计,可以将执行事件检测函数的第二时刻,确定为业务回调函数执行结束的时刻,因此,浏览器对点击事件的响应时长还可以为第一时刻,到第二时刻的时间差。
本公开中,接收到事件触发请求后,在确定待执行的事件与回调函数绑定的情况下,将待执行的事件与预设的事件监控函数绑定,之后,在获取执行事件监控函数的第二时刻后,即可根据第二时刻与第一时刻间的时间间隔,确定浏览器在待执行的事件下的响应时长。由此,通过将待执行的事件与事件监控函数进行绑定,从而提升了对各个页面事件的执行时长进行监控的准确性,进而提升了对浏览器性能监控的准确性,通过对待执行事件进行监控,增加了对浏览器监控的场景,从而增加了对浏览器性能监控的全面性。
在实际应用中,通常会有很多使用前端元素,切换路由的页面,整个过程都是在同一个页面中实现,不涉及页面间的跳转。当同一页面元素可多次被触发,以触发不同事件时,若每个事件注册的事件监控函数不被清除,则可能存在内存泄露的风险。因此,在将事件与事件监控函数绑定后,还可以根据需要对事件监控函数进行删除。下面结合图3对上述过程进行详细说明,图3为本公开实施例提供的另一种浏览器运行数据的获取方法。
如图3所示,该方法包括:
步骤301,接收事件触发请求,其中,触发请求中包括待执行的事件及触发请求对应的第一时刻。
本实施例中,步骤301的具体实现过程,可参见上述实施例的详细描述,在此不再赘述。
步骤302,在确定待执行的事件为有效事件的情况下,根据待执行的事件的类型,确定待绑定的目标回调函数。
其中,有效事件,可以为任一能够引起页面内容变化的事件。比如,点击页面中“登录”按钮之后,页面弹出验证窗口,则此点击事件为有效事件。
可以理解的是,同一类型的事件对应的回调函数可能相同,比如,所有页面元素对应的鼠标移开事件,可以对应用于实现恢复默认设置功能的回调函数。或者,同一类型的事件对应的回调函数也可能不相同,比如,“返回”按钮的鼠标点击事件,可以对应用于实现关闭窗口功能的回调函数,“确定”按钮的鼠标点击事件,可以对应用于实现提交数据功能的回调函数等等。需要说明的是,上述事件与回调函数的对应关系,仅是示意性说明,不能作为对本公开中技术方案的限制。
本实施例中,可以在浏览器的超文本标记语言(HyperText Markup Language,html)代码文件中,用注释的方式标识每个页面元素对应的每个事件是否为有效事件,然后在浏览器页面加载的过程中,解析事件对应的注释信息,确定事件是否为有效事件。在待执行事件为有效事件的情况下,当同一类型的事件对应的回调函数相同时,可以根据待执行的事件的类型,确定目标回调函数,当同一类型的事件对应的回调函数可能不同时,则可以根据待执行事件关联的页面元素的功能,确定目标回调函数,本公开对此不做限定。
本公开中,在确定所述待执行的事件为有效事件的情况下,可以根据待执行的事件的类型,确定待绑定的目标回调函数,从而可以满足多种场景的需求。
步骤303,将待执行的事件与目标回调函数进行绑定。
本实施例中,步骤303的具体实现过程,可参见上述实施例的详细描述,在此不再赘述。
步骤304,确定待执行的事件关联的页面元素当前已绑定的各函数。
在实际应用中,若同一页面元素,可以被多次触发,以产生不同事件,则该页面元素可能会被注册多个事件监控函数,从而导致内存泄漏。
比如,当前页面中有一个按钮,第一次点击该按钮后,将打开一个弹窗,且该按钮功能由“打开”变成了“关闭”,此按钮对应的点击事件被绑定了第一个事件监控函数,之后,再次点击该按钮时,弹窗将被关闭,此按钮对应的点击事件被绑定了第二个事件监控函数。随着对此按钮点击次数增多,此按钮对应的点击事件会被绑定更多的事件监控函数。因此,可以删除事件已绑定的事件监控函数,以防止内存泄露。
步骤305,在已绑定的各函数中包含事件监控函数的情况下,将所述已绑定的事件监控函数移除。
本实施例中,可以查询页面元素已绑定的函数信息中,是否存在事件监控函数,如果存在事件监控函数,则删除此页面元素已注册的所有事件监控函数,比如,可以调用事件解绑API,将该事件已绑定的事件监控函数进行解绑。
比如,当前页面中有一个按钮,第一次点击该按钮后,将打开一个弹窗,且该按钮由“打开”变成了“关闭”,此按钮对应的点击事件第一次被绑定了事件监控函数,当再次点击该按钮时,可以调用事件解绑API,删除点击事件第一次被绑定的事件监控函数。
步骤306,将待执行的事件与预设的事件监控函数绑定。
本公开中,当事件为有效事件时,用户通过页面变化可以直接感受到浏览器对事件响应速度。当事件为无效事件时,用户不能直接感受到浏览器对事件响应速度。因此,可以有针对性的,对有效事件进行监控。
本公开中,在待执行事件为有效事件的情况下,可以调用事件绑定API,完成事件监控函数与待执行的事件的绑定。
步骤307,获取执行事件监控函数的第二时刻。
步骤308,根据第二时刻与第一时刻间的时间间隔,确定浏览器在待执行的事件下的响应时长。
本实施例中,步骤307-步骤308的具体实现过程,可参见上述实施例的详细描述,在此不再赘述。
本公开中,接收到事件触发请求后,根据待执行事件的类型,确定目标回调函数,并将待执行的事件与回调函数进行绑定,之后,确定待执行的事件关联的页面元素当前已绑定的各函数,在已绑定的各函数中包含事件监控函数的情况下,将已绑定的事件监控函数移除,并将待执行的事件与预设的事件监控函数绑定,然后,在获取执行事件监控函数的第二时刻后,即可根据第二时刻与第一时刻间的时间间隔,确定浏览器在待执行的事件下的响应时长。由此,通过删除待执行的事件关联的页面元素已绑定的事件监控函数,即可防止因注册过多事件监控函数导致的内存泄露,从而提高了程序运行的稳定性,为对浏览器性能进行全面、准确的监控提供了条件。
在实际应用中,若浏览器客户端记录获取的各个事件的响应时长,则可能会缓存大量响应时长数据。但是,浏览器缓存空间是有限的,当存储大量数据后,可能导致浏览器性能下降。因此,各个客户端可以定期将监控数据上传到浏览器的服务端,不仅可以减少客户端侧的数据缓存压力,还可以使服务端根据各个客户端返回的数据,对浏览器的性能进行统一的统计和分析。下面结合图4对上述过程进行详细说明,图4为本公开实施例提供的另一种浏览器运行数据的获取方法。
步骤401,接收事件触发请求,其中,触发请求中包括待执行的事件及触发请求对应的第一时刻。
步骤402,在将待执行的事件与回调函数绑定的情况下,将待执行的事件与预设的事件监控函数绑定。
步骤403,获取执行事件监控函数的第二时刻。
步骤404,根据第二时刻与第一时刻间的时间间隔,确定浏览器在待执行的事件下的响应时长。
本实施例中,步骤401-步骤404的具体实现过程,可参见本公开任一实施例的详细描述,在此不再赘述。
步骤405,记录浏览器在待执行的事件下的响应时长。
本实施例中,在确定浏览器在待执行的事件下的响应时长后,可以将响应时长按照任一格式写到日志文件中。
其中,记录的格式可以为每一行记录一个事件名称和对应的响应时长,还可以将事件名称和对应的时长作为一个单元,单元之间用分号隔开。日志文件可以在开始运行浏览器时自动创建,还可以在监测到第一个响应时长数据时创建。
步骤406,在已记录的响应时长的数量大于阈值的情况下,根据每个响应时长对应的事件类型,确定浏览器在各类型事件下的响应时长分布特征。
本公开中,浏览器客户端会记录大量响应时长数据,但是,对浏览器性能分析时,只需关注每个类型事件的响应时长分布特征,并不需要关注每个响应时长数据。因此,浏览器客户端可以先根据记录的各个响应时长对应的事件类型,确定各个类型事件对应的响应时长分布特征,进而只上传响应时长的分布特征,从而可以减少上传数据量,缩短上传数据的时间。
本实施例中,浏览器客户端可以对记录响应时长的日志文件的大小进行实时监测,或者也可以在每一次向日志文件中写入数据时,自动更新已记录的响应时长数量。如果日志文件大于所设阈值,则根据事件类型,将日志文件中的数据进行分类,并对各类事件的响应时长数据进行统计,确定各类事件的响应时长分布特性。
其中,响应时长的分布特征,可以包括响应时长均值,响应时长分位值,响应时长极值,响应时长抽样值等特征数据。从而,根据多种响应时长分布特征,即可更全面、准确的分析浏览器的性能。
步骤407,将浏览器在各类型事件下的响应时长分布特征发送给浏览器的服务端。
本公开中,各个浏览器客户端将记录的各类事件的响应时长分布特征,发送给浏览器的服务端后,可以清空存储响应时长的日志文件。浏览器服务端在接收到响应时长分布特征数据后,可以将其写入日志文件中,以对浏览器性能分析使用。
可选的,还可以将浏览器的客户端当前所在的终端设备的属性信息,发送给浏览器的服务端,以便浏览器服务端可以根据浏览器客户端所在的终端设备的属性信息,确定在不同终端设备上对相同事件的响应情况。
本公开中,接收到事件触发请求后,在确定待执行的事件与回调函数绑定的情况下,将待执行的事件与预设的事件监控函数绑定,之后,在获取执行事件监控函数的第二时刻后,即可根据第二时刻与第一时刻间的时间间隔,确定浏览器在待执行的事件下的响应时长,然后,根据每个响应时长对应的事件类型,确定浏览器在各类型事件下的响应时长分布特征后,将响应时长分布特征发送给浏览器的服务端。由此,通过将浏览器在各类型事件下的响应时长分布特征发送给浏览器的服务端,有利于服务端根据各个客户端返回的数据,对浏览器的性能进行统一的统计和分析,提高了对浏览器进行性能分析的易用性。
为了实现上述实施例,本公开实施例还提出一种浏览器运行数据的获取装置。图5为本公开实施例提供的一种浏览器运行数据的获取装置的结构示意图。
如图5所示,该业务请求的处理装置500包括:接收模块510、绑定模块520、获取模块530、第一确定模块540。
接收模块510,用于接收事件触发请求,其中,所述触发请求中包括待执行的事件及所述触发请求对应的第一时刻;
绑定模块520,用于在将所述待执行的事件与回调函数绑定的情况下,将所述待执行的事件与预设的事件监控函数绑定;
获取模块530,用于获取执行所述事件监控函数的第二时刻;
第一确定模块540,用于根据所述第二时刻与所述第一时刻间的时间间隔,确定所述浏览器在所述待执行的事件下的响应时长。
在本公开实施例一种可能的实现方式中,上述绑定模块,具体用于:
在确定所述待执行的事件为有效事件的情况下,根据所述待执行的事件的类型,确定待绑定的目标回调函数;
将所述待执行的事件与所述目标回调函数进行绑定。
在本公开实施例一种可能的实现方式中,还包括:
记录模块,用于记录所述浏览器在所述待执行的事件下的响应时长;
第二确定模块,用于在已记录的响应时长的数量大于阈值的情况下,根据每个响应时长对应的事件类型,确定所述浏览器在各类型事件下的响应时长分布特征;
发送模块,用于将所述浏览器在各类型事件下的响应时长分布特征发送给所述浏览器的服务端。
在本公开实施例一种可能的实现方式中,上述发送模块还用于:
将所述浏览器的客户端当前所在的终端设备的属性信息,发送给所述浏览器的服务端。
在本公开实施例一种可能的实现方式中,其中,所述响应时长分布特征,包括以下至少一项:响应时长均值,响应时长分位值,响应时长极值,以及响应时长抽样值。
在本公开实施例一种可能的实现方式中,上述绑定模块,具体用于:
确定所述待执行的事件关联的页面元素当前已绑定的各函数;
在所述已绑定的各函数中包含事件监控函数的情况下,将所述已绑定的事件监控函数移除。
需要说明的是,前述浏览器运行数据的获取方法实施例的解释说明,也适用于该实施例的装置,故在此不再赘述。
本公开中,接收到事件触发请求后,在确定待执行的事件与回调函数绑定的情况下,将待执行的事件与预设的事件监控函数绑定,之后,在获取执行事件监控函数的第二时刻后,即可根据第二时刻与第一时刻间的时间间隔,确定浏览器在待执行的事件下的响应时长。由此,通过将待执行的事件与事件监控函数进行绑定,从而提升了对各个页面事件的执行时长进行监控的准确性,进而提升了对浏览器性能监控的准确性,通过对待执行事件进行监控,增加了对浏览器监控的场景,从而增加了对浏览器性能监控的全面性。
根据本公开的实施例,本公开还提供了一种电子设备、一种可读存储介质和一种计算机程序产品。
图6示出了可以用来实施本公开的实施例的示例电子设备600的示意性框图。电子设备旨在表示各种形式的数字计算机,诸如,膝上型计算机、台式计算机、工作台、个人数字助理、服务器、刀片式服务器、大型计算机、和其它适合的计算机。电子设备还可以表示各种形式的移动装置,诸如,个人数字处理、蜂窝电话、智能电话、可穿戴设备和其它类似的计算装置。本文所示的部件、它们的连接和关系、以及它们的功能仅仅作为示例,并且不意在限制本文中描述的和/或者要求的本公开的实现。
如图6所示,设备600包括计算单元601,其可以根据存储在ROM(Read-OnlyMemory,只读存储器)602中的计算机程序或者从存储单元608加载到RAM(Random AccessMemory,随机访问/存取存储器)603中的计算机程序,来执行各种适当的动作和处理。在RAM603中,还可存储设备600操作所需的各种程序和数据。计算单元601、ROM 602以及RAM 603通过总线604彼此相连。I/O(Input/Output,输入/输出)接口605也连接至总线604。
设备600中的多个部件连接至I/O接口605,包括:输入单元606,例如键盘、鼠标等;输出单元607,例如各种类型的显示器、扬声器等;存储单元608,例如磁盘、光盘等;以及通信单元609,例如网卡、调制解调器、无线通信收发机等。通信单元609允许设备600通过诸如因特网的计算机网络和/或各种电信网络与其他设备交换信息/数据。
计算单元601可以是各种具有处理和计算能力的通用和/或专用处理组件。计算单元601的一些示例包括但不限于CPU(Central Processing Unit,中央处理单元)、GPU(Graphic Processing Units,图形处理单元)、各种专用的AI(Artificial Intelligence,人工智能)计算芯片、各种运行机器学习模型算法的计算单元、DSP(Digital SignalProcessor,数字信号处理器)、以及任何适当的处理器、控制器、微控制器等。计算单元601执行上文所描述的各个方法和处理,例如浏览器运行数据的获取方法。例如,在一些实施例中,对浏览器运行数据的获取方法可被实现为计算机软件程序,其被有形地包含于机器可读介质,例如存储单元608。在一些实施例中,计算机程序的部分或者全部可以经由ROM 602和/或通信单元609而被载入和/或安装到设备600上。当计算机程序加载到RAM603并由计算单元601执行时,可以执行上文描述的浏览器运行数据的获取方法的一个或多个步骤。备选地,在其他实施例中,计算单元601可以通过其他任何适当的方式(例如,借助于固件)而被配置为执行浏览器运行数据的获取方法。
本文中以上描述的***和技术的各种实施方式可以在数字电子电路***、集成电路***、FPGA(Field Programmable Gate Array,现场可编程门阵列)、ASIC(Application-Specific Integrated Circuit,专用集成电路)、ASSP(Application Specific StandardProduct,专用标准产品)、SOC(System On Chip,芯片上***的***)、CPLD(ComplexProgrammable Logic Device,复杂可编程逻辑设备)、计算机硬件、固件、软件、和/或它们的组合中实现。这些各种实施方式可以包括:实施在一个或者多个计算机程序中,该一个或者多个计算机程序可在包括至少一个可编程处理器的可编程***上执行和/或解释,该可编程处理器可以是专用或者通用可编程处理器,可以从存储***、至少一个输入装置、和至少一个输出装置接收数据和指令,并且将数据和指令传输至该存储***、该至少一个输入装置、和该至少一个输出装置。
用于实施本公开的方法的程序代码可以采用一个或多个编程语言的任何组合来编写。这些程序代码可以提供给通用计算机、专用计算机或其他可编程数据处理装置的处理器或控制器,使得程序代码当由处理器或控制器执行时使流程图和/或框图中所规定的功能/操作被实施。程序代码可以完全在机器上执行、部分地在机器上执行,作为独立软件包部分地在机器上执行且部分地在远程机器上执行或完全在远程机器或服务器上执行。
在本公开的上下文中,机器可读介质可以是有形的介质,其可以包含或存储以供指令执行***、装置或设备使用或与指令执行***、装置或设备结合地使用的程序。机器可读介质可以是机器可读信号介质或机器可读储存介质。机器可读介质可以包括但不限于电子的、磁性的、光学的、电磁的、红外的、或半导体***、装置或设备,或者上述内容的任何合适组合。机器可读存储介质的更具体示例会包括基于一个或多个线的电气连接、便携式计算机盘、硬盘、RAM、ROM、EPROM(Electrically Programmable Read-Only-Memory,可擦除可编程只读存储器)或快闪存储器、光纤、CD-ROM(Compact Disc Read-Only Memory,便捷式紧凑盘只读存储器)、光学储存设备、磁储存设备、或上述内容的任何合适组合。
为了提供与用户的交互,可以在计算机上实施此处描述的***和技术,该计算机具有:用于向用户显示信息的显示装置(例如,CRT(Cathode-Ray Tube,阴极射线管)或者LCD(Liquid Crystal Display,液晶显示器)监视器);以及键盘和指向装置(例如,鼠标或者轨迹球),用户可以通过该键盘和该指向装置来将输入提供给计算机。其它种类的装置还可以用于提供与用户的交互;例如,提供给用户的反馈可以是任何形式的传感反馈(例如,视觉反馈、听觉反馈、或者触觉反馈);并且可以用任何形式(包括声输入、语音输入或者、触觉输入)来接收来自用户的输入。
可以将此处描述的***和技术实施在包括后台部件的计算***(例如,作为数据服务器)、或者包括中间件部件的计算***(例如,应用服务器)、或者包括前端部件的计算***(例如,具有图形用户界面或者网络浏览器的用户计算机,用户可以通过该图形用户界面或者该网络浏览器来与此处描述的***和技术的实施方式交互)、或者包括这种后台部件、中间件部件、或者前端部件的任何组合的计算***中。可以通过任何形式或者介质的数字数据通信(例如,通信网络)来将***的部件相互连接。通信网络的示例包括:LAN(LocalArea Network,局域网)、WAN(Wide Area Network,广域网)、互联网和区块链网络。
计算机***可以包括客户端和服务器。客户端和服务器一般远离彼此并且通常通过通信网络进行交互。通过在相应的计算机上运行并且彼此具有客户端-服务器关系的计算机程序来产生客户端和服务器的关系。服务器可以是云服务器,又称为云计算服务器或云主机,是云计算服务体系中的一项主机产品,以解决了传统物理主机与VPS服务(VirtualPrivate Server,虚拟专用服务器)中,存在的管理难度大,业务扩展性弱的缺陷。服务器也可以为分布式***的服务器,或者是结合了区块链的服务器。
根据本公开的实施例,本公开还提供了一种计算机程序产品,当计算机程序产品中的指令处理器执行时,执行本公开上述实施例提出的浏览器运行数据的获取方法。
应该理解,可以使用上面所示的各种形式的流程,重新排序、增加或删除步骤。例如,本公开中记载的各步骤可以并行地执行也可以顺序地执行也可以不同的次序执行,只要能够实现本公开公开的技术方案所期望的结果,本文在此不进行限制。
上述具体实施方式,并不构成对本公开保护范围的限制。本领域技术人员应该明白的是,根据设计要求和其他因素,可以进行各种修改、组合、子组合和替代。任何在本公开的精神和原则之内所作的修改、等同替换和改进等,均应包含在本公开保护范围之内。

Claims (15)

1.一种浏览器运行数据的获取方法,包括:
接收事件触发请求,其中,所述触发请求中包括待执行的事件及所述触发请求对应的第一时刻;
在将所述待执行的事件与回调函数绑定的情况下,将所述待执行的事件与预设的事件监控函数绑定;
获取执行所述事件监控函数的第二时刻;
根据所述第二时刻与所述第一时刻间的时间间隔,确定所述浏览器在所述待执行的事件下的响应时长。
2.如权利要求1所述的方法,其中,所述将所述待执行的事件与回调函数绑定,包括:
在确定所述待执行的事件为有效事件的情况下,根据所述待执行的事件的类型,确定待绑定的目标回调函数;
将所述待执行的事件与所述目标回调函数进行绑定。
3.如权利要求1所述的方法,其中,在所述确定所述浏览器在所述待执行的事件下的响应时长之后,还包括:
记录所述浏览器在所述待执行的事件下的响应时长;
在已记录的响应时长的数量大于阈值的情况下,根据每个响应时长对应的事件类型,确定所述浏览器在各类型事件下的响应时长分布特征;
将所述浏览器在各类型事件下的响应时长分布特征发送给所述浏览器的服务端。
4.如权利要求3所述的方法,其中,还包括:
将所述浏览器的客户端当前所在的终端设备的属性信息,发送给所述浏览器的服务端。
5.如权利要求3所述的方法,其中,所述响应时长分布特征,包括以下至少一项:响应时长均值,响应时长分位值,响应时长极值,以及响应时长抽样值。
6.如权利要求1-5任一所述的方法,其中,在所述将所述待执行的事件与预设的事件监控函数绑定之前,还包括:
确定所述待执行的事件关联的页面元素当前已绑定的各函数;
在所述已绑定的各函数中包含事件监控函数的情况下,将所述已绑定的事件监控函数移除。
7.一种浏览器运行数据的获取装置,包括:
接收模块,用于接收事件触发请求,其中,所述触发请求中包括待执行的事件及所述触发请求对应的第一时刻;
绑定模块,用于在将所述待执行的事件与回调函数绑定的情况下,将所述待执行的事件与预设的事件监控函数绑定;
获取模块,用于获取执行所述事件监控函数的第二时刻;
第一确定模块,用于根据所述第二时刻与所述第一时刻间的时间间隔,确定所述浏览器在所述待执行的事件下的响应时长。
8.如权利要求7所述的装置,其中,所述绑定模块,具体用于:
在确定所述待执行的事件为有效事件的情况下,根据所述待执行的事件的类型,确定待绑定的目标回调函数;
将所述待执行的事件与所述目标回调函数进行绑定。
9.如权利要求7所述的装置,还包括:
记录模块,用于记录所述浏览器在所述待执行的事件下的响应时长;
第二确定模块,用于在已记录的响应时长的数量大于阈值的情况下,根据每个响应时长对应的事件类型,确定所述浏览器在各类型事件下的响应时长分布特征;
发送模块,用于将所述浏览器在各类型事件下的响应时长分布特征发送给所述浏览器的服务端。
10.如权利要求9所述的装置,所述发送模块,还用于:
将所述浏览器的客户端当前所在的终端设备的属性信息,发送给所述浏览器的服务端。
11.如权利要求9所述的装置,其中,所述响应时长分布特征,包括以下至少一项:响应时长均值,响应时长分位值,响应时长极值,以及响应时长抽样值。
12.如权利要求7-11任一所述的装置,所述绑定模块,具体用于:
确定所述待执行的事件关联的页面元素当前已绑定的各函数;
在所述已绑定的各函数中包含事件监控函数的情况下,将所述已绑定的事件监控函数移除。
13.一种电子设备,包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行权利要求1-6中任一项所述的方法。
14.一种存储有计算机指令的非瞬时计算机可读存储介质,其中,所述计算机指令用于使所述计算机执行根据权利要求1-6中任一项所述的方法。
15.一种计算机程序产品,包括计算机程序,所述计算机程序在被处理器执行时实现权利要求1-6中任一项所述方法的步骤。
CN202111248539.5A 2021-10-26 2021-10-26 浏览器运行数据的获取方法、装置及电子设备 Pending CN114117289A (zh)

Priority Applications (3)

Application Number Priority Date Filing Date Title
CN202111248539.5A CN114117289A (zh) 2021-10-26 2021-10-26 浏览器运行数据的获取方法、装置及电子设备
EP22203836.6A EP4160421A1 (en) 2021-10-26 2022-10-26 Method and apparatus for obtaining browser running data, and storage medium
US18/049,721 US20230065492A1 (en) 2021-10-26 2022-10-26 Method for obtaining browser running data, electronic device, and storage medium

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202111248539.5A CN114117289A (zh) 2021-10-26 2021-10-26 浏览器运行数据的获取方法、装置及电子设备

Publications (1)

Publication Number Publication Date
CN114117289A true CN114117289A (zh) 2022-03-01

Family

ID=80376850

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202111248539.5A Pending CN114117289A (zh) 2021-10-26 2021-10-26 浏览器运行数据的获取方法、装置及电子设备

Country Status (3)

Country Link
US (1) US20230065492A1 (zh)
EP (1) EP4160421A1 (zh)
CN (1) CN114117289A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117290840A (zh) * 2023-09-07 2023-12-26 北京海泰方圆科技股份有限公司 浏览器审计方法、装置、计算机设备和存储介质

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117472683A (zh) * 2023-10-24 2024-01-30 航天信息(广东)有限公司 一种页面操作的监控处理方法、装置、设备及存储介质

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6611877B2 (en) * 1998-06-30 2003-08-26 Sun Microsystems, Inc. System and method for aggregating registration of entities for notifications of events
US7707588B2 (en) * 2004-03-02 2010-04-27 Avicode, Inc. Software application action monitoring
US7610266B2 (en) * 2005-05-25 2009-10-27 International Business Machines Corporation Method for vertical integrated performance and environment monitoring
US8005943B2 (en) * 2005-10-12 2011-08-23 Computer Associates Think, Inc. Performance monitoring of network applications
US8095641B2 (en) * 2005-10-27 2012-01-10 International Business Machines Corporation Method and system for virtualized health monitoring of resources
US8196118B2 (en) * 2008-03-27 2012-06-05 Microsoft Corporation Event set recording

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN117290840A (zh) * 2023-09-07 2023-12-26 北京海泰方圆科技股份有限公司 浏览器审计方法、装置、计算机设备和存储介质
CN117290840B (zh) * 2023-09-07 2024-03-15 北京海泰方圆科技股份有限公司 浏览器审计方法、装置、计算机设备和存储介质

Also Published As

Publication number Publication date
EP4160421A1 (en) 2023-04-05
US20230065492A1 (en) 2023-03-02

Similar Documents

Publication Publication Date Title
US20200073785A1 (en) Distributed code tracing system
US20230065492A1 (en) Method for obtaining browser running data, electronic device, and storage medium
CN109002395B (zh) 一种代码覆盖率管理方法和装置
US20140317081A1 (en) System and method for session data management
CN111552633A (zh) 接口的异常调用测试方法、装置、计算机设备及存储介质
US11645179B2 (en) Method and apparatus of monitoring interface performance of distributed application, device and storage medium
CN112559086A (zh) 小程序页面渲染方法、装置、电子设备及可读存储介质
CN112631887A (zh) 异常检测方法、装置、电子设备和计算机可读存储介质
CN112306700A (zh) 一种异常rpc请求的诊断方法和装置
CN113377809A (zh) 数据处理方法及装置,计算设备和介质
CN113238815B (zh) 一种接口访问控制方法、装置、设备及存储介质
CN114546830A (zh) 回归测试方法、装置、电子设备及存储介质
US20220318319A1 (en) Focus Events
CN113778644A (zh) 任务的处理方法、装置、设备及存储介质
US20160050135A1 (en) Real-time measurement of user interface performance in a remote desktop environment
CN107330031A (zh) 一种数据存储的方法、装置及电子设备
CN114462030A (zh) 隐私政策的处理、取证方法、装置、设备及存储介质
CN114238335A (zh) 一种埋点数据生成方法及其相关设备
CN110020166A (zh) 一种数据分析方法及相关设备
CN114329149A (zh) 页面信息自动抓取的检测方法、装置、电子设备及可读存储介质
CN113656391A (zh) 数据检测方法及装置、存储介质及电子设备
CN113254325A (zh) 测试用例的处理方法和装置
CN115242799B (zh) 数据上报方法、装置、设备、存储介质及程序产品
CN114217742B (zh) 一种网络设备存储空间自动分析及清理的方法、装置、存储介质及电子设备
CN113220958A (zh) 页面信息展示方法、***及存储介质

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination