CN112737856A - 链路追踪方法和装置、存储介质及电子装置 - Google Patents
链路追踪方法和装置、存储介质及电子装置 Download PDFInfo
- Publication number
- CN112737856A CN112737856A CN202011640642.XA CN202011640642A CN112737856A CN 112737856 A CN112737856 A CN 112737856A CN 202011640642 A CN202011640642 A CN 202011640642A CN 112737856 A CN112737856 A CN 112737856A
- Authority
- CN
- China
- Prior art keywords
- node
- target
- tracking
- state
- link
- 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
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/06—Management of faults, events, alarms or notifications
- H04L41/069—Management of faults, events, alarms or notifications using logs of notifications; Post-processing of notifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/06—Management of faults, events, alarms or notifications
- H04L41/0677—Localisation of faults
-
- 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/10—Active monitoring, e.g. heartbeat, ping or trace-route
Abstract
本发明公开了链路追踪方法和装置、存储介质及电子装置,该位置识别方法包括:在用于实现目标操作业务的目标链路中的各个节点接收到操作指令的情况下,在各个节点中生成各自对应的追踪标志及节点状态,其中,追踪标志用于标志节点在目标链路中的时序位置,节点状态用于指示节点执行操作指令所指示的操作的进度情况;在检测到目标操作业务出现异常的情况下,根据各个节点各自对应的节点状态,追踪定位出目标节点,其中,目标节点为目标操作业务出现异常时的故障节点。通过记录节点的追踪标志和节点状态,可以有效解决现有链路追踪技术中传的数据延迟的问题。
Description
技术领域
本发明涉及计算机领域,具体而言,涉及链路追踪方法和装置、存储介质及电子装置。
背景技术
随着互联网架构的扩张,分布式系统变得日趋复杂,越来越多的组件开始走向分布式化,如微服务、消息收发、分布式数据库、分布式缓存、分布式对象存储、跨域调用,这些组件共同构成了繁杂的分布式网络,那现在的问题是一个请求经过了这些服务后其中出现了一个调用失败的问题,只知道有异常,但具体的异常在哪个服务引起的就需要进入每一个服务里面看日志,这样的处理效率是非常低的。链式追踪其实就是将一次分布式请求还原成调用链路。现有的链路追踪实现方式是链路中的各个节点在每个用户请求到来的时候都输出相应的日志,在链路的起点为每个请求生成一个全局唯一的请求ID,根据请求ID可以串联起各个节点日志,还原出完整的调用链路。还原调用链路的具体方法是每隔一段时间,收集这段时间各个节点的日志,再根据请求ID还原调用链路。由于每隔一段时间需要对链路进行计算,现有的链路追踪实现方式不能实现实时追踪的情况,容易出现数据延迟。
针对上述的问题,目前尚未提出有效的解决方案。
发明内容
本发明实施例提供了一种链路追踪方法和装置、存储介质及电子装置,以解决现有技术中,链路追踪方法容易出现数据延迟的问题。
根据本发明实施例的一个方面,提供了一种链路追踪的方法,包括:在用于实现目标操作业务的目标链路中的各个节点接收到操作指令的情况下,在上述各个节点中生成各自对应的追踪标志及节点状态,其中,上述追踪标志用于标志上述节点在上述目标链路中的时序位置,上述节点状态用于指示上述节点执行上述操作指令所指示的操作的进度情况;在检测到上述目标操作业务出现异常的情况下,根据上述各个节点各自对应的节点状态,追踪定位出目标节点,其中,上述目标节点为上述目标操作业务出现异常时的故障节点。
可选地,上述在上述各个节点中生成各自对应的追踪标志及节点状态之后,还包括:在上述节点为父节点且连接至少两个子节点的情况下,将上述父节点的追踪标志和上述父节点的节点状态存储到上述目标操作业务的操作进程对应的调用记录中,并将上述父节点连接的上述至少两个子节点的节点状态存储到上述目标操作业务的操作进程对应的上述调用记录中。
可选地,上述将上述父节点连接的上述至少两个子节点的节点状态存储到上述目标操作业务的操作进程对应的上述调用记录中包括:获取为上述至少两个子节点中每个子节点各自配置的追踪权重;将上述每个子节点各自配置的上述追踪权重存储到与上述子节点的节点状态关联的上述调用记录中。
可选地,上述根据上述各个节点各自对应的节点状态,追踪定位出目标节点包括:遍历上述各个节点,直至定位出全部的上述目标节点:在当前节点为父节点的情况下,获取上述当前节点的节点状态;在上述当前节点的节点状态指示已完成上述操作指令所指示的操作的情况下,获取下一个节点;在上述当前节点的节点状态指示并未完成上述操作指令所指示的操作的情况下,获取上述当前节点连接的至少两个子节点的节点状态;在上述至少两个子节点中的至少一个子节点的节点状态指示未完成操作的情况下,确定上述至少一个子节点为上述目标节点。
可选地,上述确定上述至少一个子节点为上述目标节点包括:在上述当前节点的节点状态指示并未完成上述操作指令所指示的操作的情况下,获取上述当前节点连接的至少两个子节点各自的优先级;其中,上述子节点的优先级与上述子节点各自配置的追踪权重正相关;根据上述至少两个子节点各自的优先级,依次获取到上述至少两个子节点中每个子节点的节点状态;根据上述至少两个子节点中每个子节点的节点状态排查上述目标操作业务出现异常的情况;在上述两个子节点中的至少一个子节点的节点状态指示未完成操作的情况下,确定上述至少一个子节点为上述目标节点。
可选地,在根据上述各个节点各自对应的节点状态,追踪定位出目标节点之后,还包括:在父节点状态显示业务完成状态的情况下,将上述追踪标志和业务状态转换得到字符串存储到上述调用链路的每个进程每个线程的调用记录中,生成保护上述追踪标志和上述节点状态的日志信息。
可选地,在所述节点状态指示已完成所述操作指令所指示的操作的情况下,所述节点状态还用于记录每个所述节点完成所述操作指令的时长,根据所述完成所述节点的时长判断所述节点在所述目标链路中完成操作指令的效率。
根据本发明实施例的另一方面,本发明提供一种链路追踪装置,采用上述的链路追踪方法,上述装置包括:接收单元,用于接收操作指令;处理单元,用于根据上述操作指令生成与上述操作指令对应节点的追踪标志和节点状态,其中上述追踪标志用于标志上述节点在目标链路的时序位置,上述节点状态用于指示上述节点执行上述操作指令所指示的操作的进度情况;生成单元,用于在上述节点状态指示已完成上述操作指令所指示的操作的情况下,将追踪标志和业务完成状态生成链路的生成日志;报错单元,用于检测上述节点状态的完成情况,在检测到上述目标操作业务出现异常的情况下,根据上述各个节点各自对应的节点状态,追踪定位出目标节点,其中,上述目标节点为上述目标操作业务出现异常时的故障节点。
根据本发明实施例的又一方面,本发明提供一种存储介质,上述存储介质中存储有计算机程序,其中,上述计算机程序被设置为运行时执行上述的链路追踪方法。
根据本发明实施例的又一方面,本发明还提供一种电子装置,包括存储器和处理器,上述存储器中存储有计算机程序,上述处理器被设置为运行上述计算机程序以执行上述的链路追踪方法。
在本发明实施例中,在用于实现目标操作业务的目标链路中的各个节点接收到操作指令的情况下,通过在各个节点中生成各自对应的追踪标志及节点状态,其中,追踪标志用于标志节点在目标链路中的时序位置,节点状态用于指示节点执行操作指令所指示的操作的进度情况;在检测到目标操作业务出现异常的情况下,根据各个节点各自对应的节点状态,追踪定位出目标节点,其中,目标节点为目标操作业务出现异常时的故障节点。通过记录节点的追踪标志和节点状态,可以有效解决现有链路追踪技术中出现数据延迟的问题。
附图说明
此处所说明的附图用来提供对本发明的进一步理解,构成本申请的一部分,本发明的示意性实施例及其说明用于解释本发明,并不构成对本发明的不当限定。在附图中:
图1是根据本发明实施例的一种可选的链路追踪方法的应用环境的示意图;
图2是根据本发明实施例的一种可选的链路追踪方法的示意图;
图3是根据本发明实施例的另一种可选的链路追踪方法的示意图;
图4是根据本发明实施例的另一种可选的链路追踪方法的示意图;
图5是根据本发明实施例的另一种可选的链路追踪方法的示意图;
图6是根据本发明实施例的另一种可选的链路追踪方法的示意图;
图7是根据本发明实施例的另一种可选的链路追踪方法的示意图;
图8是根据本发明实施例的一种可选的链路追踪装置的示意图;
图9是根据本发明实施例的一种可选的电子装置的结构示意图。
具体实施方式
为了使本技术领域的人员更好地理解本发明方案,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分的实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都应当属于本发明保护的范围。
需要说明的是,本发明的说明书和权利要求书及上述附图中的术语“第一”、“第二”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本发明的实施例能够以除了在这里图示或描述的那些以外的顺序实施。此外,术语“包括”和“具有”以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或单元的过程、方法、系统、产品或设备不必限于清楚地列出的那些步骤或单元,而是可包括没有清楚地列出的或对于这些过程、方法、产品或设备固有的其它步骤或单元。
为了使本技术领域的人员更好地理解本发明方案,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本发明一部分的实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都应当属于本发明保护的范围。
需要说明的是,本发明的说明书和权利要求书及上述附图中的术语“第一”、“第二”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本发明的实施例能够以除了在这里图示或描述的那些以外的顺序实施。此外,术语“包括”和“具有”以及他们的任何变形,意图在于覆盖不排他的包含,例如,包含了一系列步骤或单元的过程、方法、系统、产品或设备不必限于清楚地列出的那些步骤或单元,而是可包括没有清楚地列出的或对于这些过程、方法、产品或设备固有的其它步骤或单元。
根据本发明实施例的一个方面,提供了一种链路追踪方法,可选地,作为一种可选的实施方式,上述链路追踪方法可以但不限于应用于如图1所示的环境中。其中,可以但不限于包括用户设备102、网络110、服务器112及目标缓存系统118,其中,该用户设备102上可以但不限于包括显示器108、处理器106及存储器104。
具体过程可如下步骤:
步骤S102:获取用户设备102在用户界面上触发的操作任务指令;
步骤S104-S106,用户设备102通过网络110将操作业务指令发送给服务器112;
步骤S108,处理引擎116操作业务的目标链路中的各个节点接收到操作指令的情况下,在各个节点中生成各自对应的追踪标志及节点状态,其中,追踪标志用于标志节点在目标链路中的时序位置,节点状态用于指示节点执行操作指令所指示的操作的进度情况;
步骤S110-S112,服务器112通过网络110将各个节点中生成各自节点对应的节点信息发送给目标缓存系统118,其中,目标缓存系统118用于根据节点信息生成日志信息,并为用户设备102或其他用户设备提供待读取日志信息。
可选地,作为一种可选的实施方式,如图2所示,链路追踪方法包括:
S202在用于实现目标操作业务的目标链路中的各个节点接收到操作指令的情况下,在各个节点中生成各自对应的追踪标志及节点状态,其中,追踪标志用于标志节点在目标链路中的时序位置,节点状态用于指示节点执行操作指令所指示的操作的进度情况;
S204,在检测到目标操作业务出现异常的情况下,根据各个节点各自对应的节点状态,追踪定位出目标节点,其中,目标节点为目标操作业务出现异常时的故障节点。
可选地,在本实施例中,上述数据处理方法可以但不限于应用追踪链路执行操作业务情况的场景,具体地获取在实现目标操作业务的目标链路中的各个节点接收操作指令的情况下,在各个节点中生成各自对应的追踪标志及节点状态;在检测到目标操作业务出现异常的情况下,根据各个节点各自对应的状态追踪定位至目标节点,其中目标节点未出现异常的故障节点。同时,还可以根据该链路追踪方法,显示目标链路实现目标操作业务时,各个节点完成操作指令的时间,并根据各个节点完成操作指令的时间反馈各节点完成操作指令的效率,从而评估链路设计的合理性。
在现有链路追踪技术中,是链路中的各个节点在每个用户请求到来的时候都输出相应的日志,在链路的起点为每个请求生成一个全局唯一的请求ID,根据请求ID串联起每个节点日志,还原调用链路是需要每隔一段时间,收集这段时间各个节点的日志,再根据请求ID还原调用电路。这样的还原调用电路的过程,往往与实际进程存在有时间差,不能很好地反映实时电路状态。可选地,本发明提供一种链路追踪方法,可以实现展现计算机控制状态,并不受控制链路信息的完整性限制。
进一步举例说明,可选的例如图3所示,节点信息302包括各节点对应的追踪标志和节点状态。步骤S302:将节点信息302存入目标存储系统304,S304在目标存储系统304中首先将节点信息转换为字符串,并将字符串存入目标存储心态中,S306将节点信息转换成数据,数据写入目标存储系统304中,S308对数据进行筛选;步骤S310,将数据录入目标缓存系统306中并生成日志,在目标缓存系统306中读取日志对应的业务状态数据,并基于业务状态数据继续后续的业务计算。
可选的,在本实施例中,目标缓存系统可以但不限于为一个独立的KV(key/value)结构的缓存系统,例如redis、memcache等,以redis为例说明,redis可以但不限于提供基本的数据结构:String:字符串,Hash:散列,List:列表,Set:集合,Sorted Set:有序集合,Redis Sorted Set api支持应用程序快速的有序读取最新一条数据,根据score查询一段时间数据,删除一段时间,新增数据自动根据score排序等操作。
针对现有技术存在的缺点,上链路追踪方法的执行可选的基于图4的流程中,继续例如图4所示,以手机应用里控制家中空调打开为例,生成链路的包括S402-S408进程,具体地
S402:手机应用向用户网关发送控制请求;
S404:用户网关收到手机应用请求并向设备网关发送控制请求;
S406:设备网关收到用户网关请求并向空调发出打开制冷指令;
S408:空调接收到设备网关指令并运行指令。
在现有技术中,对于目标链路S402-S408进程中,每个进程生成一个ID,将ID串联起来生成一个链路的日志信息;完成S402-408进程后,还原ID进而还原链路信息,这一个过程中会出现数据延迟现象。
可选地,在本发明的实施例中,在图4的流程图中,具体的链路追踪方法如图5所示:目标链路包括进程S402、进程S404、进程S406、进程S408;进程S402对应节点2,进程S404对应节点4、进程S406对应节点6、进程S408对应节点8;节点2生成节点状态2和追踪标志2;节点4生成节点状态4和追踪标志4;节点6生成节点状态6和追踪标志6;节点8生成节点状态8和追踪标志8。
具体地:节点2发向节点4发送操作指令2后,生成节点2的追踪标志2和节点状态2;节点4接收业务请求2后生成追踪标志4,在节点4完成操作指令2的情况下生成节点状态4并向节点6发送业务指令4;节点6接收业务请求4后生成追踪标志6,在节点6完成操作指令4的情况下生成节点状态6并向节点8发送业务指令6;节点8接收业务请求6后生成追踪标志8,在节点8完成操作指令6的情况下生成节点状态8。
综上,上述数据处理方法的执行实现了以下效果:通过查看链路中各个节点对应的节点状态,可以在指定链路范围内查询某个业务完成的情况。
需要说明的是,在实际业务中,每个链路对应多个进程,每个进程对应至少一个链路。
提供一种实施例,当链路对应的进程还包括至少一个线程的情况时,即一个进程对应的父节点对应多个子节点,子节点对应的线程为父节点对应的进程。具体地;链路生成节点信息和节点状态包括:
在节点为父节点且连接至少两个子节点的情况下,将父节点的追踪标志和父节点的节点状态存储到目标操作业务的操作进程对应的调用记录中,并将父节点连接的至少两个子节点的节点状态存储到目标操作业务的操作进程对应的调用记录中。
可选地,在生成调用记录之前,还包括:获取为至少两个子节点中每个子节点各自配置的追踪权重;将每个子节点各自配置的追踪权重存储到与子节点的节点状态关联的调用记录中。
可选地,在本实施例中,如图6所示,检测出节点状态异常的方法包括:
S602:遍历各个节点,直至定位出全部的目标节点;
S604:在当前节点为父节点的情况下,获取当前节点的节点状态;
S606:在当前节点的节点状态指示已完成操作指令所指示的操作的情况下,获取下一个节点;
S608:在当前节点的节点状态指示并未完成操作指令所指示的操作的情况下,获取当前节点连接的至少两个子节点的节点状态;在至少两个子节点中的至少一个子节点的节点状态指示未完成操作的情况下,确定至少一个子节点为目标节点。
可选地,在生成追踪标志和节点状态后,还包括在父节点状态显示业务完成状态的情况下,将追踪标志和业务状态转换得到字符串存储到调用链路的每个进程每个线程的调用记录中,生成保护追踪标志和节点状态的日志。可选地,日志可以为流水日志、内核日志、性能追踪日志的一种。
可选体,在一种实施例中,以S406进程为例;设备网关收到用户网关请求并向空调发出打开制冷指令包括S702-S706进程;其中,设备网关包括:发射网关、感应器、显示器。S702-S706具体包括:
S702:发射网关接收到用户网关指令,向空调发射蓝牙信息或红外信息;
S704:感应器接收到用户网关指令后,发出响应,所述响应用于表示设备网关已经接收用户网关请求;
S706:显示器,接收到用户网关指令后,显示信息;
在实施例中,如图7所示,S406进程对应的是父节点6;S702线程对应子节点62,子节点62对应节点状态62和追踪标志62;S704线程对应子节点64,子节点64对应节点状态64和追踪标志64;S706线程对应的子节点66,子节点66对应节点状态66和追踪标志66。
可选地,在接收到操作指令后,子节点62生成追踪标志62;子节点64生成追踪标志64;子节点67生成追踪标志67;根据子节点完成任务的情况下,子节点62生成节点状态62、子节点64生成节点状态64、子节点66生成节点状态66。
在一种实施例中,父节点6节点状态异常,根据子节点优先级对子节点62、子节点64、子节点66依次排查;子节点优先级储存在子节点优先级表中,优先级根据子节点对下一节点的必要性排序,子节点优先级与节点权重正相关。
在一种实施例中,在子节点62、子节点64、子节点66完成任务的情况下,父节点6生成节点状态。在父节点记录调用记录的过程中,子节点按照追踪权重存储到节点状态中。
根据本发明实施例的另一个方面,还提供了一种用于实施上述链路追踪方法的链路追踪装置。如图8所示,该装置包括:
接收单元802,用于接收操作指令;
处理单元804:用于根据操作指令生成与操作指令对应节点的追踪标志和节点状态,其中追踪标志用于标志节点在目标链路的时序位置,节点状态用于指示节点执行操作指令所指示的操作的进度情况;
生成单元806:用于在节点状态指示已完成操作指令所指示的操作的情况下,将追踪标志和业务完成状态生成链路的生成日志;
报错单元808:用于测节点状态的完成情况,在检测到目标操作业务出现异常的情况下,根据各个节点各自对应的节点状态,追踪定位出目标节点,其中,目标节点为目标操作业务出现异常时的故障节点。
可选地,在本实施例中,上述链路追踪装置可以但不限于应用追踪链路执行操作业务情况的场景,具体地获取在实现目标操作业务的目标链路中的各个节点接收操作指令的情况下,在各个节点中生成各自对应的追踪标志及节点状态;在检测到目标操作业务出现异常的情况下,根据各个节点各自对应的状态追踪定位至目标节点,其中目标节点未出现异常的故障节点。同时,还可以根据该链路追踪方法,显示目标链路实现目标操作业务时,各个节点完成操作指令的时间,并根据各个节点完成操作指令的时间反馈各节点完成操作指令的效率,从而评估链路设计的合理性。
在现有链路追踪技术中,是链路中的各个节点在每个用户请求到来的时候都输出相应的日志,在链路的起点为每个请求生成一个全局唯一的请求ID,根据请求ID串联起每个节点日志,还原调用链路是需要每隔一段时间,收集这段时间各个节点的日志,再根据请求ID还原调用电路。这样的还原调用电路的过程,往往与实际进程存在有时间差,不能很好地反映实时电路状态。可选地,本发明提供一种链路追踪方法,可以实现展现计算机控制状态,并不受控制链路信息的完整性限制。
具体实施例可以参考上述数据处理方法中所示示例,本示例中在此不再赘述。
根据本发明实施例的又一个方面,还提供了一种用于实施上述链路追踪方法的电子装置,如图9所示,该电子装置包括存储器902和处理器904,该存储器902中存储有计算机程序,该处理器904被设置为通过计算机程序执行上述任一项方法实施例中的步骤。
可选地,在本实施例中,上述电子装置可以位于计算机网络的多个网络设备中的至少一个网络设备。
可选地,在本实施例中,上述处理器可以被设置为通过计算机程序执行以下步骤:
S1,在用于实现目标操作业务的目标链路中的各个节点接收到操作指令的情况下,在各个节点中生成各自对应的追踪标志及节点状态,其中,追踪标志用于标志节点在目标链路中的时序位置,节点状态用于指示节点执行操作指令所指示的操作的进度情况;
S2,在检测到目标操作业务出现异常的情况下,根据各个节点各自对应的节点状态,追踪定位出目标节点,其中,目标节点为目标操作业务出现异常时的故障节点。
可选地,本领域普通技术人员可以理解,图9所示的结构仅为示意,电子装置也可以是智能手机(如Android手机、iOS手机等)、平板电脑、掌上电脑以及移动互联网设备(Mobile Internet Devices,MID)、PAD等终端设备。图9其并不对上述电子装置的结构造成限定。例如,电子装置还可包括比图9中所示更多或者更少的组件(如网络接口等),或者具有与图9所示不同的配置。
其中,存储器902可用于存储软件程序以及单元,如本发明实施例中的数据处理方法和装置对应的程序指令/单元,处理器904通过运行存储在存储器902内的软件程序以及单元,从而执行各种功能应用以及链路追踪处理,即实现上述的链路追踪方法。存储器902可包括高速随机存储器,还可以包括非易失性存储器,如一个或者多个磁性存储装置、闪存、或者其他非易失性固态存储器。在一些实例中,存储器902可进一步包括相对于处理器904远程设置的存储器,这些远程存储器可以通过网络连接至终端。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。其中,存储器902具体可以但不限于用于存储目标状态数据、存储状态数据以及目标上报时间戳等信息。作为一种示例,如图9所示,上述存储器902中可以但不限于包括上述数据处理装置中的接收单元802、处理单元804、生成单元806及报错单元808。此外,还可以包括但不限于上述数据处理装置中的其他单元,本示例中不再赘述。
可选地,上述的传输装置906用于经由一个网络接收或者发送数据。上述的网络具体实例可包括有线网络及无线网络。在一个实例中,传输装置906包括一个网络适配器(Network Interface Controller,NIC),其可通过网线与其他网络设备与路由器相连从而可与互联网或局域网进行通讯。在一个实例中,传输装置906为射频(Radio Frequency,RF)单元,其用于通过无线方式与互联网进行通讯。
此外,上述电子装置还包括:显示器908,用于显示上述目标状态数据、存储状态数据以及目标上报时间戳等信息;和连接总线910,用于连接上述电子装置中的各个单元部件。
根据本发明的实施例的又一方面,还提供了一种计算机可读的存储介质,该计算机可读的存储介质中存储有计算机程序,其中,该计算机程序被设置为运行时执行上述任一项方法实施例中的步骤。
可选地,在本实施例中,上述计算机可读的存储介质可以被设置为存储用于执行以下步骤的计算机程序:
S1,在用于实现目标操作业务的目标链路中的各个节点接收到操作指令的情况下,在各个节点中生成各自对应的追踪标志及节点状态,其中,追踪标志用于标志节点在目标链路中的时序位置,节点状态用于指示节点执行操作指令所指示的操作的进度情况;
S2在检测到目标操作业务出现异常的情况下,根据各个节点各自对应的节点状态,追踪定位出目标节点,其中,目标节点为目标操作业务出现异常时的故障节点。
可选地,在本实施例中,本领域普通技术人员可以理解上述实施例的各种方法中的全部或部分步骤是可以通过程序来指令终端设备相关的硬件来完成,该程序可以存储于一计算机可读存储介质中,存储介质可以包括:闪存盘、只读存储器(Read-Only Memory,ROM)、随机存取器(Random Access Memory,RAM)、磁盘或光盘等。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
上述实施例中的集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在上述计算机可读取的存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在存储介质中,包括若干指令用以使得一台或多台计算机设备(可为个人计算机、服务器或者网络设备等)执行本发明各个实施例方法的全部或部分步骤。
在本发明的上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述的部分,可以参见其他实施例的相关描述。
在本申请所提供的几个实施例中,应该理解到,所揭露的客户端,可通过其它的方式实现。其中,以上所描述的装置实施例仅仅是示意性的,例如单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,单元或单元的间接耦合或通信连接,可以是电性或其它的形式。
作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。
以上上述仅是本发明的优选实施方式,应当指出,对于本技术领域的普通技术人员来说,在不脱离本发明原理的前提下,还可以做出若干改进和润饰,这些改进和润饰也应视为本发明的保护范围。
Claims (10)
1.一种链路追踪方法,其特征在于,包括:
在用于实现目标操作业务的目标链路中的各个节点接收到操作指令的情况下,在所述各个节点中生成各自对应的追踪标志及节点状态,其中,所述追踪标志用于标志所述节点在所述目标链路中的时序位置,所述节点状态用于指示所述节点执行所述操作指令所指示的操作的进度情况;
在检测到所述目标操作业务出现异常的情况下,根据所述各个节点各自对应的节点状态,追踪定位出目标节点,其中,所述目标节点为所述目标操作业务出现异常时的故障节点。
2.根据权利要求1所述的方法,其特征在于,所述在所述各个节点中生成各自对应的追踪标志及节点状态之后,还包括:
在所述节点为父节点且连接至少两个子节点的情况下,将所述父节点的追踪标志和所述父节点的节点状态存储到所述目标操作业务的操作进程对应的调用记录中,并将所述父节点连接的所述至少两个子节点的节点状态存储到所述目标操作业务的操作进程对应的所述调用记录中。
3.根据权利要求2所述的方法,其特征在于,所述将所述父节点连接的所述至少两个子节点的节点状态存储到所述目标操作业务的操作进程对应的所述调用记录中包括:
获取为所述至少两个子节点中每个子节点各自配置的追踪权重;
将所述每个子节点各自配置的所述追踪权重存储到与所述子节点的节点状态关联的所述调用记录中。
4.根据权利要求1所述的方法,其特征在于,所述根据所述各个节点各自对应的节点状态,追踪定位出目标节点包括:
遍历所述各个节点,直至定位出全部的所述目标节点:
在当前节点为父节点的情况下,获取所述当前节点的节点状态;
在所述当前节点的节点状态指示已完成所述操作指令所指示的操作的情况下,获取下一个节点;
在所述当前节点的节点状态指示并未完成所述操作指令所指示的操作的情况下,获取所述当前节点连接的至少两个子节点的节点状态;在所述至少两个子节点中的至少一个子节点的节点状态指示未完成操作的情况下,确定所述至少一个子节点为所述目标节点。
5.根据权利要求4所述的方法,其特征在于,所述确定所述至少一个子节点为所述目标节点包括:
在所述当前节点的节点状态指示并未完成所述操作指令所指示的操作的情况下,获取所述当前节点连接的至少两个子节点各自的优先级,其中,所述子节点的优先级与所述子节点各自配置的追踪权重正相关;
根据所述至少两个子节点各自的优先级,依次获取到所述至少两个子节点中每个子节点的节点状态;
根据所述至少两个子节点中每个子节点的节点状态排查所述目标操作业务出现异常的情况;
在所述两个子节点中的至少一个子节点的节点状态指示未完成操作的情况下,确定所述至少一个子节点为所述目标节点。
6.根据权利要求1所述的方法,其特征在于,在根据所述各个节点各自对应的节点状态,追踪定位出目标节点之后,还包括:
在父节点状态显示业务完成状态的情况下,将所述追踪标志和业务状态转换得到字符串存储到所述调用链路的每个进程每个线程的调用记录中,生成保护所述追踪标志和所述节点状态的日志信息。
7.根据权利要求1所述的方法,其特征在于,在所述节点状态指示已完成所述操作指令所指示的操作的情况下,所述节点状态还用于记录每个所述节点完成所述操作指令的时长,根据所述完成所述节点的时长判断所述节点在所述目标链路中完成操作指令的效率。
8.一种链路追踪装置,采用所述权利要求1至7任一项所述的方法,其特征在于,所述装置包括:
接收单元,用于接收操作指令;
处理单元,用于根据所述操作指令生成与所述操作指令对应节点的追踪标志和节点状态,其中所述追踪标志用于标志所述节点在目标链路的时序位置,所述节点状态用于指示所述节点执行所述操作指令所指示的操作的进度情况;
生成单元,用于在所述节点状态指示已完成所述操作指令所指示的操作的情况下,将追踪标志和业务完成状态生成链路的生成日志;
报错单元,用于检测所述节点状态的完成情况,在检测到所述目标操作业务出现异常的情况下,根据所述各个节点各自对应的节点状态,追踪定位出目标节点,其中,所述目标节点为所述目标操作业务出现异常时的故障节点。
9.一种存储介质,其特征在于,所述存储介质中存储有计算机程序,其中,所述计算机程序被设置为运行时执行所述权利要求1至7任一项中所述的方法。
10.一种电子装置,包括存储器和处理器,其特征在于,所述存储器中存储有计算机程序,所述处理器被设置为运行所述计算机程序以执行所述权利要求1至7任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011640642.XA CN112737856B (zh) | 2020-12-31 | 2020-12-31 | 链路追踪方法和装置、存储介质及电子装置 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202011640642.XA CN112737856B (zh) | 2020-12-31 | 2020-12-31 | 链路追踪方法和装置、存储介质及电子装置 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN112737856A true CN112737856A (zh) | 2021-04-30 |
CN112737856B CN112737856B (zh) | 2023-02-03 |
Family
ID=75609060
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202011640642.XA Active CN112737856B (zh) | 2020-12-31 | 2020-12-31 | 链路追踪方法和装置、存储介质及电子装置 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112737856B (zh) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113238923A (zh) * | 2021-07-12 | 2021-08-10 | 深圳市永达电子信息股份有限公司 | 基于状态机的业务行为溯源方法及系统 |
CN114760188A (zh) * | 2022-03-04 | 2022-07-15 | 青岛海尔科技有限公司 | 异常节点的确定方法及装置 |
CN115001952A (zh) * | 2022-05-25 | 2022-09-02 | 中移互联网有限公司 | 一种业务接口的故障定位方法及装置 |
Citations (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106301948A (zh) * | 2016-08-31 | 2017-01-04 | 北京奇艺世纪科技有限公司 | 一种消息流转可视化及监控方法和系统 |
CN107016068A (zh) * | 2017-03-21 | 2017-08-04 | 深圳前海乘方互联网金融服务有限公司 | 知识图谱构建方法及装置 |
CN108833184A (zh) * | 2018-06-29 | 2018-11-16 | 腾讯科技(深圳)有限公司 | 服务故障定位方法、装置、计算机设备及存储介质 |
CN109104302A (zh) * | 2018-07-18 | 2018-12-28 | 杭州鑫合汇互联网金融服务有限公司 | 一种全链路追踪监控方法 |
CN109359094A (zh) * | 2018-08-03 | 2019-02-19 | 挖财网络技术有限公司 | 一种分布式系统日志全链路追踪方法及装置 |
CN109560993A (zh) * | 2018-12-20 | 2019-04-02 | 航天信息股份有限公司 | 通讯链路异常检测的方法,装置,电子设备及网络 |
CN109802854A (zh) * | 2018-12-14 | 2019-05-24 | 平安普惠企业管理有限公司 | 跟踪网络请求的方法、装置、计算机设备和存储介质 |
CN109873717A (zh) * | 2019-01-18 | 2019-06-11 | 深圳壹账通智能科技有限公司 | 监控方法、装置、计算机设备及存储介质 |
CN110245154A (zh) * | 2019-05-20 | 2019-09-17 | 平安科技(深圳)有限公司 | 多路链接异常处理方法以及相关设备 |
CN110457190A (zh) * | 2019-07-09 | 2019-11-15 | 优估(上海)信息科技有限公司 | 一种基于区块链的全链路监控方法、装置及系统 |
CN110677304A (zh) * | 2019-10-11 | 2020-01-10 | 广州趣丸网络科技有限公司 | 一种分布式问题追踪系统及设备 |
CN111259275A (zh) * | 2018-12-03 | 2020-06-09 | 阿里巴巴集团控股有限公司 | 一种数据追踪方法、设备及存储介质 |
CN111338901A (zh) * | 2020-02-26 | 2020-06-26 | 平安壹钱包电子商务有限公司 | 一种Redis监控方法、Redis监控装置及终端 |
-
2020
- 2020-12-31 CN CN202011640642.XA patent/CN112737856B/zh active Active
Patent Citations (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106301948A (zh) * | 2016-08-31 | 2017-01-04 | 北京奇艺世纪科技有限公司 | 一种消息流转可视化及监控方法和系统 |
CN107016068A (zh) * | 2017-03-21 | 2017-08-04 | 深圳前海乘方互联网金融服务有限公司 | 知识图谱构建方法及装置 |
CN108833184A (zh) * | 2018-06-29 | 2018-11-16 | 腾讯科技(深圳)有限公司 | 服务故障定位方法、装置、计算机设备及存储介质 |
CN109104302A (zh) * | 2018-07-18 | 2018-12-28 | 杭州鑫合汇互联网金融服务有限公司 | 一种全链路追踪监控方法 |
CN109359094A (zh) * | 2018-08-03 | 2019-02-19 | 挖财网络技术有限公司 | 一种分布式系统日志全链路追踪方法及装置 |
CN111259275A (zh) * | 2018-12-03 | 2020-06-09 | 阿里巴巴集团控股有限公司 | 一种数据追踪方法、设备及存储介质 |
CN109802854A (zh) * | 2018-12-14 | 2019-05-24 | 平安普惠企业管理有限公司 | 跟踪网络请求的方法、装置、计算机设备和存储介质 |
CN109560993A (zh) * | 2018-12-20 | 2019-04-02 | 航天信息股份有限公司 | 通讯链路异常检测的方法,装置,电子设备及网络 |
CN109873717A (zh) * | 2019-01-18 | 2019-06-11 | 深圳壹账通智能科技有限公司 | 监控方法、装置、计算机设备及存储介质 |
CN110245154A (zh) * | 2019-05-20 | 2019-09-17 | 平安科技(深圳)有限公司 | 多路链接异常处理方法以及相关设备 |
CN110457190A (zh) * | 2019-07-09 | 2019-11-15 | 优估(上海)信息科技有限公司 | 一种基于区块链的全链路监控方法、装置及系统 |
CN110677304A (zh) * | 2019-10-11 | 2020-01-10 | 广州趣丸网络科技有限公司 | 一种分布式问题追踪系统及设备 |
CN111338901A (zh) * | 2020-02-26 | 2020-06-26 | 平安壹钱包电子商务有限公司 | 一种Redis监控方法、Redis监控装置及终端 |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN113238923A (zh) * | 2021-07-12 | 2021-08-10 | 深圳市永达电子信息股份有限公司 | 基于状态机的业务行为溯源方法及系统 |
CN113238923B (zh) * | 2021-07-12 | 2021-10-22 | 深圳市永达电子信息股份有限公司 | 基于状态机的业务行为溯源方法及系统 |
CN114760188A (zh) * | 2022-03-04 | 2022-07-15 | 青岛海尔科技有限公司 | 异常节点的确定方法及装置 |
CN114760188B (zh) * | 2022-03-04 | 2024-01-23 | 青岛海尔科技有限公司 | 异常节点的确定方法及装置 |
CN115001952A (zh) * | 2022-05-25 | 2022-09-02 | 中移互联网有限公司 | 一种业务接口的故障定位方法及装置 |
CN115001952B (zh) * | 2022-05-25 | 2023-09-19 | 中移互联网有限公司 | 一种业务接口的故障定位方法及装置 |
Also Published As
Publication number | Publication date |
---|---|
CN112737856B (zh) | 2023-02-03 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN112737856B (zh) | 链路追踪方法和装置、存储介质及电子装置 | |
CN111831548B (zh) | 一种依赖关系拓扑图的绘制方法和装置 | |
CN106843957A (zh) | 系统固件升级方法及装置 | |
CN111600746B (zh) | 网络故障定位方法、装置及设备 | |
CN110287696B (zh) | 一种反弹shell进程的检测方法、装置和设备 | |
CN105187230B (zh) | 服务器的切换方法及装置 | |
US9104565B2 (en) | Fault tracing system and method for remote maintenance | |
CN112737800A (zh) | 服务节点故障定位方法、调用链生成方法及服务器 | |
CN113672441B (zh) | 对智能设备的测试方法及装置 | |
CN110784515A (zh) | 基于分布式集群的数据存储方法、及其相关设备 | |
CN108733698A (zh) | 一种日志消息的处理方法及后台服务系统 | |
CN105573872B (zh) | 数据存储系统的硬盘维护方法和装置 | |
CN108376110A (zh) | 一种自动检测方法、系统及终端设备 | |
CN114564297A (zh) | 一种任务执行顺序计算方法、装置、设备及可读存储介质 | |
CN109150587B (zh) | 一种维护方法和装置 | |
CN108737487B (zh) | 数据同步方法和装置、存储介质及电子装置 | |
CN108833961B (zh) | 获取飞行记录数据的方法、服务器和系统 | |
CN110198227B (zh) | 日志文件的处理方法、装置、存储介质及电子装置 | |
CN108540582A (zh) | 一种终端标识的处理方法、服务器及终端 | |
CN112600703B (zh) | 网络设备远程访问故障定位方法及装置 | |
CN114244686B (zh) | 通讯故障的检测方法、装置及系统 | |
CN109002253A (zh) | 一种损坏条带的处理方法及装置 | |
CN108647139B (zh) | 系统的测试方法、装置、存储介质及电子装置 | |
CN106452905A (zh) | 消息处理方法和装置 | |
CN109828910A (zh) | monkey测试的方法及装置、计算机设备、存储介质 |
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 |