CN115242684B - 全链路压测方法、装置、计算机设备及存储介质 - Google Patents
全链路压测方法、装置、计算机设备及存储介质 Download PDFInfo
- Publication number
- CN115242684B CN115242684B CN202210865402.2A CN202210865402A CN115242684B CN 115242684 B CN115242684 B CN 115242684B CN 202210865402 A CN202210865402 A CN 202210865402A CN 115242684 B CN115242684 B CN 115242684B
- Authority
- CN
- China
- Prior art keywords
- pressure measurement
- node
- flow
- service
- real
- 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.)
- Active
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L43/00—Arrangements for monitoring or testing data switching networks
- H04L43/08—Monitoring or testing based on specific metrics, e.g. QoS, energy consumption or environmental parameters
- H04L43/0876—Network utilisation, e.g. volume of load or congestion level
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L43/00—Arrangements for monitoring or testing data switching networks
- H04L43/08—Monitoring or testing based on specific metrics, e.g. QoS, energy consumption or environmental parameters
- H04L43/0876—Network utilisation, e.g. volume of load or congestion level
- H04L43/0882—Utilisation of link capacity
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L43/00—Arrangements for monitoring or testing data switching networks
- H04L43/50—Testing arrangements
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Environmental & Geological Engineering (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
Abstract
本申请实施例属于研发测试领域,应用于***压力测试领域中,涉及一种全链路压测方法、装置、计算机设备及存储介质,其中方法包括接收并解析压测请求;通过压测流量和业务模拟***,模拟真实流量在待进行压测的业务***中流量传递过程;识别在全业务链路下真实流量依次流经的节点及每个节点时对应压测数据;构建节点拓扑图;基于压测数据和节点拓扑图进行***压测指标性能分析,通过获取压测流量在流转前后对应节点的节点区别标识,并通过节点区别标识设置压测流量在流转后上一节点处的压测标识,保证了压测标识在每个节点都具备唯一性,实现压测流量在整条链路上各个节点之间都能被传递、识别和处理。
Description
技术领域
本申请涉及研发测试和***压力测试技术领域,尤其涉及一种全链路压测方法、装置、计算机设备及存储介质。
背景技术
全链路压测是指基于实际的业务场景、***环境,通过模拟海量的用户请求和数据,对整个业务链进行压力测试的过程。
针对HTTP和RPC协议的服务,在请求头中加个特殊的压测标识。这种方法,定义的压测标识内容单一,且也很难在***底层基础资源节点之间传递,导致无法通过流量标记进行***业务节点和资源节点的全链路调用追踪。
发明内容
本申请实施例的目的在于提出一种全链路压测方法、装置、计算机设备及存储介质,以便于通过自定义压测标识实现压测流量在整条链路上各个节点之间都能被传递、识别和处理。
为了解决上述技术问题,本申请实施例提供一种全链路压测方法,采用了如下所述的技术方案:
一种全链路压测方法,包括下述步骤:
接收并解析压测请求;
通过解析结果确定压测流量,将所述压测流量传入到业务模拟***中,模拟真实流量在待进行压测的业务***中流量传递过程;
基于所述压测流量在所述模拟业务***中模拟的所述流量传递过程,识别在全业务链路下所述真实流量依次流经的节点;
获取识别出的所述真实流量依次流经每个节点时对应压测数据;
基于识别出的所述真实流量依次流经的每个节点,获取所述待进行压测的业务***中节点间上下游关系,基于所述节点间上下游关系构建节点拓扑图;
基于所述压测数据和所述节点拓扑图对所述待进行压测的业务***进行***压测指标性能分析。
进一步的,在所述接收并解析压测请求的步骤之前,所述方法还包括:
基于预设镜像生成工具,生成配置与待进行压测的业务***完全一致的业务模拟***;
在所述业务模拟***与所述待进行压测的业务***间设置监测***,实时监测所述待进行压测的业务***中各节点对应的真实流量;
所述接收并解析压测请求的步骤,具体包括:
在接收到所述压测请求时,基于所述监测***,实时获取所述待进行压测的业务***中各节点对应的真实流量;
将所述待进行压测的业务***中各节点对应的真实流量作为所述压测请求对应解析结果。
进一步的,在所述实时获取所述待进行压测的业务***中各节点对应的真实流量的步骤之前,所述方法还包括:
获取所述模拟业务***中业务节点和支撑所述模拟业务***的资源节点;
对所述业务节点和所述资源节点设置节点区别标识;
在所述实时获取所述待进行压测的业务***中各节点对应的真实流量的步骤之后,所述方法还包括:
基于所述待进行压测的业务***中各节点对应的真实流量,进行统计,将统计结果作为所述模拟业务***的压测流量;
获取所述模拟业务***中与所述待进行压测的业务***中各节点相对应的各模拟业务***节点;
基于所述各模拟业务***节点对应的节点区别标识和所述待进行压测的业务***中各节点对应的真实流量,对所述压测流量进行定制化切分。
进一步的,将所述压测流量传入到业务模拟***中的步骤,具体包括:
获取定制化切分之后所述模拟业务***中各节点对应的节点区别标识,将所述节点区别标识作为其对应压测流量的初始压测标识;
基于所述定制化切分结果和所述压测流量的初始压测标识,将所述压测流量分别分配到所述模拟业务***中各节点处;
所述模拟真实流量在待进行压测的业务***中流量传递过程的步骤,具体包括:
基于所述监测***,实时获取所述待进行压测的业务***中各节点对应的真实流量的传递过程;
基于所述待进行压测的业务***中各节点对应的真实流量的传递过程确定其在业务模拟***对应压测流量的传递过程。
进一步的,所述基于所述待进行压测的业务***中各节点对应的真实流量的传递过程确定其在业务模拟***对应压测流量的传递过程的步骤之后,所述方法还包括:
基于预设中间件对当前节点处压测流量对应的压测标识进行识别,识别出所述压测流量中新传递过来的压测流量;
基于识别结果,判断当前压测流量是否为当前节点下游业务新传递过来的压测流量;
若是,则对当前压测流量进行压测标识更新;
若否,则保持当前压测流量的压测标识。
进一步的,所述对当前压测流量进行压测标识更新的步骤,具体包括:
基于所述中间件,识别所述压测流量在本次流转前所处的上一节点和当前节点;
获取所述上一节点对应的节点区别标识作为第一节点标识;
获取所述当前节点对应的节点区别标识作为第二节点标识;
基于所述中间件,识别本次流转后所述压测流量所处的节点,获取所述节点对应的节点区别标识作为第三节点标识;
对所述第一节点标识、第二节点标识、第三节点标识按流转顺序进行拼接,将拼接结果设置为所述压测流量在本次流转后的上一节点处对应的压测标识。
进一步的,所述基于所述压测流量在所述模拟业务***中模拟的所述流量传递过程,识别在全业务链路下所述真实流量依次流经的节点的步骤,具体包括:
对识别出的压测标识进行拆分处理,获取构成所述压测标识的第一节点标识、第二节点标识、第三节点标识;
基于所述第一节点标识、第二节点标识、第三节点标识,识别出所述压测流量在所述模拟业务***中各节点间的传递过程;
基于所述压测流量在所述模拟业务***中各节点间的传递过程,确定在待进行压测的业务***的全业务链路下所述真实流量依次流经的节点。
为了解决上述技术问题,本申请实施例还提供一种全链路压测装置,采用了如下所述的技术方案:
一种全链路压测装置,包括:
请求处理模块,用于接收并解析压测请求;
流量传递模拟模块,用于通过解析结果确定压测流量,将所述压测流量传入到业务模拟***中,模拟真实流量在待进行压测的业务***中流量传递过程;
流经节点识别模块,用于基于所述压测流量在所述模拟业务***中模拟的所述流量传递过程,识别在全业务链路下所述真实流量依次流经的节点;
压测数据获取模块,用于获取识别出的所述真实流量依次流经每个节点时对应压测数据;
节点拓扑图构建模块,用于基于识别出的所述真实流量依次流经的每个节点,获取所述待进行压测的业务***中节点间上下游关系,基于所述节点间上下游关系构建节点拓扑图;
压测分析模块,用于基于所述压测数据和所述节点拓扑图对所述待进行压测的业务***进行***压测指标性能分析。
为了解决上述技术问题,本申请实施例还提供一种计算机设备,采用了如下所述的技术方案:
一种计算机设备,包括存储器和处理器,所述存储器中存储有计算机可读指令,所述处理器执行所述计算机可读指令时实现上述所述的全链路压测方法的步骤。
为了解决上述技术问题,本申请实施例还提供一种计算机可读存储介质,采用了如下所述的技术方案:
一种计算机可读存储介质,所述计算机可读存储介质上存储有计算机可读指令,所述计算机可读指令被处理器执行时实现如上述所述的全链路压测方法的步骤。
与现有技术相比,本申请实施例主要有以下有益效果:
本申请实施例所述全链路压测方法,通过接收并解析压测请求;通过压测流量和业务模拟***,模拟真实流量在待进行压测的业务***中流量传递过程;识别在全业务链路下真实流量依次流经的节点及每个节点时对应压测数据;构建节点拓扑图;基于压测数据和节点拓扑图进行***压测指标性能分析,通过获取压测流量在流转前后对应节点的节点区别标识,并通过节点区别标识设置压测流量在流转后上一节点处的压测标识,保证了压测标识在每个节点都具备唯一性,实现压测流量在整条链路上各个节点之间都能被传递、识别和处理。
附图说明
为了更清楚地说明本申请中的方案,下面将对本申请实施例描述中所需要使用的附图作一个简单介绍,显而易见地,下面描述中的附图是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本申请可以应用于其中的示例性***架构图;
图2根据本申请的全链路压测方法的一个实施例的流程图;
图3是图2所示步骤202的一种具体实施方式的流程图;
图4是本申请对当前压测流量进行压测标识更新的一种具体实施方式的流程图;
图5是图2所示步骤203的一种具体实施方式的流程图;
图6是根据本申请的全链路压测装置的一个实施例的结构示意图;
图7是本申请所示607的一种具体实施方式的结构示意图;
图8是图6所示602的一种具体实施方式的结构示意图;
图9是根据本申请的计算机设备的一个实施例的结构示意图。
具体实施方式
除非另有定义,本文所使用的所有的技术和科学术语与属于本申请的技术领域的技术人员通常理解的含义相同;本文中在申请的说明书中所使用的术语只是为了描述具体的实施例的目的,不是旨在于限制本申请;本申请的说明书和权利要求书及上述附图说明中的术语“包括”和“具有”以及它们的任何变形,意图在于覆盖不排他的包含。本申请的说明书和权利要求书或上述附图中的术语“第一”、“第二”等是用于区别不同对象,而不是用于描述特定顺序。
在本文中提及“实施例”意味着,结合实施例描述的特定特征、结构或特性可以包含在本申请的至少一个实施例中。在说明书中的各个位置出现该短语并不一定均是指相同的实施例,也不是与其它实施例互斥的独立的或备选的实施例。本领域技术人员显式地和隐式地理解的是,本文所描述的实施例可以与其它实施例相结合。
为了使本技术领域的人员更好地理解本申请方案,下面将结合附图,对本申请实施例中的技术方案进行清楚、完整地描述。
如图1所示,***架构100可以包括终端设备101、102、103,网络104和服务器105。网络104用以在终端设备101、102、103和服务器105之间提供通信链路的介质。网络104可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
用户可以使用终端设备101、102、103通过网络104与服务器105交互,以接收或发送消息等。终端设备101、102、103上可以安装有各种通讯客户端应用,例如网页浏览器应用、购物类应用、搜索类应用、即时通信工具、邮箱客户端、社交平台软件等。
终端设备101、102、103可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、电子书阅读器、MP3播放器(Moving PictureExpertsGroup Audio Layer III,动态影像专家压缩标准音频层面3)、MP4(MovingPictureExperts Group Audio Layer IV,动态影像专家压缩标准音频层面4)播放器、膝上型便携计算机和台式计算机等等。
服务器105可以是提供各种服务的服务器,例如对终端设备101、102、103上显示的页面提供支持的后台服务器。
需要说明的是,本申请实施例所提供的全链路压测方法一般由服务器/终端设备执行,相应地,全链路压测装置一般设置于服务器/终端设备中。
应该理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
继续参考图2,示出了根据本申请的全链路压测方法的一个实施例的流程图。所述的全链路压测方法,包括以下步骤:
步骤201,接收并解析压测请求。
本实施例中,流量指的是业务***中各节点处对应的访问人数数量。
本实施例中,在所述接收并解析压测请求的步骤之前,所述方法还包括:基于预设镜像生成工具,生成配置与待进行压测的业务***完全一致的业务模拟***;在所述业务模拟***与所述待进行压测的业务***间设置监测***,实时监测所述待进行压测的业务***中各节点对应的真实流量。
本实施例中,所述接收并解析压测请求的步骤,具体包括:在接收到所述压测请求时,基于所述监测***,实时获取所述待进行压测的业务***中各节点对应的真实流量;将所述待进行压测的业务***中各节点对应的真实流量作为所述压测请求对应解析结果。
通过镜像生成工具,对待进行压测***进行模拟业务***生成,获取待进行压测***中各节点对应的真实流量,为所述模拟业务***进行压测流量分配提供参照依据,同时以模拟***进行压测,不会对原有业务***造成任何程序性影响,也避免了在原有业务***中直接压测,易产生脏数据。
本实施例中,在所述实时获取所述待进行压测的业务***中各节点对应的真实流量的步骤之前,所述方法还包括:获取所述模拟业务***中业务节点和支撑所述模拟业务***的资源节点;对所述业务节点和所述资源节点设置节点区别标识。
通过对所述模拟业务***中的资源节点进行分类和设置节点区别标识,便于后期压测人员进行识别和分析。
本实施例中,在所述实时获取所述待进行压测的业务***中各节点对应的真实流量的步骤之后,所述方法还包括:基于所述待进行压测的业务***中各节点对应的真实流量,进行统计,将统计结果作为所述模拟业务***的压测流量;获取所述模拟业务***中与所述待进行压测的业务***中各节点相对应的各模拟业务***节点;基于所述各模拟业务***节点对应的节点区别标识和所述待进行压测的业务***中各节点对应的真实流量,对所述压测流量进行定制化切分。
通过对模拟业务***中业务节点和支撑所述模拟业务***的资源节点设置节点区别标识,通过真实流量确定压测流量,并进行定制化切分,使得模拟业务***中的压测流量与所述待进行压测***中的真实流量一致,保证压测的准确性。
步骤202,通过解析结果确定压测流量,将所述压测流量传入到业务模拟***中,模拟真实流量在待进行压测的业务***中流量传递过程。
本实施例中,将所述压测流量传入到业务模拟***中的步骤,具体包括:获取定制化切分之后所述模拟业务***中各节点对应的节点区别标识,将所述节点区别标识作为其对应压测流量的初始压测标识;基于所述定制化切分结果和所述压测流量的初始压测标识,将所述压测流量分别分配到所述模拟业务***中各节点处。
通过对所述压测流量进行定制化切分,能够将压测流量按照所述待进行压测的业务***中各节点处真实流量的比例和流量设置到模拟业务***内,保证了压测的可参考性和准确性。
本实施例中,所述模拟真实流量在待进行压测的业务***中流量传递过程的步骤,具体包括:基于所述监测***,实时获取所述待进行压测的业务***中各节点对应的真实流量的传递过程;基于所述待进行压测的业务***中各节点对应的真实流量的传递过程确定其在业务模拟***对应压测流量的传递过程。
通过监测***监测真实流量的传递过程,从而确定压测流量的传递过程,保证模拟业务***与待进行压测***中流量传递的一致性,使得压测结果更加准确。
继续参考图3,图3是图2所示步骤202的一种具体实施方式的流程图,包括步骤:
步骤301,获取定制化切分之后所述模拟业务***中各节点对应的节点区别标识,将所述节点区别标识作为其对应压测流量的初始压测标识;
步骤302,基于所述定制化切分结果和所述压测流量的初始压测标识,将所述压测流量分别分配到所述模拟业务***中各节点处;
步骤303,基于所述监测***,实时获取所述待进行压测的业务***中各节点对应的真实流量的传递过程;
步骤304,基于所述待进行压测的业务***中各节点对应的真实流量的传递过程确定其在业务模拟***对应压测流量的传递过程。
本实施例中,所述基于所述待进行压测的业务***中各节点对应的真实流量的传递过程确定其在业务模拟***对应压测流量的传递过程的步骤之后,所述方法还包括:基于预设中间件对当前节点处压测流量对应的压测标识进行识别,识别出所述压测流量中新传递过来的压测流量;基于识别结果,判断当前压测流量是否为当前节点下游业务新传递过来的压测流量;若是,则对当前压测流量进行压测标识更新;若否,则保持当前压测流量的压测标识。
通过预设中间件对压测标识进行识别,并在压测流量在链路中传递时,更新压测标识,为后续获取节点拓扑图和进行压测分析提供支持。
本实施例中,所述对当前压测流量进行压测标识更新的步骤,具体包括:基于所述中间件,识别所述压测流量在本次流转前所处的上一节点和当前节点;获取所述上一节点对应的节点区别标识作为第一节点标识;获取所述当前节点对应的节点区别标识作为第二节点标识;基于所述中间件,识别本次流转后所述压测流量所处的节点,获取所述节点对应的节点区别标识作为第三节点标识;对所述第一节点标识、第二节点标识、第三节点标识按流转顺序进行拼接,将拼接结果设置为所述压测流量在本次流转后的上一节点处对应的压测标识。
通过获取压测流量在流转前后对应节点的节点区别标识,并通过所述节点区别标识设置压测流量在流转后上一节点处的压测标识,保证了压测标识在每个节点都具备唯一性,便于进行节点拓扑图的构建和压测分析。
继续参考图4,图4示出了对当前压测流量进行压测标识更新的一种具体实施方式的流程图,包括步骤:
步骤401,基于所述中间件,识别所述压测流量在本次流转前所处的上一节点和当前节点;
步骤402,获取所述上一节点对应的节点区别标识作为第一节点标识;
步骤403,获取所述当前节点对应的节点区别标识作为第二节点标识;
步骤404,基于所述中间件,识别本次流转后所述压测流量所处的节点,获取所述节点对应的节点区别标识作为第三节点标识;
步骤405,对所述第一节点标识、第二节点标识、第三节点标识按流转顺序进行拼接,将拼接结果设置为所述压测流量在本次流转后的上一节点处对应的压测标识。
步骤203,基于所述压测流量在所述模拟业务***中模拟的所述流量传递过程,识别在全业务链路下所述真实流量依次流经的节点。
本实施例中,所述基于所述压测流量在所述模拟业务***中模拟的所述流量传递过程,识别在全业务链路下所述真实流量依次流经的节点的步骤,具体包括:对识别出的压测标识进行拆分处理,获取构成所述压测标识的第一节点标识、第二节点标识、第三节点标识;基于所述第一节点标识、第二节点标识、第三节点标识,识别出所述压测流量在所述模拟业务***中各节点间的传递过程;基于所述压测流量在所述模拟业务***中各节点间的传递过程,确定在待进行压测的业务***的全业务链路下所述真实流量依次流经的节点。
通过对识别出的压测标识进行解析,获取构成所述压测标识的第一节点标识、第二节点标识、第三节点标识,从而确定所述模拟业务***中压测流量在节点间的传递过程,反推出待进行压测的业务***的全业务链路下所述真实流量依次流经的节点,通过模拟业务***对所述待进行压测的业务***进行压测,保证了压测***与真实业务***的分离,避免直接对真实业务***进行压测,造成测试压力过大。
继续参考图5,图5是图2所示步骤203的一种具体实施方式的流程图,包括步骤:
步骤501,对识别出的压测标识进行拆分处理,获取构成所述压测标识的第一节点标识、第二节点标识、第三节点标识;
步骤502,基于所述第一节点标识、第二节点标识、第三节点标识,识别出所述压测流量在所述模拟业务***中各节点间的传递过程;
步骤503,基于所述压测流量在所述模拟业务***中各节点间的传递过程,确定在待进行压测的业务***的全业务链路下所述真实流量依次流经的节点。
本实施例中,通过所述业务模拟***中压测流量,在本次流转后,获取所述压测流量在当前节点处时所述节点的压测数据替换所述压测流量在上一节点处所述节点的压测数据,进行当前节点对应的压测数据更新。
在压测流量每流经一个节点,获取该节点对应的压测数据,进行压测数据更新,能够依照节点进行压测数据获取和缓存,便于后期按照节点进行压测分析。
步骤205,基于识别出的所述真实流量依次流经的每个节点,获取所述待进行压测的业务***中节点间上下游关系,基于所述节点间上下游关系构建节点拓扑图。
本实施例中,循环获取压测流量每次流转后在对应节点处的压测标识,进行拆分处理,获取到每个压测标识对应的第一节点标识、第二节点标识、第三节点标识,基于所述第一节点标识、第二节点标识、第三节点标识确定模拟业务***中节点间上下游关系,并构建节点拓扑图,所述模拟业务***对应的节点拓扑图,即所述待进行压测的业务***的节点拓扑图。
通过对对应节点处的压测标识进行拆分,获取到第一节点标识、第二节点标识、第三节点标识,从而确定模拟业务***中节点间上下游关系,便于直观的进行节点拓扑图构建。
需要注意的是,对定制化切分后的压测流量设置初始压测标识,此时,初始压测标识只有当前节点对应的第二节点标识,当定制化切分后的压测流量经过一次流转之后,其在上一节点对应的压测标识更新为由第一节点标识和第二节点标识所构成的压测标识,当定制化切分后的压测流量经过二次及二次以上流转之后,其在上一节点对应的压测标识更新为由第一节点标识、第二节点标识、第三节点标识所构成的压测标识。
步骤206,基于所述压测数据和所述节点拓扑图对所述待进行压测的业务***进行***压测指标性能分析。
本申请通过接收并解析压测请求;通过压测流量和业务模拟***,模拟真实流量在待进行压测的业务***中流量传递过程;识别在全业务链路下真实流量依次流经的节点及每个节点时对应压测数据;构建节点拓扑图;基于压测数据和节点拓扑图进行***压测指标性能分析,通过获取压测流量在流转前后对应节点的节点区别标识,并通过节点区别标识设置压测流量在流转后上一节点处的压测标识,保证了压测标识在每个节点都具备唯一性,实现压测流量在整条链路上各个节点之间都能被传递、识别和处理。
本申请实施例可以基于人工智能技术对相关的数据进行获取和处理。其中,人工智能(Artificial Intelligence,AI)是利用数字计算机或者数字计算机控制的机器模拟、延伸和扩展人的智能,感知环境、获取知识并使用知识获得最佳结果的理论、方法、技术及应用***。
人工智能基础技术一般包括如传感器、专用人工智能芯片、云计算、分布式存储、大数据处理技术、操作/交互***、机电一体化等技术。人工智能软件技术主要包括计算机视觉技术、机器人技术、生物识别技术、语音处理技术、自然语言处理技术以及机器学习/深度学习等几大方向。
例如,本申请实施例中,可以使用人工智能技术进行压测流量模拟生成和传入,同时,也可以使用人工智能技术对压测流量对应的压测标识进行更新。
进一步参考图6,作为对上述图2所示方法的实现,本申请提供了一种全链路压测装置的一个实施例,该装置实施例与图2所示的方法实施例相对应,该装置具体可以应用于各种电子设备中。
如图6所示,本实施例所述的全链路压测装置600包括:请求处理模块601、流量传递模拟模块602、流经节点识别模块603、压测数据获取模块604、节点拓扑图构建模块605和压测分析模块606。其中:
请求处理模块601,用于接收并解析压测请求;
流量传递模拟模块602,用于通过解析结果确定压测流量,将所述压测流量传入到业务模拟***中,模拟真实流量在待进行压测的业务***中流量传递过程;
流经节点识别模块603,用于基于所述压测流量在所述模拟业务***中模拟的所述流量传递过程,识别在全业务链路下所述真实流量依次流经的节点;
压测数据获取模块604,用于获取识别出的所述真实流量依次流经每个节点时对应压测数据;
节点拓扑图构建模块605,用于基于识别出的所述真实流量依次流经的每个节点,获取所述待进行压测的业务***中节点间上下游关系,基于所述节点间上下游关系构建节点拓扑图;
压测分析模块606,用于基于所述压测数据和所述节点拓扑图对所述待进行压测的业务***进行***压测指标性能分析。
本申请通过接收并解析压测请求;通过压测流量和业务模拟***,模拟真实流量在待进行压测的业务***中流量传递过程;识别在全业务链路下真实流量依次流经的节点及每个节点时对应压测数据;构建节点拓扑图;基于压测数据和节点拓扑图进行***压测指标性能分析,通过获取压测流量在流转前后对应节点的节点区别标识,并通过节点区别标识设置压测流量在流转后上一节点处的压测标识,保证了压测标识在每个节点都具备唯一性,实现压测流量在整条链路上各个节点之间都能被传递、识别和处理。
继续参考图7,本实施例所述的全链路压测装置600还包括压测前配置模块607,所示压测前配置模块607包括第一配置子模块6091和第二配置子模块6092,其中,
第一配置子模块6091,用于基于预设镜像生成工具,生成配置与待进行压测的业务***完全一致的业务模拟***;在所述业务模拟***与所述待进行压测的业务***间设置监测***,实时监测所述待进行压测的业务***中各节点对应的真实流量。
第二配置子模块6092,用于获取所述模拟业务***中业务节点和支撑所述模拟业务***的资源节点;对所述业务节点和所述资源节点设置节点区别标识。
通过压测前配置模块,生成模拟业务***,获取待进行压测***中各节点对应的真实流量,为所述模拟业务***进行压测流量分配提供参照依据,同时以模拟***进行压测,不会对原有业务***造成任何程序性影响,也避免了在原有业务***中直接压测,易产生脏数据,通过对所述模拟业务***中的资源节点进行分类和设置节点区别标识,便于后期压测人员进行识别和分析。
本实施例所述的全链路压测装置600还包括压测流量分配模块,所示压测流量分配模块用于基于所述待进行压测的业务***中各节点对应的真实流量,进行统计,将统计结果作为所述模拟业务***的压测流量;获取所述模拟业务***中与所述待进行压测的业务***中各节点相对应的各模拟业务***节点;基于所述各模拟业务***节点对应的节点区别标识和所述待进行压测的业务***中各节点对应的真实流量,对所述压测流量进行定制化切分。
通过压测流量分配模块对模拟业务***中业务节点和支撑所述模拟业务***的资源节点设置节点区别标识,通过真实流量确定压测流量,并进行定制化切分,使得模拟业务***中的压测流量与所述待进行压测***中的真实流量一致,保证压测的准确性。
继续参考图8,图8是图6所示602的一种具体实施方式的结构示意图,所示流量传递模拟模块602包括流量传入子模块6021、压测标识识别子模块6022、压测标识更新子模块6023,其中,
流量传入子模块6021,用于获取定制化切分之后所述模拟业务***中各节点对应的节点区别标识,将所述节点区别标识作为其对应压测流量的初始压测标识;基于所述定制化切分结果和所述压测流量的初始压测标识,将所述压测流量分别分配到所述模拟业务***中各节点处。
压测标识识别子模块6022,用于基于预设中间件对当前节点处压测流量对应的压测标识进行识别,识别出所述压测流量中新传递过来的压测流量;基于识别结果,判断当前压测流量是否为当前节点下游业务新传递过来的压测流量;若是,则对当前压测流量进行压测标识更新;若否,则保持当前压测流量的压测标识。
压测标识更新子模块6023,用于基于所述中间件,识别所述压测流量在本次流转前所处的上一节点和当前节点;获取所述上一节点对应的节点区别标识作为第一节点标识;获取所述当前节点对应的节点区别标识作为第二节点标识;基于所述中间件,识别本次流转后所述压测流量所处的节点,获取所述节点对应的节点区别标识作为第三节点标识;对所述第一节点标识、第二节点标识、第三节点标识按流转顺序进行拼接,将拼接结果设置为所述压测流量在本次流转后的上一节点处对应的压测标识。
通过压测标识识别子模块识别出当前节点中新传递过来的压测流量,通过压测标识更新子模块对新传递过来的压测流量实现压测标识更新。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机可读指令来指令相关的硬件来完成,该计算机可读指令可存储于计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。其中,前述的存储介质可为磁碟、光盘、只读存储记忆体(Read-Only Memory,ROM)等非易失性存储介质,或随机存储记忆体(Random Access Memory,RAM)等。
应该理解的是,虽然附图的流程图中的各个步骤按照箭头的指示依次显示,但是这些步骤并不是必然按照箭头指示的顺序依次执行。除非本文中有明确的说明,这些步骤的执行并没有严格的顺序限制,其可以以其他的顺序执行。而且,附图的流程图中的至少一部分步骤可以包括多个子步骤或者多个阶段,这些子步骤或者阶段并不必然是在同一时刻执行完成,而是可以在不同的时刻执行,其执行顺序也不必然是依次进行,而是可以与其他步骤或者其他步骤的子步骤或者阶段的至少一部分轮流或者交替地执行。
为解决上述技术问题,本申请实施例还提供计算机设备。具体请参阅图9,图9为本实施例计算机设备基本结构框图。
所述计算机设备9包括通过***总线相互通信连接存储器91、处理器92、网络接口93。需要指出的是,图中仅示出了具有组件91-93的计算机设备9,但是应理解的是,并不要求实施所有示出的组件,可以替代的实施更多或者更少的组件。其中,本技术领域技术人员可以理解,这里的计算机设备是一种能够按照事先设定或存储的指令,自动进行数值计算和/或信息处理的设备,其硬件包括但不限于微处理器、专用集成电路(ApplicationSpecific Integrated Circuit,ASIC)、可编程门阵列(Field-Programmable GateArray,FPGA)、数字处理器(Digital Signal Processor,DSP)、嵌入式设备等。
所述计算机设备可以是桌上型计算机、笔记本、掌上电脑及云端服务器等计算设备。所述计算机设备可以与用户通过键盘、鼠标、遥控器、触摸板或声控设备等方式进行人机交互。
所述存储器91至少包括一种类型的可读存储介质,所述可读存储介质包括闪存、硬盘、多媒体卡、卡型存储器(例如,SD或DX存储器等)、随机访问存储器(RAM)、静态随机访问存储器(SRAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、可编程只读存储器(PROM)、磁性存储器、磁盘、光盘等。在一些实施例中,所述存储器91可以是所述计算机设备9的内部存储单元,例如该计算机设备9的硬盘或内存。在另一些实施例中,所述存储器91也可以是所述计算机设备9的外部存储设备,例如该计算机设备9上配备的插接式硬盘,智能存储卡(Smart Media Card,SMC),安全数字(Secure Digital,SD)卡,闪存卡(FlashCard)等。当然,所述存储器91还可以既包括所述计算机设备9的内部存储单元也包括其外部存储设备。本实施例中,所述存储器91通常用于存储安装于所述计算机设备9的操作***和各类应用软件,例如全链路压测方法的计算机可读指令等。此外,所述存储器91还可以用于暂时地存储已经输出或者将要输出的各类数据。
所述处理器92在一些实施例中可以是中央处理器(Central Processing Unit,CPU)、控制器、微控制器、微处理器、或其他数据处理芯片。该处理器92通常用于控制所述计算机设备9的总体操作。本实施例中,所述处理器92用于运行所述存储器91中存储的计算机可读指令或者处理数据,例如运行所述全链路压测方法的计算机可读指令。
所述网络接口93可包括无线网络接口或有线网络接口,该网络接口93通常用于在所述计算机设备9与其他电子设备之间建立通信连接。
本实施例提出的计算机设备,属于研发测试技术领域。本申请通过接收并解析压测请求;通过压测流量和业务模拟***,模拟真实流量在待进行压测的业务***中流量传递过程;识别在全业务链路下真实流量依次流经的节点及每个节点时对应压测数据;构建节点拓扑图;基于压测数据和节点拓扑图进行***压测指标性能分析,通过获取压测流量在流转前后对应节点的节点区别标识,并通过节点区别标识设置压测流量在流转后上一节点处的压测标识,保证了压测标识在每个节点都具备唯一性,实现压测流量在整条链路上各个节点之间都能被传递、识别和处理。
本申请还提供了另一种实施方式,即提供一种计算机可读存储介质,所述计算机可读存储介质存储有计算机可读指令,所述计算机可读指令可被处理器执行,以使所述处理器执行如上述的全链路压测方法的步骤。
本实施例提出的计算机可读存储介质,属于研发测试技术领域。本申请通过接收并解析压测请求;通过压测流量和业务模拟***,模拟真实流量在待进行压测的业务***中流量传递过程;识别在全业务链路下真实流量依次流经的节点及每个节点时对应压测数据;构建节点拓扑图;基于压测数据和节点拓扑图进行***压测指标性能分析,通过获取压测流量在流转前后对应节点的节点区别标识,并通过节点区别标识设置压测流量在流转后上一节点处的压测标识,保证了压测标识在每个节点都具备唯一性,实现压测流量在整条链路上各个节点之间都能被传递、识别和处理。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本申请的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本申请各个实施例所述的方法。
显然,以上所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例,附图中给出了本申请的较佳实施例,但并不限制本申请的专利范围。本申请可以以许多不同的形式来实现,相反地,提供这些实施例的目的是使对本申请的公开内容的理解更加透彻全面。尽管参照前述实施例对本申请进行了详细的说明,对于本领域的技术人员来而言,其依然可以对前述各具体实施方式所记载的技术方案进行修改,或者对其中部分技术特征进行等效替换。凡是利用本申请说明书及附图内容所做的等效结构,直接或间接运用在其他相关的技术领域,均同理在本申请专利保护范围之内。
Claims (10)
1.一种全链路压测方法,其特征在于,包括下述步骤:
接收并解析压测请求;
通过解析结果确定压测流量,将所述压测流量传入到业务模拟***中,模拟真实流量在待进行压测的业务***中流量传递过程;
基于所述压测流量在所述业务模拟***中模拟的所述流量传递过程,识别在全业务链路下所述真实流量依次流经的节点;
获取识别出的所述真实流量依次流经每个节点时对应压测数据;
基于识别出的所述真实流量依次流经的每个节点,获取所述待进行压测的业务***中节点间上下游关系,基于所述节点间上下游关系构建节点拓扑图;
基于所述压测数据和所述节点拓扑图对所述待进行压测的业务***进行***压测指标性能分析。
2.根据权利要求1所述的全链路压测方法,其特征在于,在所述接收并解析压测请求的步骤之前,所述方法还包括:
基于预设镜像生成工具,生成配置与待进行压测的业务***完全一致的业务模拟***;
在所述业务模拟***与所述待进行压测的业务***间设置监测***,实时监测所述待进行压测的业务***中各节点对应的真实流量;
所述接收并解析压测请求的步骤,具体包括:
在接收到所述压测请求时,基于所述监测***,实时获取所述待进行压测的业务***中各节点对应的真实流量;
将所述待进行压测的业务***中各节点对应的真实流量作为所述压测请求对应解析结果。
3.根据权利要求2所述的全链路压测方法,其特征在于,在所述实时获取所述待进行压测的业务***中各节点对应的真实流量的步骤之前,所述方法还包括:
获取所述业务模拟***中业务节点和支撑所述业务模拟***的资源节点;
对所述业务节点和所述资源节点设置节点区别标识;
在所述实时获取所述待进行压测的业务***中各节点对应的真实流量的步骤之后,所述方法还包括:
基于所述待进行压测的业务***中各节点对应的真实流量,进行统计,将统计结果作为所述业务模拟***的压测流量;
获取所述业务模拟***中与所述待进行压测的业务***中各节点相对应的各业务模拟***节点;
基于所述各业务模拟***节点对应的节点区别标识和所述待进行压测的业务***中各节点对应的真实流量,对所述压测流量进行定制化切分。
4.根据权利要求3所述的全链路压测方法,其特征在于,将所述压测流量传入到业务模拟***中的步骤,具体包括:
获取定制化切分之后所述业务模拟***中各节点对应的节点区别标识,将所述节点区别标识作为其对应压测流量的初始压测标识;
基于所述定制化切分结果和所述压测流量的初始压测标识,将所述压测流量分别分配到所述业务模拟***中各节点处;
所述模拟真实流量在待进行压测的业务***中流量传递过程的步骤,具体包括:
基于所述监测***,实时获取所述待进行压测的业务***中各节点对应的真实流量的传递过程;
基于所述待进行压测的业务***中各节点对应的真实流量的传递过程确定其在业务模拟***对应压测流量的传递过程。
5.根据权利要求4所述的全链路压测方法,其特征在于,所述基于所述待进行压测的业务***中各节点对应的真实流量的传递过程确定其在业务模拟***对应压测流量的传递过程的步骤之后,所述方法还包括:
基于预设中间件对当前节点处压测流量对应的压测标识进行识别,识别出所述压测流量中新传递过来的压测流量;
基于识别结果,判断当前压测流量是否为当前节点下游业务新传递过来的压测流量;
若是,则对当前压测流量进行压测标识更新;
若否,则保持当前压测流量的压测标识。
6.根据权利要求5所述的全链路压测方法,其特征在于,所述对当前压测流量进行压测标识更新的步骤,具体包括:
基于所述中间件,识别所述压测流量在本次流转前所处的上一节点和当前节点;
获取所述上一节点对应的节点区别标识作为第一节点标识;
获取所述当前节点对应的节点区别标识作为第二节点标识;
基于所述中间件,识别本次流转后所述压测流量所处的节点,获取所述节点对应的节点区别标识作为第三节点标识;
对所述第一节点标识、第二节点标识、第三节点标识按流转顺序进行拼接,将拼接结果设置为所述压测流量在本次流转后的上一节点处对应的压测标识。
7.根据权利要求6所述的全链路压测方法,其特征在于,所述基于所述压测流量在所述业务模拟***中模拟的所述流量传递过程,识别在全业务链路下所述真实流量依次流经的节点的步骤,具体包括:
对识别出的压测标识进行拆分处理,获取构成所述压测标识的第一节点标识、第二节点标识、第三节点标识;
基于所述第一节点标识、第二节点标识、第三节点标识,识别出所述压测流量在所述业务模拟***中各节点间的传递过程;
基于所述压测流量在所述业务模拟***中各节点间的传递过程,确定在待进行压测的业务***的全业务链路下所述真实流量依次流经的节点。
8.一种全链路压测装置,其特征在于,包括:
请求处理模块,用于接收并解析压测请求;
流量传递模拟模块,用于通过解析结果确定压测流量,将所述压测流量传入到业务模拟***中,模拟真实流量在待进行压测的业务***中流量传递过程;
流经节点识别模块,用于基于所述压测流量在所述业务模拟***中模拟的所述流量传递过程,识别在全业务链路下所述真实流量依次流经的节点;
压测数据获取模块,用于获取识别出的所述真实流量依次流经每个节点时对应压测数据;
节点拓扑图构建模块,用于基于识别出的所述真实流量依次流经的每个节点,获取所述待进行压测的业务***中节点间上下游关系,基于所述节点间上下游关系构建节点拓扑图;
压测分析模块,用于基于所述压测数据和所述节点拓扑图对所述待进行压测的业务***进行***压测指标性能分析。
9.一种计算机设备,包括存储器和处理器,所述存储器中存储有计算机可读指令,所述处理器执行所述计算机可读指令时实现如权利要求1至7中任一项所述的全链路压测方法的步骤。
10.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有计算机可读指令,所述计算机可读指令被处理器执行时实现如权利要求1至7中任一项所述的全链路压测方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210865402.2A CN115242684B (zh) | 2022-07-21 | 2022-07-21 | 全链路压测方法、装置、计算机设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210865402.2A CN115242684B (zh) | 2022-07-21 | 2022-07-21 | 全链路压测方法、装置、计算机设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN115242684A CN115242684A (zh) | 2022-10-25 |
CN115242684B true CN115242684B (zh) | 2023-06-20 |
Family
ID=83675558
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210865402.2A Active CN115242684B (zh) | 2022-07-21 | 2022-07-21 | 全链路压测方法、装置、计算机设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115242684B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN116756044B (zh) * | 2023-08-11 | 2023-11-21 | 杭州罗莱迪思科技股份有限公司 | 一种基于数据链路追踪的rpc远程调试方法、装置及应用 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109726094A (zh) * | 2017-10-27 | 2019-05-07 | 北京京东尚科信息技术有限公司 | 压力测试的方法和装置 |
CN110532168A (zh) * | 2019-07-05 | 2019-12-03 | 中国平安财产保险股份有限公司 | 全链路接口压测方法、装置、计算机设备及存储介质 |
CN111723018A (zh) * | 2020-06-28 | 2020-09-29 | 中国平安财产保险股份有限公司 | 性能压力测试方法、装置、设备及存储介质 |
CN114185792A (zh) * | 2021-12-13 | 2022-03-15 | 中国平安财产保险股份有限公司 | 一种压测场景的数据隔离方法、装置、设备及存储介质 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP3582437A1 (en) * | 2018-06-14 | 2019-12-18 | Vocalink Limited | System and method for simulating network events |
-
2022
- 2022-07-21 CN CN202210865402.2A patent/CN115242684B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109726094A (zh) * | 2017-10-27 | 2019-05-07 | 北京京东尚科信息技术有限公司 | 压力测试的方法和装置 |
CN110532168A (zh) * | 2019-07-05 | 2019-12-03 | 中国平安财产保险股份有限公司 | 全链路接口压测方法、装置、计算机设备及存储介质 |
CN111723018A (zh) * | 2020-06-28 | 2020-09-29 | 中国平安财产保险股份有限公司 | 性能压力测试方法、装置、设备及存储介质 |
CN114185792A (zh) * | 2021-12-13 | 2022-03-15 | 中国平安财产保险股份有限公司 | 一种压测场景的数据隔离方法、装置、设备及存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN115242684A (zh) | 2022-10-25 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110737726B (zh) | 一种确定待测试接口的测试数据的方法和装置 | |
CN112860662B (zh) | 自动化生产数据血缘关系建立方法、装置、计算机设备及存储介质 | |
CN115242684B (zh) | 全链路压测方法、装置、计算机设备及存储介质 | |
CN117234505A (zh) | 一种交互页面生成方法、装置、设备及其存储介质 | |
CN116841846A (zh) | 一种实时日志异常检测方法、装置、设备及其存储介质 | |
CN116453125A (zh) | 基于人工智能的数据录入方法、装置、设备及存储介质 | |
CN116383787A (zh) | 页面创建方法、装置、计算机设备及存储介质 | |
CN111859985B (zh) | Ai客服模型测试方法、装置、电子设备及存储介质 | |
CN112765022A (zh) | 一种基于数据流的Webshell静态检测方法及电子设备 | |
CN115314404B (zh) | 服务优化方法、装置、计算机设备及存储介质 | |
CN110580626A (zh) | 用于生成信息的方法和装置 | |
CN114545328B (zh) | 光缆巡线设备的跟踪方法、***、计算机设备及存储介质 | |
CN117851252A (zh) | 一种接口异常处理方法、装置、设备及其存储介质 | |
CN113806485B (zh) | 一种基于小样本冷启动的意图识别方法、装置及可读介质 | |
CN115250200B (zh) | 服务授权认证方法及其相关设备 | |
CN116467166A (zh) | 一种缺陷信息处理方法、装置、设备及其存储介质 | |
CN116795882A (zh) | 数据获取方法、装置、计算机设备及存储介质 | |
CN118250335A (zh) | 一种流量处理方法、装置、设备及其存储介质 | |
CN116431913A (zh) | 车主业务推文智能推荐方法、装置、设备及其存储介质 | |
CN116665646A (zh) | 方言数据自动筛选识别方法、装置、设备及其存储介质 | |
CN117421207A (zh) | 智能评估影响点测试方法、装置、计算机设备及存储介质 | |
CN116701488A (zh) | 数据处理方法、装置、计算机设备及存储介质 | |
CN116542733A (zh) | 产品推荐方法、装置、计算机设备及存储介质 | |
CN116860644A (zh) | 自动化测试方法、装置、计算机设备及存储介质 | |
CN116738084A (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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant |