CN113076251A - 测试方法和装置 - Google Patents

测试方法和装置 Download PDF

Info

Publication number
CN113076251A
CN113076251A CN202110410227.3A CN202110410227A CN113076251A CN 113076251 A CN113076251 A CN 113076251A CN 202110410227 A CN202110410227 A CN 202110410227A CN 113076251 A CN113076251 A CN 113076251A
Authority
CN
China
Prior art keywords
service
recording
data
recorded
identifier
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
CN202110410227.3A
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 Jingdong Tuoxian Technology Co Ltd
Original Assignee
Beijing Jingdong Tuoxian 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 Jingdong Tuoxian Technology Co Ltd filed Critical Beijing Jingdong Tuoxian Technology Co Ltd
Priority to CN202110410227.3A priority Critical patent/CN113076251A/zh
Publication of CN113076251A publication Critical patent/CN113076251A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/362Software debugging
    • G06F11/3644Software debugging by instrumenting at runtime
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/362Software debugging
    • G06F11/366Software debugging using diagnostics

Abstract

本发明公开了一种测试方法和装置,涉及计算机技术领域。该方法的一具体实施方式包括:接收压力测试请求,并确定压力测试请求的标识;根据压力测试请求的标识,获取录制数据;其中,录制数据是在线上流量访问待测试服务时录制的,录制数据包括待测试服务所调用的方法以及方法的入参和出参;回放录制数据,得到回放结果;对比出参和回放结果,得到测试结果。该实施方式避免了对线上真实流程产生影响;解决了手动编写的压测数据无法完全覆盖线上用户访问的所有场景而导致某些压测场景遗漏的风险以及线上真实用户因流量大而导致服务宕机的;解决了因备份压测数据库或者缓存的性能和线上真实环境性能存在差异,压测结果存在偏差的问题。

Description

