CN112486807A - 一种压力测试方法、装置、电子设备和可读存储介质 - Google Patents

一种压力测试方法、装置、电子设备和可读存储介质 Download PDF

Info

Publication number
CN112486807A
CN112486807A CN202011294192.3A CN202011294192A CN112486807A CN 112486807 A CN112486807 A CN 112486807A CN 202011294192 A CN202011294192 A CN 202011294192A CN 112486807 A CN112486807 A CN 112486807A
Authority
CN
China
Prior art keywords
pressure test
pressure
cluster
suite
image file
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
CN202011294192.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.)
China Citic Bank Corp Ltd
Original Assignee
China Citic Bank Corp 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 China Citic Bank Corp Ltd filed Critical China Citic Bank Corp Ltd
Priority to CN202011294192.3A priority Critical patent/CN112486807A/zh
Publication of CN112486807A publication Critical patent/CN112486807A/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/3668Software testing
    • G06F11/3672Test management
    • G06F11/3688Test management for test execution, e.g. scheduling of test suites
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/3668Software testing
    • G06F11/3696Methods or tools to render software testable
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/61Installation
    • G06F8/63Image based installation; Cloning; Build to order
    • 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/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • 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/44Arrangements for executing specific programs
    • G06F9/455Emulation; Interpretation; Software simulation, e.g. virtualisation or emulation of application or operating system execution engines
    • G06F9/45533Hypervisors; Virtual machine monitors
    • G06F9/45558Hypervisor-specific management and integration aspects
    • G06F2009/45591Monitoring or debugging support

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • Quality & Reliability (AREA)
  • Debugging And Monitoring (AREA)

Abstract

本发明涉及计算机测试技术领域,具体涉及一种压力测试方法、装置、电子设备和可读存储介质。所述方法包括:将压力测试基础镜像文件和压力测试套件集群推送至预设云容器;其中,所述压力测试套件集群包括至少一个压力测试套件;根据被测系统压力测试需求,利用压力测试套件集群编辑生成压力测试模型;其中所述压力测试模型组合有至少两种压力测试套件;利用生成的压力测试模型对被测系统执行压力测试。本申请公开的方案节省了多个压力测试程序的占用空间,提升了制作压力测试模型的效率,而且能够进行压力测试问题溯源。

Description

