CN116401089A - 一种基于增量迭代的接口熔断方法、存储介质及电子设备 - Google Patents

一种基于增量迭代的接口熔断方法、存储介质及电子设备 Download PDF

Info

Publication number
CN116401089A
CN116401089A CN202310439040.5A CN202310439040A CN116401089A CN 116401089 A CN116401089 A CN 116401089A CN 202310439040 A CN202310439040 A CN 202310439040A CN 116401089 A CN116401089 A CN 116401089A
Authority
CN
China
Prior art keywords
interface
data
target
identifier
identification
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.)
Granted
Application number
CN202310439040.5A
Other languages
English (en)
Other versions
CN116401089B (zh
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 Travelsky Mobile Technology Co Ltd
Original Assignee
China Travelsky Mobile 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 China Travelsky Mobile Technology Co Ltd filed Critical China Travelsky Mobile Technology Co Ltd
Priority to CN202310439040.5A priority Critical patent/CN116401089B/zh
Publication of CN116401089A publication Critical patent/CN116401089A/zh
Application granted granted Critical
Publication of CN116401089B publication Critical patent/CN116401089B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/0703Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
    • G06F11/0793Remedial or corrective actions
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/0703Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
    • G06F11/0706Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02PCLIMATE CHANGE MITIGATION TECHNOLOGIES IN THE PRODUCTION OR PROCESSING OF GOODS
    • Y02P90/00Enabling technologies with a potential contribution to greenhouse gas [GHG] emissions mitigation
    • Y02P90/02Total factory control, e.g. smart factories, flexible manufacturing systems [FMS] or integrated manufacturing systems [IMS]

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Quality & Reliability (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Communication Control (AREA)

Abstract

本发明涉及数据处理领域,特别是涉及一种基于增量迭代的接口熔断方法、存储介质及电子设备,该接口熔断方法应用于目标设备;目标设备中设置有若干数据接口;该接口熔断方法包括:响应于检测到目标数据接口处于故障状态,获取目标接口标识列表组H;目标数据接口为若干数据接口中的任一,目标数据接口的接口标识为目标标识;若H中存在包括目标标识的子接口标识组,则将H中包括目标标识的每一子接口标识组所在的接口标识组中的首个接口标识作为候选接口标识;将至少部分候选接口标识对应的数据接口作为关键数据接口;根据每一关键数据接口将目标数据接口调整至第一熔断状态。由此,可以提高目标设备获取数据的效率。

Description

一种基于增量迭代的接口熔断方法、存储介质及电子设备
技术领域
本发明涉及数据处理领域,特别是涉及一种基于增量迭代的接口熔断方法、存储介质及电子设备。
背景技术
在设置有若干数据接口的目标设备中的任一数据接口发生故障后,若目标设备根据接收到的数据获取请求调用的若干数据接口中包括发生故障的数据接口,则由于发生故障的数据接口返回数据较可能用时时长,因此会造成该目标设备根据接收到的数据获取请求进行数据获取的速度较慢,降低目标设备获取数据的效率。
发明内容
针对上述技术问题,本发明采用的技术方案为:
根据本发明的一方面,提供了一种基于增量迭代的接口熔断方法,该接口熔断方法应用于目标设备;目标设备中设置有若干数据接口。
接口熔断方法包括以下步骤:
S100,响应于检测到目标数据接口处于故障状态,获取目标接口标识列表组H;目标数据接口为若干数据接口中的任一;目标数据接口的接口标识为目标标识。
S200,若H中存在包括目标标识的子接口标识组,则将H中包括目标标识的每一子接口标识组所在的接口标识组中的首个接口标识作为候选接口标识。
S300,将至少部分候选接口标识对应的数据接口作为关键数据接口。
S400,根据每一关键数据接口将目标数据接口调整至第一熔断状态;处于第一熔断状态的目标数据接口被配置为,响应于被任一关键数据接口调用,在目标时长Δt内向关键数据接口返回预设失败标识;Δt≤Δt0,Δt0为预设时长。
H的获取方法包括以下步骤:
S110,周期性进行数据获取处理;数据获取处理包括以下步骤:
S111,获取目标通信协议对应的接口标识列表组A=(A1,A2,...,Ai,...,An),
Ai=(Ai1,Ai2,...,Aij,...,Aim(i)),Aij=(aij 0,aij),aij=(aij 1,aij 2,...,aij k,...,aij p(i,j)),i=1,2,...,n,
j=1,2,...,m(i),k=1,2,...,p(i,j);其中,Ai为第i个目标数据获取请求的对应的接口标识列表,目标数据获取请求为通信协议为目标通信协议的数据获取请求;n为在当前周期内目标设备接收到的目标数据获取请求的数量;Aij为目标设备根据第i个目标数据获取请求调用的第j个数据接口对应的接口标识组;m(i)为目标设备根据第i个目标数据获取请求调用的数据接口的数量;aij 0为目标设备根据第i个目标数据获取请求调用的第j个数据接口的接口标识;aij为Aij对应的子接口标识组,aij k为aij 0对应的数据接口根据第i个目标数据获取请求调用的第k个数据接口的接口标识,p(i,j)为aij 0对应的数据接口根据第i个目标数据获取请求调用的数据接口的数量。
S112,对A中的接口标识列表进行去重处理,以得到去重后接口标识列表组B=(b1,b2,...,bu,...,bv),u=1,2,...,v;其中,bu为B中的第u个去重后接口标识列表,B中的任意两个去重后接口标识列表均不同;v为B中的去重后接口标识列表的数量,v≤n;
S113,若当前周期为首个周期,则将B确定为H;否则,进入步骤S114。
S114,确定出B与当前的H的并集,并将H更新为该并集。
根据本发明的另一方面,还提供了一种非瞬时性计算机可读存储介质,存储介质中存储有至少一条指令或至少一段程序,至少一条指令或至少一段程序由处理器加载并执行以实现上述基于增量迭代的接口熔断方法。
根据本发明的另一方面,还提供了一种电子设备,包括处理器和上述非瞬时性计算机可读存储介质。
本发明至少具有以下有益效果:
本发明中在检测到目标设备中的目标数据接口处于故障状态时,获取当前的目标接口标识列表组H,若当前的H中存在包括目标标识的子接口标识组,则将H中包括目标标识的每一子接口标识组所在的接口标识组中的首个接口标识作为候选接口标识,再将至少部分候选接口标识对应的数据接口作为关键数据接口,并根据每一关键数据接口将目标数据接口调整至第一熔断状态。其中,处于第一熔断状态的目标数据接口被配置为,响应于被任一关键数据接口调用,在目标时长Δt内向关键数据接口返回预设失败标识,Δt≤Δt0
相比于为相关技术中在目标数据接口处于故障状态时目标数据接口向关键数据接口返回数据的速度较慢,本发明中将处于故障状态的目标数据接口调整为第一熔断状态,即任一关键数据接口调用目标数据接口,目标数据接口会在Δt内向该关键数据接口返回预设失败标识,即目标数据接口向该关键数据接口返回预设失败标识的速度较快,进而使目标设备根据接收到的数据获取请求进行数据获取的速度较快,提高目标设备获取数据的效率。
进一步的,相比于在目标数据接口发生故障时直接获取持续时长较长的历史时间段内的接口标识列表组,本发明在每一周期中会获取对应的接口标识列表组B,并基于B对经过上一个周期得到的H进行更新,以得到更新后的H,进而本发明中在确定出目标数据接口发生故障时可以较快的确定出当前的H,因此可以提高将目标数据接口调整至第一熔断状态的及时性。还可以目标设备在同一时间的计算压力,以减小目标设备出现异常的可能性。
附图说明
为了更清楚地说明本发明实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本发明实施例提供的基于增量迭代的接口熔断方法的流程图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
本发明实施例提供了一种基于增量迭代的接口熔断方法。该接口熔断方法应用于目标设备;目标设备中设置有若干数据接口。
具体的,目标设备可以为可以为以下任意一项或由以下任意项组合而成:终端、服务器、其他具备处理能力的设备,本发明实施例对此不作限定。数据接口为API(Application Programming Interface,应用程序编程接口)接口。
参照图1所示的基于增量迭代的接口熔断方法的流程图,该接口熔断方法包括以下步骤:
S100,响应于检测到目标数据接口处于故障状态,获取目标接口标识列表组H。
其中,目标数据接口为若干数据接口中的任一,目标数据接口的接口标识为目标标识。
具体的,数据接口的接口标识为对应的数据接口的唯一编码。目标数据接口处于故障状态为目标数据接口出现接收到数据获取请求后获取数据失败或返回数据超时等问题,本发明实施例对此不作限定。
S200,若H中存在包括目标标识的子接口标识组,则将H中包括目标标识的每一子接口标识组所在的接口标识组中的首个接口标识作为候选接口标识。
S300,将至少部分候选接口标识对应的数据接口作为关键数据接口。
S400,根据每一关键数据接口将目标数据接口调整至第一熔断状态。
其中,处于第一熔断状态的目标数据接口被配置为,响应于被任一关键数据接口调用,在目标时长Δt内向关键数据接口返回预设失败标识。
其中,Δt≤Δt0,Δt0为预设时长。
具体的,处于第一熔断状态的目标数据接口被配置为:对于每一关键数据接口,响应于被该关键数据接口调用,在目标时长Δt内向该关键数据接口返回预设失败标识。
可选的,处于正常状态的目标数据接口被配置为,对于其以外的每一数据接口,响应于被该数据接口调用,若调用失败,则在被该数据接口调用后经过至少失败时长Δt1后向该数据接口返回调用失败信息,Δt1≥Δt0
其中,H的获取方法包括以下步骤:
S110,周期性进行数据获取处理。数据获取处理包括以下步骤:
S111,获取目标通信协议对应的接口标识列表组A=(A1,A2,...,Ai,...,An),
Ai=(Ai1,Ai2,...,Aij,...,Aim(i)),Aij=(aij 0,aij),aij=(aij 1,aij 2,...,aij k,...,aij p(i,j)),i=1,2,...,n,
j=1,2,...,m(i),k=1,2,...,p(i,j);其中,Ai为第i个目标数据获取请求的对应的接口标识列表,目标数据获取请求为通信协议为目标通信协议的数据获取请求;n为在当前周期内目标设备接收到的目标数据获取请求的数量;Aij为目标设备根据第i个目标数据获取请求调用的第j个数据接口对应的接口标识组;m(i)为目标设备根据第i个目标数据获取请求调用的数据接口的数量;aij 0为目标设备根据第i个目标数据获取请求调用的第j个数据接口的接口标识;aij为Aij对应的子接口标识组,aij k为aij 0对应的数据接口根据第i个目标数据获取请求调用的第k个数据接口的接口标识,p(i,j)为aij 0对应的数据接口根据第i个目标数据获取请求调用的数据接口的数量。
例如,目标设备根据接收到的任一目标数据获取请求会调用3个数据接口,3个数据接口的接口标识分别为API1、API2和API3,API1响应于接收到该目标数据获取请求会调用API2和API3,即会向API2发送根据该目标数据获取请求生成的第一请求,并会向API3发送根据该目标数据获取请求生成的第二请求,API2响应于接收到第一请求会调用API3,即向API3发送根据第一请求生成的第三请求。基于此,若该目标数据获取请求为第1个目标数据获取请求,则该目标数据获取请求对应的接口标识列表为A1=(A11,A12,A13),其中,A11=(a11 0,a11),a11 0=API1,a11=(a11 1,a11 2),a11 1=API2,a11 2=API3;A12=(a12 0,a12),a12 0=API2,a12=(a12 1),a12 1=API3;A13=(a13 0,a13),a13 0=API3,a13为空集。
S112,对A中的接口标识列表进行去重处理,以得到去重后接口标识列表组B=(b1,b2,...,bu,...,bv),u=1,2,...,v;其中,bu为B中的第u个去重后接口标识列表,B中的任意两个去重后接口标识列表均不同;v为B中的去重后接口标识列表的数量,v≤n。
S113,若当前周期为首个周期,则将B确定为H;否则,进入步骤S114。
S114,确定出B与当前的H的并集,并将H更新为并集。
由此可知,本发明中在检测到目标设备中的目标数据接口处于故障状态时,获取当前的目标接口标识列表组H,若当前的H中存在包括目标标识的子接口标识组,则将H中包括目标标识的每一子接口标识组所在的接口标识组中的首个接口标识作为候选接口标识,再将至少部分候选接口标识对应的数据接口作为关键数据接口,并根据每一关键数据接口将目标数据接口调整至第一熔断状态。其中,处于第一熔断状态的目标数据接口被配置为,响应于被任一关键数据接口调用,在目标时长Δt内向关键数据接口返回预设失败标识,Δt≤Δt0
相比于为相关技术中在目标数据接口处于故障状态时目标数据接口向关键数据接口返回数据的速度较慢,本发明中将处于故障状态的目标数据接口调整为第一熔断状态,即任一关键数据接口调用目标数据接口,目标数据接口会在Δt内向该关键数据接口返回预设失败标识,即目标数据接口向该关键数据接口返回预设失败标识的速度较快,进而使目标设备根据接收到的数据获取请求进行数据获取的速度较快,提高目标设备获取数据的效率。
进一步的,相比于在目标数据接口发生故障时直接获取持续时长较长的历史时间段内的接口标识列表组,本发明在每一周期中会获取对应的接口标识列表组B,并基于B对经过上一个周期得到的H进行更新,以得到更新后的H,进而本发明中在确定出目标数据接口发生故障时可以较快的确定出当前的H,因此可以提高将目标数据接口调整至第一熔断状态的及时性。还可以目标设备在同一时间的计算压力,以减小目标设备出现异常的可能性。
在第一种具体的实施方式中:
每一数据接口均设置于目标设备对应的生产环境中。
基于此,步骤S113包括以下步骤:
S1131,若当前周期为首个周期,则将B确定为H,并进行关联类型确定处理;否则,进入步骤S114。
步骤S114包括以下步骤:
S1141,确定出B与当前的H的并集,将H更新为并集,并进行关联类型确定处理。
其中,关联类型确定处理包括以下步骤:
S115,将B中的全部子接口标识组的并集内的每一接口标识均作为第一接口标识,并对于每一第一接口标识,并将B中包括第一接口标识的每一子接口标识组所在的接口标识组中的首个接口标识均作为对应的第二接口标识;第一接口标识对应的数据接口为第一数据接口,第二接口标识对应的数据接口为第二数据接口。
S116,对每一第一数据接口和第一数据接口对应的每一第二数据接口进行关联类型确定子处理,以确定第一数据接口和第二数据接口之间的关联类型。
其中,关联类型确定子处理包括以下步骤:
S1161,将当前进行关联类型确定子处理的第一数据接口确定为第一当前接口,将当前进行关联类型确定子处理的第二数据接口确定为第二当前接口,并将当前的H中任一参考接口标识组中的首个接口标识对应的数据接口作为参考数据接口;参考接口标识组为当前的H中包括第二当前接口的接口标识的子接口标识组所在的接口标识组。
S1162,在目标设备对应的灰度环境中设置与第一当前接口相同的第一检测接口和与第二当前接口相同的第二检测接口。
具体的,第一检测接口调用第二检测接口的调用逻辑和第一当前接口调用第二当前接口的调用逻辑相同。
上述步骤S1162的一种具体的实施方式可以为,搭建灰度环境的泳道,在该泳道内设置第一检测接口和第二检测接口,基于此,对每一参考数据接口进行如下设置:
若接收到的数据获取请求为指示参考数据接口调用第二当前接口,则确定接收到的数据获取请求是否包括检测标识,若是,则将接收到的数据获取请求中的第二当前接口的接口标识替换为第二检测接口的接口标识。
S1163,将第一检测接口调整至第二熔断状态;处于第二熔断状态的第一检测接口被配置为,响应于被第二检测接口调用,在Δt内向第二检测接口返回预设失败标识。
S1164,通过参考数据接口向第二检测接口发送参考数据获取请求;第二检测接口响应于接收到参考数据获取请求,至少调用第一检测接口。
具体的,参考数据获取请求中包括上述检测标识。
S1165,若参考数据接口接收到第二检测接口返回的参考失败标识,则将第一当前接口与第二当前接口之间的关联类型确定为第一类型;否则,将第一当前接口与第二当前接口之间的关联类型确定为第二类型;参考失败标识用于表示第二检测接口根据参考数据获取请求获取数据失败。
具体的,第一类型和第二类型不同。
步骤S300包括以下步骤:
S301,在若干候选接口标识对应的数据接口中,将与目标数据接口之间的关联类型为第二类型的每一数据接口均作为关键数据接口。
由此可知,本发明中在第一检测接口被调整至第二熔断状态的前提下,即在第二检测接口接收到第一检测接口返回的预设失败标识的前提下,若参考数据接口接收到了第二检测接口返回的参考失败标识,则说明参考数据接口无法正常成功返回数据,进而可以说明第一当前接口的故障状态对第二当前接口的工作状态影响较大,此时将第一当前接口与第二当前接口之间的关联类型确定为第一类型;否则,可以说明第一当前接口的故障状态对第二当前接口的工作状态影响较小,此时将第一当前接口与第二当前接口之间的关联类型确定为第二类型。
相比于将每一候选接口标识对应的数据接口均作为关键数据接口,本发明中将与目标数据接口之间的关联类型为第二类型的每一数据接口作为关键数据接口,进而将目标数据接口调整至第一熔断状态时对其他数据接口的工作状态产生的影响较小,因此可以减小目标设备根据接收到的数据获取请求完全无法获取数据的可能性,提升用户体验。
在第二种具体的实施方式中:
上述步骤S1164替换为以下步骤:
S1166,若目标子接口标识组中的接口标识的数量不为1,则通过参考数据接口向第二检测接口发送若干第一数据获取请求。
其中,目标子接口标识组为目标接口标识组中的子接口标识组,目标接口标识组为当前的H中首个接口标识为第二当前接口的接口标识的接口标识组;第二检测接口根据接收到的第一数据获取请求,调用第一检测接口和第一数据请求对应的至少一个备选数据接口,备选数据接口为目标子接口标识组中,与第一当前接口的接口标识不同的接口标识对应的数据接口;至少部分第一数据获取请求对应的备选数据接口不同。
S1167,若目标子接口标识组中的接口标识的数量为1,则通过参考数据接口向第二检测接口发送若干第二数据获取请求。
其中,第二检测接口根据接收到的第二数据获取请求调用第一检测接口。
具体的,第一数据获取请求和第二数据获取请求均包括上述检测标识。
基于此,步骤S1165替换为以下步骤:
S1168,若参考数据接口中,接收到第二检测接口返回的目标失败标识的数量达到预设数量,则将第一当前接口与第二当前接口之间的关联类型确定为第一类型;否则,将第一当前接口与第二当前接口之间的关联类型确定为第二类型。
其中,目标失败标识用于表示第二检测接口根据接收到的对应的第一数据获取请求或对应的第二数据获取请求获取数据失败。
具体的,若目标子接口标识组中的接口标识的数量不为1,则预设数量至少为第一数据获取请求的数量的百分之50,否则,预设数量至少为第二数据获取请求的数量的百分之50。
相比于上述第一种具体的实施方式中,本发明采用的第二种具体的实施方式在目标子接口标识组中的接口标识的数量不为1时,会通过参考数据接口向第二检测接口发送若干第一数据获取请求,此时第二检测接口根据接收到的至少两个第一数据获取请求调用的数据接口至少部分不同,进而可以减小由于第二检测接口调用的第一检测接口以外的其他数据接口发生故障而导致第一检测接口向参考数据接口返回目标失败标识的可能性,因此可以减小误确定第一当前接口与第二当前接口之间的关联类型的可能性,达到了提高确定第一当前接口与第二当前接口之间的关联类型的准确性的目的。
可选的,参考数据获取请求为根据目标设备接收到的用户输入信息生成的或预设得到的。
同理,第一数据获取请求和第二数据获取请求为根据目标设备接收到的用户输入信息生成的或预设得到的。
可选的,步骤S113包括以下步骤:
S1132,若当前周期为首个周期,则将B确定为H,并进行第一展示处理;否则,进入步骤S114,并进行第二展示处理。
第一展示处理包括以下步骤:
S117,根据B中的每一接口标识组的首个接口标识和B中的每一子接口标识组生成有向图。
第二展示处理包括以下步骤:
S118,根据B中的每一接口标识组的首个接口标识和B中的每一子接口标识组对当前的有向图进行补充,以更新有向图。
第一展示处理和第二展示处理可以使开发人员基于有向图更清晰直接的了解到当前的H的具体情况。
可选的,有向图为拓扑图。
可选的,Δt0≤3秒。
可选的,步骤S200包括以下步骤:
S201,若当前的H中存在包括目标标识的子接口标识组,则将H中包括目标标识的每一子接口标识组所在的接口标识组中的首个接口标识作为候选接口标识;否则,输出用于表示熔断错误的标识。
本发明的实施例还提供了一种非瞬时性计算机可读存储介质,该存储介质可设置于电子设备之中以保存用于实现方法实施例中一种方法相关的至少一条指令或至少一段程序,该至少一条指令或该至少一段程序由该处理器加载并执行以实现上述实施例提供的接口熔断方法。
本发明的实施例还提供了一种电子设备,包括处理器和前述的非瞬时性计算机可读存储介质。
本发明的实施例还提供一种计算机程序产品,其包括程序代码,当程序产品在电子设备上运行时,程序代码用于使该电子设备执行本说明书上述描述的根据本发明各种示例性实施方式的接口熔断方法中的步骤。
虽然已经通过示例对本发明的一些特定实施例进行了详细说明,但是本领域的技术人员应该理解,以上示例仅是为了进行说明,而不是为了限制本发明的范围。本领域的技术人员还应理解,可以对实施例进行多种修改而不脱离本发明的范围和精神。本发明公开的范围由所附权利要求来限定。

Claims (10)

1.一种基于增量迭代的接口熔断方法,其特征在于,所述接口熔断方法应用于目标设备;所述目标设备中设置有若干数据接口;
所述接口熔断方法包括以下步骤:
S100,响应于检测到目标数据接口处于故障状态,获取目标接口标识列表组H;所述目标数据接口为若干所述数据接口中的任一;所述目标数据接口的接口标识为目标标识;
S200,若H中存在包括所述目标标识的子接口标识组,则将H中包括所述目标标识的每一子接口标识组所在的接口标识组中的首个接口标识作为候选接口标识;
S300,将至少部分候选接口标识对应的数据接口作为关键数据接口;
S400,根据每一所述关键数据接口将所述目标数据接口调整至第一熔断状态;处于所述第一熔断状态的目标数据接口被配置为,响应于被任一所述关键数据接口调用,在目标时长Δt内向所述关键数据接口返回预设失败标识;Δt≤Δt0,Δt0为预设时长;
H的获取方法包括以下步骤:
S110,周期性进行数据获取处理;所述数据获取处理包括以下步骤:
S111,获取目标通信协议对应的接口标识列表组A=(A1,A2,...,Ai,...,An),
Ai=(Ai1,Ai2,...,Aij,...,Aim(i)),Aij=(aij 0,aij),aij=(aij 1,aij 2,...,aij k,...,aij p(i ,j)),
i=1,2,...,n,j=1,2,...,m(i),k=1,2,...,p(i,j);其中,Ai为第i个目标数据获取请求的对应的接口标识列表,所述目标数据获取请求为通信协议为所述目标通信协议的数据获取请求;n为在当前周期内所述目标设备接收到的目标数据获取请求的数量;Aij为所述目标设备根据第i个目标数据获取请求调用的第j个数据接口对应的接口标识组;m(i)为所述目标设备根据第i个目标数据获取请求调用的数据接口的数量;aij 0为所述目标设备根据第i个目标数据获取请求调用的第j个数据接口的接口标识;aij为Aij对应的子接口标识组,aij k为aij 0对应的数据接口根据第i个目标数据获取请求调用的第k个数据接口的接口标识,p(i,j)为aij 0对应的数据接口根据第i个目标数据获取请求调用的数据接口的数量;
S112,对A中的接口标识列表进行去重处理,以得到去重后接口标识列表组B=(b1,b2,...,bu,...,bv),u=1,2,...,v;其中,bu为B中的第u个去重后接口标识列表,B中的任意两个去重后接口标识列表均不同;v为B中的去重后接口标识列表的数量,v≤n;
S113,若所述当前周期为首个周期,则将B确定为H;否则,进入步骤S114;
S114,确定出B与当前的H的并集,并将H更新为所述并集。
2.根据权利要求1所述的接口熔断方法,其特征在于,每一所述数据接口均设置于所述目标设备对应的生产环境中;
所述步骤S113包括以下步骤:
S1131,若所述当前周期为首个周期,则将B确定为H,并进行关联类型确定处理;否则,进入步骤S114;
所述步骤S114包括以下步骤:
S1141,确定出B与当前的H的并集,将H更新为所述并集,并进行关联类型确定处理;
所述关联类型确定处理包括以下步骤:
S115,将B中的全部子接口标识组的并集内的每一接口标识均作为第一接口标识,并对于每一所述第一接口标识,并将B中包括所述第一接口标识的每一子接口标识组所在的接口标识组中的首个接口标识均作为对应的第二接口标识;所述第一接口标识对应的数据接口为第一数据接口,所述第二接口标识对应的数据接口为第二数据接口;
S116,对每一第一数据接口和所述第一数据接口对应的每一第二数据接口进行关联类型确定子处理,以确定所述第一数据接口和所述第二数据接口之间的关联类型;
所述关联类型确定子处理包括以下步骤:
S1161,将当前进行所述关联类型确定子处理的第一数据接口确定为第一当前接口,将当前进行所述关联类型确定子处理的第二数据接口确定为第二当前接口,并将当前的H中任一参考接口标识组中的首个接口标识对应的数据接口作为参考数据接口;所述参考接口标识组为当前的H中包括所述第二当前接口的接口标识的子接口标识组所在的接口标识组;
S1162,在所述目标设备对应的灰度环境中设置与第一当前接口相同的第一检测接口和与第二当前接口相同的第二检测接口;
S1163,将所述第一检测接口调整至第二熔断状态;处于所述第二熔断状态的第一检测接口被配置为,响应于被所述第二检测接口调用,在Δt内向所述第二检测接口返回所述预设失败标识;
S1164,通过所述参考数据接口向所述第二检测接口发送参考数据获取请求;所述第二检测接口响应于接收到所述参考数据获取请求,至少调用所述第一检测接口;
S1165,若所述参考数据接口接收到所述第二检测接口返回的参考失败标识,则将所述第一当前接口与所述第二当前接口之间的关联类型确定为第一类型;否则,将所述第一当前接口与所述第二当前接口之间的关联类型确定为第二类型;所述参考失败标识用于表示所述第二检测接口根据所述参考数据获取请求获取数据失败;
所述步骤S300包括以下步骤:
S301,在若干所述候选接口标识对应的数据接口中,将与所述目标数据接口之间的关联类型为第二类型的每一所述数据接口均作为关键数据接口。
3.根据权利要求2所述的接口熔断方法,其特征在于,所述步骤S1164替换为以下步骤:
S1166,若目标子接口标识组中的接口标识的数量不为1,则通过所述参考数据接口向所述第二检测接口发送若干第一数据获取请求;所述目标子接口标识组为目标接口标识组中的子接口标识组,所述目标接口标识组为当前的H中首个接口标识为所述第二当前接口的接口标识的接口标识组;所述第二检测接口根据接收到的第一数据获取请求,调用所述第一检测接口和所述第一数据请求对应的至少一个备选数据接口,所述备选数据接口为所述目标子接口标识组中,与所述第一当前接口的接口标识不同的接口标识对应的数据接口;至少部分第一数据获取请求对应的备选数据接口不同;
S1167,若目标子接口标识组中的接口标识的数量为1,则通过所述参考数据接口向所述第二检测接口发送若干第二数据获取请求;所述第二检测接口根据接收到的第二数据获取请求调用所述第一检测接口;
所述步骤S1165替换为以下步骤:
S1168,若所述参考数据接口中,接收到所述第二检测接口返回的目标失败标识的数量达到预设数量,则将所述第一当前接口与所述第二当前接口之间的关联类型确定为第一类型;否则,将所述第一当前接口与所述第二当前接口之间的关联类型确定为第二类型;所述目标失败标识用于表示所述第二检测接口根据接收到的对应的第一数据获取请求或对应的第二数据获取请求获取数据失败。
4.根据权利要求2所述的接口熔断方法,其特征在于,所述参考数据获取请求为根据所述目标设备接收到的用户输入信息生成的或预设得到的。
5.根据权利要求1所述的接口熔断方法,其特征在于,所述步骤S113包括以下步骤:
S1132,若所述当前周期为首个周期,则将B确定为H,并进行第一展示处理;否则,进入步骤S114,并进行第二展示处理;
所述第一展示处理包括以下步骤:
S117,根据B中的每一接口标识组的首个接口标识和B中的每一子接口标识组生成有向图;
所述第二展示处理包括以下步骤:
S118,根据B中的每一接口标识组的首个接口标识和B中的每一子接口标识组对当前的有向图进行补充,以更新所述有向图。
6.根据权利要求5所述的接口熔断方法,其特征在于,所述有向图为拓扑图。
7.根据权利要求1所述的接口熔断方法,其特征在于,Δt0≤3秒。
8.根据权利要求1所述的接口熔断方法,其特征在于,所述步骤S200包括以下步骤:
S201,若当前的H中存在包括所述目标标识的子接口标识组,则将H中包括所述目标标识的每一子接口标识组所在的接口标识组中的首个接口标识作为候选接口标识;否则,输出用于表示熔断错误的标识。
9.一种非瞬时性计算机可读存储介质,所述存储介质中存储有至少一条指令或至少一段程序,其特征在于,所述至少一条指令或所述至少一段程序由处理器加载并执行以实现如权利要求1-8中任意一项的所述方法。
10.一种电子设备,其特征在于,包括处理器和权利要求9中的所述非瞬时性计算机可读存储介质。
CN202310439040.5A 2023-04-23 2023-04-23 一种基于增量迭代的接口熔断方法、存储介质及电子设备 Active CN116401089B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202310439040.5A CN116401089B (zh) 2023-04-23 2023-04-23 一种基于增量迭代的接口熔断方法、存储介质及电子设备

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202310439040.5A CN116401089B (zh) 2023-04-23 2023-04-23 一种基于增量迭代的接口熔断方法、存储介质及电子设备

Publications (2)

Publication Number Publication Date
CN116401089A true CN116401089A (zh) 2023-07-07
CN116401089B CN116401089B (zh) 2024-01-26

Family

ID=87015971

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202310439040.5A Active CN116401089B (zh) 2023-04-23 2023-04-23 一种基于增量迭代的接口熔断方法、存储介质及电子设备

Country Status (1)

Country Link
CN (1) CN116401089B (zh)

Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110650186A (zh) * 2019-09-06 2020-01-03 上海陆家嘴国际金融资产交易市场股份有限公司 接口调用方法、装置、计算机设备和存储介质
WO2021217846A1 (zh) * 2020-04-28 2021-11-04 平安国际智慧城市科技股份有限公司 接口数据处理方法、装置、计算机设备和存储介质
CN114356785A (zh) * 2022-03-11 2022-04-15 中航信移动科技有限公司 一种数据处理方法、装置、电子设备及存储介质
CN114827280A (zh) * 2022-04-26 2022-07-29 中国建设银行股份有限公司 请求处理方法、装置、设备、介质
CN114860793A (zh) * 2022-07-05 2022-08-05 中航信移动科技有限公司 数据处理方法、装置、存储介质及电子设备
CN115454400A (zh) * 2022-09-05 2022-12-09 深圳前海微众银行股份有限公司 接口参数的处理方法、装置、设备、介质及程序产品
CN115809305A (zh) * 2022-11-30 2023-03-17 和美(深圳)信息技术股份有限公司 一种用于实体数据的数据存储方法、电子设备及存储介质

Patent Citations (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110650186A (zh) * 2019-09-06 2020-01-03 上海陆家嘴国际金融资产交易市场股份有限公司 接口调用方法、装置、计算机设备和存储介质
WO2021217846A1 (zh) * 2020-04-28 2021-11-04 平安国际智慧城市科技股份有限公司 接口数据处理方法、装置、计算机设备和存储介质
CN114356785A (zh) * 2022-03-11 2022-04-15 中航信移动科技有限公司 一种数据处理方法、装置、电子设备及存储介质
CN114827280A (zh) * 2022-04-26 2022-07-29 中国建设银行股份有限公司 请求处理方法、装置、设备、介质
CN114860793A (zh) * 2022-07-05 2022-08-05 中航信移动科技有限公司 数据处理方法、装置、存储介质及电子设备
CN115454400A (zh) * 2022-09-05 2022-12-09 深圳前海微众银行股份有限公司 接口参数的处理方法、装置、设备、介质及程序产品
CN115809305A (zh) * 2022-11-30 2023-03-17 和美(深圳)信息技术股份有限公司 一种用于实体数据的数据存储方法、电子设备及存储介质

Also Published As

Publication number Publication date
CN116401089B (zh) 2024-01-26

Similar Documents

Publication Publication Date Title
CN110995851B (zh) 消息处理方法、装置、存储介质及设备
JP2011103030A (ja) インシデント管理方法および運用管理サーバ
CN111654453A (zh) 表单数据离线缓存方法、装置、终端及存储介质
CN111339137A (zh) 一种数据校验方法及装置
WO2016109951A1 (zh) 响应消息处理方法、装置及系统
CN110955758A (zh) 代码检测方法、代码检测服务器及索引服务器
CN116401089B (zh) 一种基于增量迭代的接口熔断方法、存储介质及电子设备
CN113641544A (zh) 用于检测应用状态的方法、装置、设备、介质和产品
CN111597032B (zh) 任务调度管理方法、装置及电子设备
CN116383083B (zh) 基于多接口连接的异常数据源确定方法及存储介质
CN115296979B (zh) 一种故障处理方法、装置、设备及存储介质
CN116627432A (zh) 一种前端应用自动化部署方法、装置、设备及介质
CN116450176A (zh) 版本更新方法、装置、电子设备及存储介质
CN113377381B (zh) 小程序包的分发方法、装置、电子设备和介质
CN115167896A (zh) 一种更新软件版本的方法、装置、存储介质及电子设备
CN111858124A (zh) 一种自动检测智能终端驱动程序完整性的方法及系统
CN113672281A (zh) 代码差异查询方法、装置、设备及存储介质
CN117093465B (zh) 服务器日志收集方法、装置、通信设备及存储介质
CN112907221B (zh) 一种自服务方法、装置及系统
CN116401090B (zh) 一种基于数据更新的异常数据源确定方法
CN117493000A (zh) 一种任务处理方法、装置、设备及介质
CN116719791A (zh) 一种信息处理方法、装置、电子设备及存储介质
CN113010272A (zh) 一种交易并发数控制方法及其相关设备
CN115617616A (zh) 一种服务器fru的运行监测方法、装置、设备及存储介质
CN115686933A (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