测试方法和装置
技术领域
本发明涉及计算机技术领域,尤其涉及一种测试方法和装置。
背景技术
近几年各大电商平台的促销活动如火如荼。各大电商大促期间流量剧增长,对电商平台相关的软件和服务系统也带来了严峻的挑战;比如秒杀、抢购活动要求提高系统高并发、高可用的处理能力,核心的业务流程要求更好的可用性以及稳定性,因此在大促前夕,需要精确的对线上服务进行压力测试,及时做好系统服务器性能的评估和限流等相关工作,其中包括系统压力测试、稳定性测试、负载能力测试和可扩展性测试等;但是压力测试会产生很多测试数据,处理不好可能会对线上正常数据产生影响,因此压测数据的处理,也是一个严重的问题。目前的主要的压测方案大概有两种,一种是手动编写压测脚本,涉及到对数据库或者缓存进行读写时,写入有压测标识的影子数据;另一种是备份一份和线上配置相同的数据库或者缓存;压力测试只压其中一个,以此测试一个数据库或者缓存承受压力。但是,对于第一种方案,如果向缓存或者数据库存入有压测标识的影子数据,在测试完成后,缓存或者数据库会产生很多测试数据,可能会对线上存在一定影响;如果清理这些测试数据可能会存在误删、漏删等风险。如果不写入数据,直接返回成功标识,那么本次压力测试并没有覆盖所有的流程,等到线上流量真正写入时,在高并发情况下,某个服务或者某个模块可能存在问题,影响整个流程。对于第二种方案,其解决了方案一中清理数据存在误删、漏删等风险,但是备份数据库或者缓存的性能和线上数据库或者缓存的性能难免会存在差异,所以最终的压测结果可能存在一定的偏差。并且,该方案是手动编写压测数据进行压测,和线上流量真实访问可能存在差异,无法完全覆盖线上流量访问的所有场景。
发明内容
有鉴于此,本发明实施例提供一种测试方法和装置,不需要写入带有压测标识的影子数据,避免了在压测时对线上数据库或缓存进行读写而产生测试数据,避免对线上真实流程产生影响;能够全面压测线上服务,降低因某些模块没有真实压测到,导致线上真实用户因流量大而导致服务宕机的风险,解决手动编写的压测数据无法完全覆盖线上用户访问的所有场景而导致某些压测场景遗漏的风险;利用录制数据对线上真实环境进行压测,解决因备份压测数据库或者缓存的性能和线上真实环境性能存在差异,压测结果存在偏差的问题。
为实现上述目的,根据本发明实施例的一个方面,提供了一种测试方法,包括:
接收压力测试请求,并确定所述压力测试请求的标识;
根据所述压力测试请求的标识,获取录制数据;其中,所述录制数据是在线上流量访问待测试服务时录制的,所述录制数据包括所述待测试服务所调用的方法以及所述方法的入参和出参;
回放所述录制数据,以对所述待测试服务进行测试,得到回放结果;
对比所述出参和所述回放结果,得到测试结果。
可选地,在接收压力测试请求之前,所述方法还包括:配置录制切面和录制切点;根据所述录制切面,自动识别待录制的服务;根据所述录制切点,确定执行录制操作的位置,并在所述位置执行录制操作,得到录制数据。
可选地,在得到录制数据之后,所述方法还包括:确定与所述待录制的服务对应的标识;建立所述标识与所述录制数据的映射关系。
可选地,在建立所述标识与所述录制数据的映射关系之后,所述方法还包括:将所述录制数据和所述映射关系写入数据库,以存储所述录制数据和所述映射关系。
可选地,根据所述压力测试请求的标识,获取录制数据包括:将所述压力测试请求的标识与所述映射关系中记录的待录制的服务对应的标识进行匹配,获取匹配到的待录制的服务对应的录制数据。
可选地,所述录制数据还包括录制切点;
回放所述录制数据包括:根据所述录制切点,确定回放位置,并在所述回放位置回放所述录制数据。
可选地,在所述回放位置回放所述录制数据包括:在所述回放位置,根据所述待测试服务所调用的方法以及所述方法的入参,线上请求所述待测试服务。
为实现上述目的,根据本发明实施例的另一个方面,提供了一种测试装置,包括:
接收模块,用于接收压力测试请求,并确定所述压力测试请求的标识;
获取模块,用于根据所述压力测试请求的标识,获取录制数据;其中,所述录制数据是在线上流量访问待测试服务时录制的,所述录制数据包括所述待测试服务所调用的方法以及所述方法的入参和出参;
回放模块,用于回放所述录制数据,以对所述待测试服务进行测试,得到回放结果;
对比模块,用于对比所述出参和所述回放结果,得到测试结果。
可选地,所述装置还包括录制模块,用于:配置录制切面和录制切点;根据所述录制切面,自动识别待录制的服务;根据所述录制切点,确定执行录制操作的位置,并在所述位置执行录制操作,得到录制数据。
可选地,所述录制模块还用于:确定与所述待录制的服务对应的标识;建立所述标识与所述录制数据的映射关系。
可选地,所述装置还包括存储模块,用于将所述录制数据和所述映射关系写入数据库,以存储所述录制数据和所述映射关系。
可选地,所述获取模块还用于:将所述压力测试请求的标识与所述映射关系中记录的待录制的服务对应的标识进行匹配,获取匹配到的待录制的服务对应的录制数据。
可选地,所述录制数据还包括录制切点;
所述回放模块还用于:根据所述录制切点,确定回放位置,并在所述回放位置回放所述录制数据。
可选地,所述回放模块还用于在所述回放位置,根据所述待测试服务所调用的方法以及所述方法的入参,线上请求所述待测试服务。
为实现上述目的,根据本发明实施例的又一个方面,提供了一种电子设备,包括:一个或多个处理器;存储装置,用于存储一个或多个程序,当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现本发明实施例的测试方法。
为实现上述目的,根据本发明实施例的再一个方面,提供了一种计算机可读介质,其上存储有计算机程序,所述程序被处理器执行时实现本发明实施例的测试方法。
上述发明中的一个实施例具有如下优点或有益效果:因为采用接收压力测试请求,并确定压力测试请求的标识;根据压力测试请求的标识,获取录制数据;其中,录制数据是在线上流量访问待测试服务时录制的,录制数据包括待测试服务所调用的方法以及方法的入参和出参;回放录制数据,得到回放结果;对比方法的出参和回放结果,得到测试结果的技术手段,避免了在压测时对线上数据库或缓存进行读写而产生测试数据,避免对线上真实流程产生影响;能够全面压测线上服务,降低因某些模块没有真实压测到,导致线上真实用户因流量大而导致服务宕机的风险,解决手动编写的压测数据无法完全覆盖线上用户访问的所有场景而导致某些压测场景遗漏的风险;利用录制数据对线上真实环境进行压测,解决因备份压测数据库或者缓存的性能和线上真实环境性能存在差异,压测结果存在偏差的问题。
上述的非惯用的可选方式所具有的进一步效果将在下文中结合具体实施方式加以说明。
附图说明
附图用于更好地理解本发明,不构成对本发明的不当限定。其中:
图1是本发明实施例的测试方法的主要流程的示意图;
图2是现有技术一压力测试方法的流程示意图;
图3是现有技术另一压力测试方法的流程示意图;
图4是本发明另一实施例的测试方法的主要流程示意图;
图5是本发明又一实施例的测试方法的流程示意图;
图6是本发明实施例的测试装置的主要模块的示意图;
图7是本发明实施例可以应用于其中的示例性系统架构图;
图8是适于用来实现本发明实施例的终端设备或服务器的计算机系统的结构示意图。
具体实施方式
以下结合附图对本发明的示范性实施例做出说明,其中包括本发明实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本发明的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
图1是本发明实施例的测试方法的主要步骤的流程示意图,如图1所示,该测试方法包括:
步骤S101:配置录制切面和录制切点;
步骤S102:根据所述录制切面,自动识别待录制的服务;
步骤S103:根据所述录制切点,确定执行录制操作的位置,并在所述位置执行录制操作,得到录制数据;
步骤S104:接收压力测试请求,并确定所述压力测试请求的标识;
步骤S105:根据所述压力测试请求的标识,获取录制数据;其中,所述录制数据是在线上流量访问待测试服务时录制的,所述录制数据包括所述待测试服务所调用的方法以及所述方法的入参和出参;
步骤S106:回放所述录制数据,以对所述待测试服务进行测试,得到回放结果;
步骤S107:对比所述出参和所述回放结果,得到测试结果。
本发明实施例的测试方法可以用于压力测试场景。其中,压力测试(Stress Test)也称为强度测试、负载测试。压力测试是模拟实际应用的软硬件环境及用户使用过程的系统负荷,长时间或超大负荷地运行测试软件,来测试被测系统的性能、可靠性、稳定性等。在现有技术中,主要的压测方案大概有两种,一种是手动编写压测脚本,涉及到对数据库或者缓存进行读写时,写入有压测标识的影子数据;另一种是备份一份和线上配置相同的数据库或者缓存,压力测试只压其中一个,以此测试一个数据库或者缓存承受压力。具体方式如图2和图3所示。
在图2中,流程①-⑦为正常线上流量访问流程,流程A-G为现有Java后端服务压力测试流程。本方案在服务2中,根据系统实际情况,在写入缓存时,为了避免和线上数据冲突,写入有压测标识的影子数据或者直接返回成功标识。压测工具在接收服务3的响应数据后,根据不同系统的特点和系统性能,逐步增大压力,查看各种状态下服务性能表现和指标,找到系统运行瓶颈并对其进行优化。在压测后,根据压测数据标识,删除压测产生影子数据。然而,该方案在流程C和服务2发起请求时,如果向缓存或者数据库存入有压测标识的影子数据,在测试完成后,缓存或者数据库会产生很多测试数据,可能会对线上存在一定影响;如果清理这些测试数据可能会存在误删、漏删等风险;如果不写入数据,直接返回成功标识,那么本次压力测试并没有覆盖所有的流程,等到线上流量真正写入时,在高并发情况下,某个服务或者某个模块可能存在问题,影响整个流程。
在图3中,流程①-⑦为正常线上流量访问流程;流程A-H为压力测试流程;本方案备份了一份和线上相同的数据库或者缓存,压测时,压测数据都存放在备份数据库或者缓存中。其中,增加的备份集群和备份数据库或者表结构和线上真实环境配置和性能完全相同,因此产生的压测结果和线上服务器的性能基本相似,可以作为压测最终结果。本方案将压测数据和线上数据进行隔离,避免了处理压测数据时对线上数据库或者缓存的影响,避免了误删、漏删等风险,但是该也是使用压测工具,手动编写的压测数据进行压测,和线上流量真实访问可能存在差异,无法完全覆盖线上流量访问的所有场景。
为了至少解决上述问题,本发明实施例提供了一种测试方法,其利用录制数据对待测试服务进行测试,具体的,如图1所示。
在步骤S101-S103中,通过配置录制切面和录制切点的形式,自动识别需要录制的服务,即需要测试的服务,并在录制切点位置执行录制操作,记录该服务所调用的方法及该方法的入参和出参,得到录制数据。录制数据中还可以包括录制切点。其中,通过AOP技术配置录制切面和录制切点。AOP(Aspect Oriented Programming,面向切面编程)是通过预编译方式和运行期间动态代理实现程序功能的统一维护的一种技术。切面(Aspect)指需要执行操作步骤和行为,泛指交叉业务逻辑。切点是指需要执行操作的位置,切面具体织入的位置。
在本实施例中,在得到录制数据之后,为每个录制的服务生成一个唯一标识,并建立该唯一标识和录制数据的映射关系,以便压测使用。
在可选的实施例中,可以将录制数据以及唯一标识和录制数据的映射关系存储在数据库中,便于后续压测时使用。
在步骤S104中,可以利用压测工具如Apache Jmeter、Loadrunner等编写压测脚本,与现有技术不同的是,本实施例的压测脚本只需要编写录制时生成的唯一标识即可。编写压测脚本之后,通过该压测工具发起压力测试请求。
在步骤S105中,可以将压力测试请求的标识与上述映射关系中记录的待录制的服务对应的标识进行匹配,从而获取到匹配到的待录制的服务对应的录制数据。
在步骤S106中,可以解析录制数据,从中得到待测试服务所调用的方法及其入参和录制切点。根据该录制切点,确定回放位置,在该回放位置,根据待测试服务所调用的方法及其入参,调用真实线上环境,以线上请求该待测试服务,得到回放结果。
在步骤S107中,自动将该回放结果和录制的出参进行对比,根据对比结果确定该待测试服务的性能。若回放结果与出参一致,则该待测试服务功能正常、性能稳定,则可以加大压力继续测试。若回放结果与出参不一致,则该测试服务功能异常、性能不稳定,则可以根据回放结果进行故障排查。
本发明实施例的测试方法,不需要写入带有压测标识的影子数据,避免了在压测时对线上数据库或缓存进行读写而产生测试数据,避免对线上真实流程产生影响;能够全面压测线上服务,降低因某些模块没有真实压测到,导致线上真实用户因流量大而导致服务宕机的风险,解决手动编写的压测数据无法完全覆盖线上用户访问的所有场景而导致某些压测场景遗漏的风险;利用录制数据对线上真实环境进行压测,解决因备份压测数据库或者缓存的性能和线上真实环境性能存在差异,压测结果存在偏差的问题。
图4是本发明另一实施例的测试方法的主要步骤的流程示意图,如图4所示,该方法包括:
步骤S401:配置录制切面和录制切点;
步骤S402:根据所述录制切面,自动识别待录制的服务;
步骤S403:根据所述录制切点,确定执行录制操作的位置,并在所述位置执行录制操作,得到录制数据;
步骤S404:确定与所述待录制的服务对应的标识,建立所述标识与所述录制数据的映射关系;
步骤S405:将所述录制数据和所述映射关系写入数据库,以存储所述录制数据和所述映射关系;
步骤S406:接收压力测试请求,并确定所述压力测试请求的标识;
步骤S407:将所述压力测试请求的标识与所述映射关系中记录的待录制的服务对应的标识进行匹配,获取匹配到的待录制的服务对应的录制数据;其中,所述录制数据是在线上流量访问待测试服务时录制的,所述录制数据包括所述待测试服务所调用的方法以及所述方法的入参和出参;
步骤S408:回放所述录制数据,得到回放结果;
步骤S409:对比所述出参和所述回放结果,得到测试结果。
本发明实施例的测试方法,避免了在压测时对线上数据库或缓存进行读写而产生测试数据,避免对线上真实流程产生影响;能够全面压测线上服务,降低因某些模块没有真实压测到,导致线上真实用户因流量大而导致服务宕机的风险,解决手动编写的压测数据无法完全覆盖线上用户访问的所有场景而导致某些压测场景遗漏的风险;利用录制数据对线上真实环境进行压测,解决因备份压测数据库或者缓存的性能和线上真实环境性能存在差异,压测结果存在偏差的问题。
图5是本发明另一实施例的压测方法的流程示意图,在图5中,流程1-7为线上流量的访问流程。
如图5所示,该方法可以包括录制端、数据中心、回放端和压测工具。其中,录制端包含两个操作:AOP录制切面和写入日志操作。AOP录制切面通过配置录制切面和录制切点的形式,自动识别需要录制的服务,并在切点位置执行录制操作,记录方法访问的入参和出参数据,同时为每个录制的服务生成一个唯一标识,以便压测使用。写入日志操作,在AOP切面确定在某个位置执行录制操作后,会将录制的方法入参、出参写入到数据中心,同时将每个方法的入参和出参进行存储。
数据中心:包含日志接收器和数据库两个部分。日志接收器负责接收录制端记录方法的入参和出参等日志数据。数据库负责对接收录制端记录方法的入参和出参等日志数据进行存储。
回放端:包含回放worker服务器、AOP回放切面、回放服务器和自定义对比工具等。回放worker服务:当压测工具发起压力测试请求后,触发回放worker服务器访问数据中心,根据压力测试请求的唯一标识,获取到已经录制并且存放在数据中心的线上流量真实各自方法的入参和出参等日志。AOP回放切面及回放服务:通过回放worker服务器获取到的线上流量访问的方法及入参,AOP切面会在切点位置的执行回放服务,回放服务根据对应方法和入参调用真实线上环境,并且获取到本次回放的结果。自定义对比工具:自定义对比工具将本次回放服务返回的数据和之前已经录制的结果进行对比,同时根据对比结果调整压力测试的并发数等参数,以确定待测试服务的性能。
压测工具:通过压测工具手动编写压测脚本,和现有技术的不同是本次的压测脚本只需要编写录制端在录制时生成的唯一标识即可,至于压测数据,会根据该唯一标识在已经录制的数据中心中可以获取到。
在本实施例中,当需要对线上流量访问数据进行录制时,录制端会通过AOP录制切面对线上流量访问方法的入参、出参进行录制(图3中流程A),生成每次访问的唯一标识,存放在数据中心(图3中流程B)。当需要进行压力测试时,压测脚本配置好已经记录的唯一标识访问回放端(图3中流程①),回放端根据请求的唯一标识,请求数据中心(图3中流程②),获取到已经录制并且存放在数据中心的入参和出参日志,并且根据这些方法和日志再次请求线上服务(图3中流程③),获取到线上请求的结果后,自定义对比工具将原来记录的数据和本次请求的结果进行对比,同时根据对比结果综合分析出本次压测的最终结果。
本发明实施例的压测方法,不需要写入带有压测标识的影子数据,避免了在压测时对线上数据库或缓存进行读写而产生测试数据,避免对线上真实流程产生影响;能够全面压测线上服务,降低因某些模块没有真实压测到,导致线上真实用户因流量大而导致服务宕机的风险,解决手动编写的压测数据无法完全覆盖线上用户访问的所有场景而导致某些压测场景遗漏的风险;利用录制数据对线上真实环境进行压测,解决因备份压测数据库或者缓存的性能和线上真实环境性能存在差异,压测结果存在偏差的问题。
图6是本发明实施例的测试装置600的主要模块的示意图,如图6所示,该装置600包括:
接收模块601,用于接收压力测试请求,并确定所述压力测试请求的标识;
获取模块602,用于根据所述压力测试请求的标识,获取录制数据;其中,所述录制数据是在线上流量访问待测试服务时录制的,所述录制数据包括所述待测试服务所调用的方法以及所述方法的入参和出参;
回放模块603,用于回放所述录制数据,得到回放结果;
对比模块604,用于对比所述出参和所述回放结果,得到测试结果。
可选地,所述装置还包括录制模块,用于:配置录制切面和录制切点;根据所述录制切面,自动识别待录制的服务;根据所述录制切点,确定执行录制操作的位置,并在所述位置执行录制操作,得到录制数据。
可选地,所述录制模块还用于:确定与所述待录制的服务对应的标识;建立所述标识与所述录制数据的映射关系。
可选地,所述装置还包括存储模块,用于将所述录制数据和所述映射关系写入数据库,以存储所述录制数据和所述映射关系。
可选地,所述获取模块还用于:将所述压力测试请求的标识与所述映射关系中记录的待录制的服务对应的标识进行匹配,获取匹配到的待录制的服务对应的录制数据。
可选地,所述录制数据还包括录制切点;
所述回放模块还用于:根据所述录制切点,确定回放位置,并在所述回放位置回放所述录制数据。
可选地,所述回放模块还用于在所述回放位置,根据所述待测试服务所调用的方法以及所述方法的入参,线上请求所述待测试服务。
本发明实施例的压测装置,不需要写入带有压测标识的影子数据,避免了在压测时对线上数据库或缓存进行读写而产生测试数据,避免对线上真实流程产生影响;能够全面压测线上服务,降低因某些模块没有真实压测到,导致线上真实用户因流量大而导致服务宕机的风险,解决手动编写的压测数据无法完全覆盖线上用户访问的所有场景而导致某些压测场景遗漏的风险;利用录制数据对线上真实环境进行压测,解决因备份压测数据库或者缓存的性能和线上真实环境性能存在差异,压测结果存在偏差的问题。
上述装置可执行本发明实施例所提供的方法,具备执行方法相应的功能模块和有益效果。未在本实施例中详尽描述的技术细节,可参见本发明实施例所提供的方法。
图7示出了可以应用本发明实施例的测试方法或测试装置的示例性系统架构700。
如图7所示,系统架构700可以包括终端设备701、702、703,网络704和服务器705。网络704用以在终端设备701、702、703和服务器705之间提供通信链路的介质。网络704可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用终端设备701、702、703通过网络704与服务器705交互,以接收或发送消息等。终端设备701、702、703上可以安装有各种通讯客户端应用,例如购物类应用、网页浏览器应用、搜索类应用、即时通信工具、邮箱客户端、社交平台软件等。
终端设备701、702、703可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、膝上型便携计算机和台式计算机等等。
服务器705可以是提供各种服务的服务器,例如对用户利用终端设备701、702、703所浏览的购物类网站提供支持的后台管理服务器。后台管理服务器可以对接收到的产品信息查询请求等数据进行分析等处理,并将处理结果(例如目标推送信息、产品信息)反馈给终端设备。
需要说明的是,本发明实施例所提供的测试方法一般由服务器705执行,相应地,测试装置一般设置于服务器705中。
应该理解,图7中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
下面参考图8,其示出了适于用来实现本发明实施例的终端设备的计算机系统800的结构示意图。图8示出的终端设备仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图8所示,计算机系统800包括中央处理单元(CPU)801,其可以根据存储在只读存储器(ROM)802中的程序或者从存储部分808加载到随机访问存储器(RAM)803中的程序而执行各种适当的动作和处理。在RAM 803中,还存储有系统800操作所需的各种程序和数据。CPU 801、ROM 802以及RAM 803通过总线804彼此相连。输入/输出(I/O)接口805也连接至总线804。
以下部件连接至I/O接口805:包括键盘、鼠标等的输入部分806;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分807;包括硬盘等的存储部分808;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分809。通信部分809经由诸如因特网的网络执行通信处理。驱动器810也根据需要连接至I/O接口805。可拆卸介质811,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器810上,以便于从其上读出的计算机程序根据需要被安装入存储部分808。
特别地,根据本发明公开的实施例,上文参考流程图描述的过程可以被实现为计算机软件程序。例如,本发明公开的实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施例中,该计算机程序可以通过通信部分809从网络上被下载和安装,和/或从可拆卸介质811被安装。在该计算机程序被中央处理单元(CPU)801执行时,执行本发明的系统中限定的上述功能。
需要说明的是,本发明所示的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本发明中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本发明中,计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
附图中的流程图和框图,图示了按照本发明各种实施例的系统、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,上述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图或流程图中的每个方框、以及框图或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本发明实施例中所涉及到的模块可以通过软件的方式实现,也可以通过硬件的方式来实现。所描述的模块也可以设置在处理器中,例如,可以描述为:一种处理器包括发送模块、获取模块、确定模块和第一处理模块。其中,这些模块的名称在某种情况下并不构成对该单元本身的限定,例如,发送模块还可以被描述为“向所连接的服务端发送图片获取请求的模块”。
作为另一方面,本发明还提供了一种计算机可读介质,该计算机可读介质可以是上述实施例中描述的设备中所包含的;也可以是单独存在,而未装配入该设备中。上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被一个该设备执行时,使得该设备包括:
接收压力测试请求,并确定所述压力测试请求的标识;
根据所述压力测试请求的标识,获取录制数据;其中,所述录制数据是在线上流量访问待测试服务时录制的,所述录制数据包括所述待测试服务所调用的方法以及所述方法的入参和出参;
回放所述录制数据,得到回放结果;
对比所述出参和所述回放结果,得到测试结果。
本发明实施例的技术方案,不需要写入带有压测标识的影子数据,避免了在压测时对线上数据库或缓存进行读写而产生测试数据,避免对线上真实流程产生影响;能够全面压测线上服务,降低因某些模块没有真实压测到,导致线上真实用户因流量大而导致服务宕机的风险,解决手动编写的压测数据无法完全覆盖线上用户访问的所有场景而导致某些压测场景遗漏的风险;利用录制数据对线上真实环境进行压测,解决因备份压测数据库或者缓存的性能和线上真实环境性能存在差异,压测结果存在偏差的问题。
上述具体实施方式,并不构成对本发明保护范围的限制。本领域技术人员应该明白的是,取决于设计要求和其他因素,可以发生各种各样的修改、组合、子组合和替代。任何在本发明的精神和原则之内所作的修改、等同替换和改进等,均应包含在本发明保护范围之内。