一种压力测试方法、装置、电子设备和可读存储介质
技术领域
本发明涉及计算机测试技术领域,具体涉及一种压力测试方法、装置、电子设备和可读存储介质。
背景技术
面对复杂的业务系统软件的稳定性测试需求,目前主流的技术方案存在着一些技术问题,一是通过单一压力测试模型验证线上服务特定情况的服务稳定性,需要编写自动化脚本实现调度逻辑,组织多种压力测试模型叠加场景,这种方式缺乏灵活性;二是稳定性测试往往耗时长,多个项目同时进行时需要分别独占一份测试资源,缺乏有效隔离及共用条件,造成测试资源的浪费。三是压力测试模型的问题溯源往往只保存了测试case,未保存完整的压力测试环境,问题溯源无法保证溯源环境的一致性。尤其是在解决金融行业稳定性测试过程时,这些问题就更明显。
发明内容
本申请的目的旨在至少能解决上述的技术缺陷之一。本申请所采用的技术方案如下:
第一方面,本申请实施例公开了一种压力测试方法,所述方法包括:
将压力测试基础镜像文件和压力测试套件集群推送至预设云容器;其中,所述压力测试套件集群包括至少一个压力测试套件;
根据被测系统压力测试需求,利用压力测试套件集群编辑生成压力测试模型;其中所述压力测试模型组合有至少两种压力测试套件;
利用生成的压力测试模型对被测系统执行压力测试。
进一步地,所述将压力测试基础镜像文件推送至预设容器包括:
利用云容器引擎,构建被测系统压力测试操作系统和压力测试框架程序的镜像文件并确定为基础镜像文件;
将所述基础镜像文件推送至预设云容器。
进一步地,将压力测试套件集群推送至预设云容器包括:
以基础镜像文件为模板,获取压力测试套件集群;其中每一个压力测试套件根据基础镜像文件模板生成;
将压力测试套件集群中的每一个压力测试套件制作为镜像文件;
将压力测试套件集群的镜像文件推送至预设云容器。
进一步地,将压力测试套件集群中的每一个压力测试套件制作为镜像文件之后,所述方法还包括:
为每一个压力测试套件的镜像文件添加唯一标签;其中所述标签用于区别不同的压力测试套件。
进一步地,所述利用压力测试套件集群编辑生成压力测试模型包括:
根据被测系统压力测试需求,编写yaml文件组合至少两个压力测试套件生成压力测试模型;
将所述压力测试模型推送至预设云容器并生成容器化的压力测试模型。
进一步地,所述方法还包括:将所述yaml文件和容器化的压力测试套件集群保存至本地;其中所述yaml文件中包括压力测试环境参数。
第二方面,本申请实施例提供了一种压力测试装置,所述装置包括:通讯模块、生成模块和执行模块,其中,
所述通讯模块,用于将压力测试基础镜像文件和压力测试套件集群推送至预设云容器;其中,所述压力测试套件集群包括至少一个压力测试套件;
所述生成模块,用于根据被测系统压力测试需求,利用压力测试套件集群编辑生成压力测试模型;其中所述压力测试模型组合有至少两种压力测试套件;
所述执行模块,用于利用生成的压力测试模型对被测系统执行压力测试。
具体地,所述生成模块具体用于利用云容器引擎,构建被测系统压力测试操作系统和压力测试框架程序的镜像文件并确定为基础镜像文件;
所述通讯模块将所述基础镜像文件推送至预设云容器。
第三方面,本申请实施例提供了一种电子设备,包括处理器和存储器;
所述存储器,用于存储操作指令;
所述处理器,用于通过调用所述操作指令,执行上述任一实施例中所述的方法。
第四方面,本申请实施例提供了一种计算机可读存储介质,所述存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现上述任一实施例所述的方法。
本申请实施例提供压力测试方案基于容器云构建压力测试基础镜像文件和压力测试套件,将所述压力测试环境和压力测试套件集群容器化后对被测系统执行压力测试进程。本申请的有益效果至少包括以下之一:
(1)本实施例中以基础镜像和测试套件实现了压力测试模型容器化,即多种压力测试模型共用基础镜像,多个项目同时进行不仅屏蔽同一测试系统环境下发压程序之间的相互影响,而且节省了多个压力测试程序的占用空间,多个项目可以共用一个物理环境开展工作,节省测试资源成本。
(2)本申请实施例所述的压力测试方案利用容器云调度技术,通过编写yaml文件将多个压力测试套件进行自由组合,生成新的叠加型压力测试套件即满足被测系统的压力测试模型提升了制作压力测试模型的效率。
(3)在本申请实施例中可以将压力测试环境文件保存至本地仓库,可以一键还原便于问题溯源。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对本申请实施例描述中所需要使用的附图作简单地介绍。
图1为本申请实施例提供的一种压力测试方法的流程示意图;
图2为本申请实施例提供的一种压力测试装置的示意图;
图3为本申请实施例提供的一种电子设备的结构示意图。
具体实施方式
下面详细描述本申请的实施例,所述实施例的示例在附图中示出,其中自始至终相同或类似的标号表示相同或类似的元件或具有相同或类似功能的元件。下面通过参考附图描述的实施例是示例性的,仅用于解释本申请,而不能解释为对本发明的限制。
本技术领域技术人员可以理解,除非特意声明,这里使用的单数形式“一”、“一个”、“所述”和“该”也可包括复数形式,其中的“第一”“第二”等只是为了介绍清楚方案而进行的对象区分定义,并不对对象本身进行限制,当然“第一”和“第二”限定的对象可能是同一个终端、设备和用户等,也可能是同一种终端、设备和用户。应该进一步理解的是,本申请的说明书中使用的措辞“包括”是指存在所述特征、整数、步骤、操作、元件和/或组件,但是并不排除存在或添加一个或多个其他特征、整数、步骤、操作、元件、组件和/或它们的组。这里使用的措辞“和/或”包括一个或更多个相关联的列出项的全部或任一单元和全部组合。
此外应理解,本申请实施例中“至少一个”是指一个或者多个,“多个”是指两个或两个以上。“和/或”,描述关联对象的关联关系,表示可以存在三种关系,例如,A和/或B,可以表示:单独存在A,同时存在A和B,单独存在B的情况,其中A、B可以是单数或者复数。字符“/”一般表示前后关联对象是一种“或”的关系。“以下至少一(项)个”或其类似表达,是指的这些项中的任意组合,包括单项(个)或复数项(个)的任意组合。例如,a、b或c中的至少一项(个),可以表示:a,b,c,a和b,a和c,b和c,或a、b和c,其中a、b、c可以是单个,也可以是多个。
为使本申请的目的、技术方案和优点更加清楚,下面将结合附图对本申请实施方式作进一步地详细描述。
下面介绍一些下面实施例可能用到或用于辅助解释实施例技术方案的概念、术语或装置:
容器就是一个操作系统的最小镜像,在上面可以运行应用程序,常用的容器就是Docker。
Docker是一个开源的应用容器引擎,基于Go语言并遵从Apache2.0协议开源。Docker可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化。Docker file是一个包含用于组合映像的命令的文本文档。可以使用在命令行中调用任何命令。Docker通过读取Docker file中的指令自动生成映像。
YAML是一个可读性高,用来表达数据序列化的格式。YAML参考了其他多种语言,包括:C语言、Python、Perl。
下面以具体地实施例对本申请的技术方案以及本申请的技术方案如何解决上述技术问题进行详细说明。下面这几个具体的实施例可以相互结合,对于相同或相似的概念或过程可能在某些实施例中不再赘述。下面将结合附图,对本申请的实施例进行描述。
下面以具体地实施例对本申请的技术方案以及本申请的技术方案如何解决上述技术问题进行详细说明。下面这几个具体的实施例可以相互结合,对于相同或相似的概念或过程可能在某些实施例中不再赘述。下面将结合附图,对本申请的实施例进行描述。
图1示出了本申请实施例提供的一种压力测试的流程示意图,如图1所示,该方法主要可以包括:
S101、将压力测试基础镜像文件和压力测试套件集群推送至预设云容器;其中,所述压力测试套件集群包括至少一个压力测试套件;
在进一步地实施例中,利用云容器引擎,构建被测系统压力测试操作系统和压力测试框架程序的镜像文件并确定为基础镜像文件,具体实现过程为通过镜像控制程序,编写dockerfile,选择操作系统镜像和发压框架程序,使用docker build完成基础镜像的构建,并使用docker push推送基础镜像至容器云镜像仓库。
在进一步地实施例中,将压力测试套件集群推送至预设云容器包括通过镜像控制程序,以基础镜像为模板,分别添加多种发压套件(即压力测试套件,也可称之为测试case),每种发压套件制作成一个docker镜像,添加标签识别不同发压套件后利用dockerpush推送至容器云的镜像仓库,具体实现过程为:
步骤1、以基础镜像文件为模板,获取压力测试套件集群;其中每一个压力测试套件根据基础镜像文件模板生成;
步骤2、将压力测试套件集群中的每一个压力测试套件制作为镜像文件;为每一个压力测试套件的镜像文件添加唯一标签;其中所述标签用于区别不同的压力测试套件;
步骤3、将压力测试套件集群的镜像文件推送至预设云容器。
S102、根据被测系统压力测试需求,利用压力测试套件集群编辑生成压力测试模型;其中所述压力测试模型组合有至少两种压力测试套件;
在本申请实施例中,在步骤S102中之前通过镜像控制程序下发基础镜像至测试环境,对测试发压环境进行预热,作为应用镜像的底层,多个应用镜像复用基础镜像,节省了镜像存储占用空间,节省了压力测试套件集群生成时间。
在本申请实施例中,步骤是S102具体实现过程为:
步骤1、根据被测系统压力测试需求,编写yaml文件组合至少两个压力测试套件生成压力测试模型;具体地,根据发压需求即被测系统压力测试需求,编写yaml文件对应用压力测试套件进行组合应用以组织编写生成预期发压模型形成多套件叠加的压力测试模型(也可称之为发压模型),例如将长期稳定性发压套件(测试案例)和随机脉冲发压套件(测试案例)进行组合叠加形成长期稳定型+随机脉冲型发压模型,用来模拟线上瞬时流量洪峰,并添加资源限制(CPU,Memery,IO,Network)条件。
步骤2、将所述压力测试模型推送至预设云容器并生成容器化的压力测试模型。具体地,在将所述压力测试模型推送至预设云容器后再通过云容器平台下发yaml数据,生成预期压力测试模型容器化压测测试套件集群。
本申请实施例所述的压力测试方法通过引入容器云调度技术通过描述yaml文件实现了自由组合发压测试套件形成预期的发压模型,能够无须用代码实现调度逻辑,解决稳定性测试中多种发压模型组织灵活性差的问题。
S103、利用生成的压力测试模型对被测系统执行压力测试。
在进一步地实施例中,所述方法还包括:将所述yaml文件和容器化的压力测试套件集群保存至本地;其中所述yaml文件中包括压力测试环境参数。即按照压力测试模型对被测系统完成测试后,为了便于将来问题的溯源可以将yaml文件和压力测试套件集群保存至本地镜像仓库,因yaml文件中包含压力测试模型环境资源参数及容器化的测试套件环境,以保障未来溯源时环境恢复的一致性。
基于图1所示的压力测试方法,另一方面本申请实施例提供了一种压力测试装置,所述装置如图2所示,所述装置可以包括:201通讯模块、202生成模块和203执行模块,其中,
所述201通讯模块,用于将压力测试基础镜像文件和压力测试套件集群推送至预设云容器;其中,所述压力测试套件集群包括至少一个压力测试套件;
所述202生成模块,用于根据被测系统压力测试需求,利用压力测试套件集群编辑生成压力测试模型;其中所述压力测试模型组合有至少两种压力测试套件;
所述203执行模块,用于利用生成的压力测试模型对被测系统执行压力测试。
具体地,所述202生成模块具体用于利用云容器引擎,构建被测系统压力测试操作系统和压力测试框架程序的镜像文件并确定为基础镜像文件;
所述201通讯模块将所述基础镜像文件推送至预设云容器。
可以理解的是,本实施例中的压力测试装置的上述各组成设备具有实现图1中所示的实施例中的方法相应步骤的功能。该功能可以通过硬件实现,也可以通过硬件执行相应的软件实现。该硬件或软件包括一个或多个与上述功能相对应的模块或系统。上述模块和系统可以是软件和/或硬件,上述各模块和系统可以单独实现,也可以多个模块和系统集成实现。对于上述各模块和系统的功能描述具体可以参见图1中所示实施例中的方法的对应描述,因此,其所能达到的有益效果可参考上文所提供的对应的方法中的有益效果,此处不再赘述。
可以理解的是,本发明实施例示意的结构并不构成对压力测试装置的具体结构的具体限定。在本申请另一些实施例中,压力测试装置可以包括比图示更多或更少的部件,或者组合某些部件,或者拆分某些部件,或者不同的部件布置。图示的部件可以以硬件,软件或软件和硬件的组合实现。
本申请实施例提供了一种电子设备,包括处理器和存储器;
存储器,用于存储操作指令;
处理器,用于通过调用操作指令,执行本申请任一实施方式中所提供的压力测试方法。
作为一个示例,图3示出了本申请实施例所适用的一种电子设备的结构示意图,如图3所示,该电子设备300包括:处理器301和存储器303。其中,处理器301和存储器303相连,如通过总线302相连。可选的,电子设备300还可以包括收发器304。需要说明的是,实际应用中收发器304不限于一个。可以理解的是,本发明实施例示意的结构并不构成对电子设备300的具体结构的具体限定。在本申请另一些实施例中,电子设备300可以包括比图示更多或更少的部件,或者组合某些部件,或者拆分某些部件,或者不同的部件布置。图示的部件可以以硬件,软件或软件和硬件的组合实。可选地,电子设备还可以包括显示屏305,用于显示图像,或需要时接收用户的操作指令。
其中,处理器301应用于本申请实施例中,用于实现上述方法实施例所示的方法。收发器304可以包括接收机和发射机,收发器304应用于本申请实施例中,用于执行时实现本申请实施例的电子设备与其他设备通信的功能。
处理器301可以是CPU(Central Processing Unit,中央处理器),通用处理器,DSP(Digital Signal Processor,数据信号处理器),ASIC(Application SpecificIntegrated Circuit,专用集成电路),FPGA(Field Programmable Gate Array,现场可编程门阵列)或者其他可编程逻辑器件、晶体管逻辑器件、硬件部件或者其任意组合。其可以实现或执行结合本申请公开内容所描述的各种示例性的逻辑方框,模块和电路。处理器301也可以是实现计算功能的组合,例如包含一个或多个微处理器组合,DSP和微处理器的组合等。
处理器301也可以包括一个或多个处理单元,例如:处理器301可以包括应用处理器(application processor,AP),调制解调处理器,图形处理器(graphicsprocessingunit,GPU),图像信号处理器(image signal processor,ISP),控制器,存储器,视频编解码器,数字信号处理器(digital signal processor,DSP),基带处理器,和/或神经网络处理器(Neural-network Processing Unit,NPU)等。其中,不同的处理单元可以是独立的器件,也可以集成在一个或多个处理器中。其中,控制器可以是电子设备300的神经中枢和指挥中心。控制器可以根据指令操作码和时序信号,产生操作控制信号,完成取指令和执行指令的控制。处理器301中还可以设置存储器,用于存储指令和数据。在一些实施例中,处理器301中的存储器为高速缓冲存储器。该存储器可以保存处理器301刚用过或循环使用的指令或数据。如果处理器301需要再次使用该指令或数据,可从所述存储器中直接调用。避免了重复存取,减少了处理器301的等待时间,因而提高了系统的效率。
处理器301可以运行本申请实施例提供的压力测试方法,以便于降低用户的操作复杂度、提高终端设备的智能化程度,提升用户的体验。处理器301可以包括不同的器件,比如集成CPU和GPU时,CPU和GPU可以配合执行本申请实施例提供的压力测试方法,比如压力测试方法中部分算法由CPU执行,另一部分算法由GPU执行,以得到较快的处理效率。
总线302可包括一通路,在上述组件之间传送信息。总线302可以是PCI(Peripheral Component Interconnect,外设部件互连标准)总线或EISA(ExtendedIndustry Standard Architecture,扩展工业标准结构)总线等。总线302可以分为地址总线、数据总线、控制总线等。为便于表示,图3中仅用一条粗线表示,但并不表示仅有一根总线或一种类型的总线。
存储器303可以是ROM(Read Only Memory,只读存储器)或可存储静态信息和指令的其他类型的静态存储设备,RAM(Random Access Memory,随机存取存储器)或者可存储信息和指令的其他类型的动态存储设备,也可以是EEPROM(Electrically ErasableProgrammable Read Only Memory,电可擦可编程只读存储器)、CD-ROM(Compact DiscRead Only Memory,只读光盘),也可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件,闪存器件,通用闪存存储器(universal flashstorage,UFS),或其他光盘存储、光碟存储(包括压缩光碟、激光碟、光碟、数字通用光碟、蓝光光碟等)、磁盘存储介质或者其他磁存储设备、或者能够用于携带或存储具有指令或数据结构形式的期望的程序代码并能够由计算机存取的任何其他介质,但不限于此。
可选的,存储器303用于存储执行本申请方案的应用程序代码,并由处理器301来控制执行。处理器301用于执行存储器303中存储的应用程序代码,以实现本申请任一实施方式中所提供的压力测试方法。
存储器303可以用于存储计算机可执行程序代码,所述可执行程序代码包括指令。处理器301通过运行存储在存储器303的指令,从而执行电子设备300的各种功能应用以及数据处理。存储器303可以包括存储程序区和存储数据区。其中,存储程序区可存储操作系统,应用程序的代码等。存储数据区可存储电子设备300使用过程中所创建的数据(比如相机应用采集的图像、视频等)等。
存储器303还可以存储本申请实施例提供的压力测试方法对应的一个或多个计算机程序。该一个或多个计算机程序被存储在上述存储器303中并被配置为被该一个或多个处理器301执行,该一个或多个计算机程序包括指令,上述指令可以用于执行上述相应实施例中的各个步骤。
当然,本申请实施例提供的压力测试方法的代码还可以存储在外部存储器中。这种情况下,处理器301可以通过外部存储器接口运行存储在外部存储器中的压力测试方法的代码,处理器301可以控制运行压力测试流程。
显示屏305包括显示面板。显示面板可以采用液晶显示屏(liquid crystaldisplay,LCD),有机发光二极管(organic light-emittingdiode,OLED),有源矩阵有机发光二极体或主动矩阵有机发光二极体(active-matrixorganic light emitting diode的,AMOLED),柔性发光二极管(flex light-emittingdiode,FLED),Miniled,MicroLed,Micro-oLed,量子点发光二极管(quantum dot lightemitting diodes,QLED)等。在一些实施例中,电子设备300可以包括1个或N个显示屏305,N为大于1的正整数。显示屏305可用于显示由用户输入的信息或提供给用户的信息以及各种图形用户界面(graphical userinterface,GUI)。例如,显示屏305可以显示照片、视频、网页、或者文件等。
本申请实施例提供的电子设备,适用于上述方法任一实施例,因此,其所能达到的有益效果可参考上文所提供的对应的方法中的有益效果,此处不再赘述。
本申请实施例提供了一种计算机可读存储介质,该计算机可读存储介质上存储有计算机程序,该程序被处理器执行时实现上述方法实施例所示的压力测试方法。
本申请实施例提供的计算机可读存储介质,适用于上述方法任一实施例,因此,其所能达到的有益效果可参考上文所提供的对应的方法中的有益效果,此处不再赘述。
本申请实施例还提供了一种计算机程序产品,当该计算机程序产品在计算机上运行时,使得计算机执行上述相关步骤,以实现上述实施例中的方法。本申请实施例提供的计算机程序产品,适用于上述方法任一实施例,因此,其所能达到的有益效果可参考上文所提供的对应的方法中的有益效果,此处不再赘述。
本申请上述实施例公开的压力测试方案通过将压力测试基础镜像文件和压力测试套件集群推送至预设云容器;其中,所述压力测试套件集群包括至少一个压力测试套件;根据被测系统压力测试需求,利用压力测试套件集群编辑生成压力测试模型;其中所述压力测试模型组合有至少两种压力测试套件;利用生成的压力测试模型对被测系统执行压力测试。本申请实施例提供的压力测试方案以基础镜像和测试套件实现了压力测试模型容器化,即多种压力测试模型共用基础镜像,多个项目同时进行不仅屏蔽同一测试系统环境下发压程序之间的相互影响,而且节省了多个压力测试程序的占用空间,多个项目可以共用一个物理环境开展工作,节省测试资源成本。同时本申请实施例所述的压力测试方案利用容器云调度技术,通过编写yaml文件将多个压力测试套件进行自由组合,生成新的叠加型压力测试套件即满足被测系统的压力测试模型提升了制作压力测试模型的效率。此外在本申请实施例中可以将压力测试环境文件保存至本地仓库,可以一键还原便于问题溯源。
在本申请所提供的几个实施例中,应该理解到,所揭露的装置和方法,可以通过其他的方式实现。例如,以上所描述的装置实施例仅是示意性的,例如,模块或单元的划分,仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个装置,或一些特征可以丢弃,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其他的形式。
作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是一个物理单元或多个物理单元,即可以位于一个地方,或者也可以分布到多个不同地方。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本申请各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个可读取存储介质中。基于这样的理解,本申请实施例的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该软件产品存储在一个存储介质中,包括若干指令用以使得一个设备(可以是单片机,芯片等)或处理器(processor)执行本申请各个实施例方法的全部或部分步骤。而前述的存储介质包括:U盘、移动硬盘、只读存储器(read only memory,ROM)、随机存取存储器(random access memory,RAM)、磁碟或者光盘等各种可以存储程序代码的介质。
应该理解的是,虽然附图的流程图中的各个步骤按照箭头的指示依次显示,但是这些步骤并不是必然按照箭头指示的顺序依次执行。除非本文中有明确的说明,这些步骤的执行并没有严格的顺序限制,其可以以其他的顺序执行。而且,附图的流程图中的至少一部分步骤可以包括多个子步骤或者多个阶段,这些子步骤或者阶段并不必然是在同一时刻执行完成,而是可以在不同的时刻执行,其执行顺序也不必然是依次进行,而是可以与其他步骤或者其他步骤的子步骤或者阶段的至少一部分轮流或者交替地执行。
以上内容,仅为本申请的具体实施方式,但本申请的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本申请揭露的技术范围内,可轻易想到变化或替换,还可以做出若干改进和润饰,这些变化、替换、改进和润饰也应视为都应涵盖在本申请的保护范围之内。因此,本申请的保护范围应以权利要求的保护范围为准。

Claims (10)

1.一种压力测试方法,其特征在于,所述方法包括:
将压力测试基础镜像文件和压力测试套件集群推送至预设云容器;其中,所述压力测试套件集群包括至少一个压力测试套件;
根据被测系统压力测试需求,利用压力测试套件集群编辑生成压力测试模型;其中所述压力测试模型组合有至少两种压力测试套件;
利用生成的压力测试模型对被测系统执行压力测试。
2.根据权利要求1所述的压力测试方法,其特征在于,所述将压力测试基础镜像文件推送至预设容器包括:
利用云容器引擎,构建被测系统压力测试操作系统和压力测试框架程序的镜像文件并确定为基础镜像文件;
将所述基础镜像文件推送至预设云容器。
3.根据权利要求2所述的压力测试方法,其特征在于,将压力测试套件集群推送至预设云容器包括:
以基础镜像文件为模板,获取压力测试套件集群;其中每一个压力测试套件根据基础镜像文件模板生成;
将压力测试套件集群中的每一个压力测试套件制作为镜像文件;
将压力测试套件集群的镜像文件推送至预设云容器。
4.根据权利要求3所述的压力测试方法,其特征在于,将压力测试套件集群中的每一个压力测试套件制作为镜像文件之后,所述方法还包括:
为每一个压力测试套件的镜像文件添加唯一标签;其中所述标签用于区别不同的压力测试套件。
5.根据权利要求4所述的压力测试方法,其特征在于,所述利用压力测试套件集群编辑生成压力测试模型包括:
根据被测系统压力测试需求,编写yaml文件组合至少两个压力测试套件生成压力测试模型;
将所述压力测试模型推送至预设云容器并生成容器化的压力测试模型。
6.根据权利要求5所述的压力测试方法,其特征在于,所述方法还包括:
将所述yaml文件和容器化的压力测试套件集群保存至本地;其中所述yaml文件中包括压力测试环境参数。
7.一种压力测试装置,其特征在于,所述装置包括:通讯模块、生成模块和执行模块,其中,
所述通讯模块,用于将压力测试基础镜像文件和压力测试套件集群推送至预设云容器;其中,所述压力测试套件集群包括至少一个压力测试套件;
所述生成模块,用于根据被测系统压力测试需求,利用压力测试套件集群编辑生成压力测试模型;其中所述压力测试模型组合有至少两种压力测试套件;
所述执行模块,用于利用生成的压力测试模型对被测系统执行压力测试。
8.根据权利要求7所述的压力测试装置,其特征在于,
所述生成模块具体用于利用云容器引擎,构建被测系统压力测试操作系统和压力测试框架程序的镜像文件并确定为基础镜像文件;
所述通讯模块将所述基础镜像文件推送至预设云容器。
9.一种电子设备,其特征在于,包括处理器和存储器;
所述存储器,用于存储操作指令;
所述处理器,用于通过调用所述操作指令,执行权利要求1-7中任一项所述的方法。
10.一种计算机可读存储介质,其特征在于,所述存储介质上存储有计算机程序,所述计算机程序被处理器执行时实现权利要求1-7中任一项所述的方法。
CN202011294192.3A 2020-11-18 2020-11-18 一种压力测试方法、装置、电子设备和可读存储介质 Pending CN112486807A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202011294192.3A CN112486807A (zh) 2020-11-18 2020-11-18 一种压力测试方法、装置、电子设备和可读存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202011294192.3A CN112486807A (zh) 2020-11-18 2020-11-18 一种压力测试方法、装置、电子设备和可读存储介质

Publications (1)

Publication Number Publication Date
CN112486807A true CN112486807A (zh) 2021-03-12

Family

ID=74931715

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202011294192.3A Pending CN112486807A (zh) 2020-11-18 2020-11-18 一种压力测试方法、装置、电子设备和可读存储介质

Country Status (1)

Country Link
CN (1) CN112486807A (zh)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114116487A (zh) * 2021-11-29 2022-03-01 北京百度网讯科技有限公司 压力测试方法、装置、电子设备及存储介质
CN116665751A (zh) * 2022-12-16 2023-08-29 荣耀终端有限公司 测试方法及电子设备

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109783348A (zh) * 2018-12-06 2019-05-21 中国电力科学研究院有限公司 基于云平台的测试工具资源管理方法、系统
CN109828901A (zh) * 2018-12-15 2019-05-31 深圳壹账通智能科技有限公司 搭建压测环境的方法及装置、Linux服务器、及可读存储介质
CN110162471A (zh) * 2019-04-28 2019-08-23 中国工商银行股份有限公司 一种基于容器云的压力测试方法及系统
CN111124850A (zh) * 2019-11-12 2020-05-08 上海移远通信科技有限公司 Mqtt服务器性能测试方法、系统、计算机设备及存储介质

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109783348A (zh) * 2018-12-06 2019-05-21 中国电力科学研究院有限公司 基于云平台的测试工具资源管理方法、系统
CN109828901A (zh) * 2018-12-15 2019-05-31 深圳壹账通智能科技有限公司 搭建压测环境的方法及装置、Linux服务器、及可读存储介质
CN110162471A (zh) * 2019-04-28 2019-08-23 中国工商银行股份有限公司 一种基于容器云的压力测试方法及系统
CN111124850A (zh) * 2019-11-12 2020-05-08 上海移远通信科技有限公司 Mqtt服务器性能测试方法、系统、计算机设备及存储介质

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114116487A (zh) * 2021-11-29 2022-03-01 北京百度网讯科技有限公司 压力测试方法、装置、电子设备及存储介质
CN114116487B (zh) * 2021-11-29 2024-03-15 北京百度网讯科技有限公司 压力测试方法、装置、电子设备及存储介质
CN116665751A (zh) * 2022-12-16 2023-08-29 荣耀终端有限公司 测试方法及电子设备
CN116665751B (zh) * 2022-12-16 2024-04-02 荣耀终端有限公司 测试方法及电子设备

