[发明专利]一种故障注入方法、装置及设备有效
申请号: | 201810573924.9 | 申请日: | 2018-06-06 |
公开(公告)号: | CN109032825B | 公开(公告)日: | 2021-09-14 |
发明(设计)人: | 邱硕 | 申请(专利权)人: | 创新先进技术有限公司 |
主分类号: | G06F11/07 | 分类号: | G06F11/07;G06F8/30 |
代理公司: | 北京国昊天诚知识产权代理有限公司 11315 | 代理人: | 许志勇 |
地址: | 英属开曼群岛大开曼*** | 国省代码: | 暂无信息 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 故障 注入 方法 装置 设备 | ||
本说明书实施例公开了一种故障注入方法、装置及设备,所述方法包括:拦截目标服务方法的调用请求,所述调用请求中包括所述目标服务方法的标识和调用参数的数值;如果预定的目标故障描述信息与所述目标服务方法的标识和调用参数的数值相匹配,则对所述目标服务方法注入所述目标故障描述信息对应的目标故障注入逻辑,以确定执行所述目标故障注入逻辑产生的故障结果,所述目标故障描述信息包括进行故障注入的服务方法的标识和所述服务方法对应的调用参数的数值。
技术领域
本说明书涉及计算机技术领域,尤其涉及一种故障注入方法、装置及设备。
背景技术
在互联网系统中,单体应用被拆分成多个应用后,不同应用之间可以通过分布式服务框架,或者也可以通过预定的可以实现RPC(Remote Procedure Call,远程过程调用)的服务框架进行通讯交互,从而实现面向服务架构的互联网系统,而通常面向服务架构的互联网系统需要针对某服务进行线上监控。
通常,可以通过向指定服务方法中注入故障数据来实现判断是否具备异常行为的容错能力,具体地,可以在原有服务方法的实现逻辑之前或之后注入故障数据,其中,该故障数据的编写(可以通过Java等编程语言编写)是在服务方法实现内部完成,会使得每次新增故障类型(或故障行为)和/或注入条件时需要发布新的应用代码,以更新相应的应用和业务系统,而相应的应用和业务系统也需要对故障数据进行编译等处理,从而使得故障注入逻辑较复杂,故障注入效率低下,因此,需要提供一种更简单快捷、故障注入效率更高的方案。
发明内容
本说明书实施例的目的是提供一种故障注入方法、装置及设备,以提供一种更简单快捷、故障注入效率更高的方案。
为实现上述技术方案,本说明书实施例是这样实现的:
本说明书实施例提供的一种故障注入方法,包括:
拦截目标服务方法的调用请求,所述调用请求中包括所述目标服务方法的标识和调用参数的数值;
如果预定的目标故障描述信息与所述目标服务方法的标识和调用参数的数值相匹配,则对所述目标服务方法注入所述目标故障描述信息对应的目标故障注入逻辑,以确定执行所述目标故障注入逻辑产生的故障结果,所述目标故障描述信息包括进行故障注入的服务方法的标识和所述服务方法对应的调用参数的数值。
可选地,所述对所述目标服务方法注入所述目标故障描述信息对应的目标故障注入逻辑,包括:
获取所述目标故障注入逻辑对应的故障类型,所述故障类型包括前置类和非前置类;
如果所述故障类型为前置类,则对所述目标服务方法注入所述目标故障描述信息对应的目标故障注入逻辑。
可选地,所述前置类包括抛错、延迟和篡改参数数值,
所述如果所述故障类型为前置类,则对所述目标服务方法注入所述目标故障描述信息对应的目标故障注入逻辑,包括:
如果所述故障类型为前置类中的第一子类,则根据所述第一子类,判断是否在调用所述目标服务方法前,对所述目标服务方法注入所述目标故障描述信息对应的目标故障注入逻辑,其中,所述第一子类为抛错、延迟或篡改参数数值。
可选地,所述目标故障描述信息是通过领域专用语言DSL编写。
可选地,所述目标故障描述信息中包括多个关键字段,所述多个关键字段分别用于表征进行故障注入的服务方法的标识和调用参数的数值,以及注入的故障逻辑的内容。
可选地,所述目标故障描述信息的多个关键字段分别为FROM、WHERE和UPDATE。
可选地,所述方法还包括:
对所述目标故障描述信息的内容进行分析,分别得到每个关键字段对应的内容;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于创新先进技术有限公司,未经创新先进技术有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201810573924.9/2.html,转载请声明来源钻瓜专利网。