Claims (10)

1.一种测试方法,其特征在于,包括:
接收压力测试请求,并确定所述压力测试请求的标识;
根据所述压力测试请求的标识,获取录制数据;其中,所述录制数据是在线上流量访问待测试服务时录制的,所述录制数据包括所述待测试服务所调用的方法以及所述方法的入参和出参;
回放所述录制数据,以对所述待测试服务进行测试,得到回放结果;
对比所述出参和所述回放结果,得到测试结果。
2.根据权利要求1所述的方法,其特征在于,在接收压力测试请求之前,所述方法还包括:
配置录制切面和录制切点;
根据所述录制切面,自动识别待录制的服务;
根据所述录制切点,确定执行录制操作的位置,并在所述位置执行录制操作,得到录制数据。
3.根据权利要求2所述的方法,其特征在于,在得到录制数据之后,所述方法还包括:
确定与所述待录制的服务对应的标识;
建立所述标识与所述录制数据的映射关系。
4.根据权利要求3所述的方法,其特征在于,在建立所述标识与所述录制数据的映射关系之后,所述方法还包括:将所述录制数据和所述映射关系写入数据库,以存储所述录制数据和所述映射关系。
5.根据权利要求4所述的方法,其特征在于,根据所述压力测试请求的标识,获取录制数据包括:
将所述压力测试请求的标识与所述映射关系中记录的待录制的服务对应的标识进行匹配,获取匹配到的待录制的服务对应的录制数据。
6.根据权利要求2所述的方法,其特征在于,所述录制数据还包括录制切点;
回放所述录制数据包括:根据所述录制切点,确定回放位置,并在所述回放位置回放所述录制数据。
7.根据权利要求6所述的方法,其特征在于,在所述回放位置回放所述录制数据包括:在所述回放位置,根据所述待测试服务所调用的方法以及所述方法的入参,线上请求所述待测试服务。
8.一种测试装置,其特征在于,包括:
接收模块,用于接收压力测试请求,并确定所述压力测试请求的标识;
获取模块,用于根据所述压力测试请求的标识,获取录制数据;其中,所述录制数据是在线上流量访问待测试服务时录制的,所述录制数据包括所述待测试服务所调用的方法以及所述方法的入参和出参;
回放模块,用于回放所述录制数据,以对所述待测试服务进行测试,得到回放结果;
对比模块,用于对比所述出参和所述回放结果,得到测试结果。
9.一种电子设备,其特征在于,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-7中任一所述的方法。
10.一种计算机可读介质,其上存储有计算机程序,其特征在于,所述程序被处理器执行时实现如权利要求1-7中任一所述的方法。
CN202110410227.3A 2021-04-16 2021-04-16 测试方法和装置 Pending CN113076251A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202110410227.3A CN113076251A (zh) 2021-04-16 2021-04-16 测试方法和装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202110410227.3A CN113076251A (zh) 2021-04-16 2021-04-16 测试方法和装置