Similar Documents

Publication Publication Date Title
US10579344B2 (en) Converting visual diagrams into code
US10026041B2 (en) Interoperable machine learning platform
WO2020006910A1 (zh) 业务组件式开发方法、装置、计算机设备及存储介质
US11327726B2 (en) Workflow engine tool
CN102930580A (zh) 数据帧动画
CN112241932A (zh) 一种图片处理方法及装置
CN112486807A (zh) 一种压力测试方法、装置、电子设备和可读存储介质
CN116662038B (zh) 基于共享内存的工业信息检测方法、装置、设备及介质
CN114186527A (zh) 一种不依赖于网格点实现集成电路自动布线的方法及装置
CN116662039B (zh) 基于共享内存的工业信息并行检测方法、装置及介质
CN105573763A (zh) 一种支持rtos的嵌入式系统建模方法
CN110908644B (zh) 状态节点的配置方法、装置、计算机设备和存储介质
CN114564241B (zh) 硬件设备的访问方法、装置、计算机设备和存储介质
CN113835835B (zh) 一种创建一致性组的方法、装置、及计算机可读存储介质
CN111796812A (zh) 图像渲染的方法、装置、电子设备及计算机可读存储介质
CN114185522A (zh) 页面主题定制方法、装置、电子设备及存储介质
CN114398282A (zh) 测试脚本的生成方法、装置、设备及存储介质
CN114217927A (zh) 一种线程调用方法、装置、计算机设备及存储介质
CN114489861A (zh) 目标组件转化方法、装置、电子设备及可读存储介质
CN113010129A (zh) 虚拟演播厅全流程多终端板书提取方法和装置
CN114706715B (zh) 一种基于bmc的分布式raid的控制方法、装置、设备及介质
US20220261227A1 (en) Code Generation Tool for Cloud-Native High-Performance Computing
CN117235174A (zh) 一种多源数据同步系统、数据接入平台及数据接入方法
CN114995940A (zh) 弹框配置及展示方法、装置、设备及存储介质
CN115729655A (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