Publications (1)

Publication Number Publication Date
CN113076251A true CN113076251A (zh) 2021-07-06

Family

ID=76617722

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110410227.3A Pending CN113076251A (zh) 2021-04-16 2021-04-16 测试方法和装置

Country Status (1)

Country Link
CN (1) CN113076251A (zh)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113595829A (zh) * 2021-07-30 2021-11-02 北京达佳互联信息技术有限公司 压力测试方法、装置、电子设备及存储介质
CN114978944A (zh) * 2022-05-13 2022-08-30 北京百度网讯科技有限公司 压力测试方法、装置及计算机程序产品
CN116719750A (zh) * 2023-08-11 2023-09-08 海马云(天津)信息技术有限公司 软件测试方法及装置、服务器设备和存储介质

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113595829A (zh) * 2021-07-30 2021-11-02 北京达佳互联信息技术有限公司 压力测试方法、装置、电子设备及存储介质
CN114978944A (zh) * 2022-05-13 2022-08-30 北京百度网讯科技有限公司 压力测试方法、装置及计算机程序产品
CN116719750A (zh) * 2023-08-11 2023-09-08 海马云(天津)信息技术有限公司 软件测试方法及装置、服务器设备和存储介质
CN116719750B (zh) * 2023-08-11 2023-12-22 海马云(天津)信息技术有限公司 软件测试方法及装置、服务器设备和存储介质

Similar Documents

Publication Publication Date Title
CN113076251A (zh) 测试方法和装置
CN109002395B (zh) 一种代码覆盖率管理方法和装置
CN111460129B (zh) 标识生成的方法、装置、电子设备和存储介质
CN110858172A (zh) 一种自动化测试代码生成方法和装置
EP3937022B1 (en) Method and apparatus of monitoring interface performance of distributed application, device and storage medium
CN110647460B (zh) 一种测试资源管理方法、装置和测试客户端
CN113076253A (zh) 一种测试方法和测试装置
CN109218041B (zh) 用于服务器系统的请求处理方法和装置
CN113127057A (zh) 多任务并行执行的方法和装置
CN115705190A (zh) 依赖程度的确定方法及装置
CN109522202B (zh) 一种软件测试的方法和装置
CN107315672B (zh) 用于监控服务器的方法和装置
CN113127356A (zh) 压测方法、装置、电子设备及存储介质
CN112650689A (zh) 测试方法、装置、电子设备及存储介质
CN114465919B (zh) 一种网络服务测试方法、系统、电子设备及存储介质
CN112948195B (zh) 接口测试的方法、装置、电子设备和存储介质
CN112532734B (zh) 报文敏感信息检测方法和装置
CN112131095B (zh) 压力测试方法和装置
CN109756393B (zh) 信息处理方法、系统、介质和计算设备
CN113468218A (zh) 一种对数据库慢sql进行监测和管理的方法和装置
CN113434382A (zh) 数据库性能监控方法、装置、电子设备及计算机可读介质
CN112579428A (zh) 接口测试的方法、装置、电子设备和存储介质
CN113778777A (zh) 一种日志回放方法和装置
CN112988560A (zh) 测试系统健壮性的方法和装置
CN112860538A (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