CN110489315B - 一种操作请求的跟踪方法、跟踪装置及服务器 - Google Patents
一种操作请求的跟踪方法、跟踪装置及服务器 Download PDFInfo
- Publication number
- CN110489315B CN110489315B CN201910649631.9A CN201910649631A CN110489315B CN 110489315 B CN110489315 B CN 110489315B CN 201910649631 A CN201910649631 A CN 201910649631A CN 110489315 B CN110489315 B CN 110489315B
- Authority
- CN
- China
- Prior art keywords
- operation request
- identifier
- request
- server
- log
- 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
- 238000000034 method Methods 0.000 title claims abstract description 36
- 238000004590 computer program Methods 0.000 claims description 21
- 238000004458 analytical method Methods 0.000 claims description 9
- 230000000977 initiatory effect Effects 0.000 claims description 2
- 238000012986 modification Methods 0.000 claims description 2
- 230000004048 modification Effects 0.000 claims description 2
- 238000012545 processing Methods 0.000 description 4
- 230000008878 coupling Effects 0.000 description 3
- 238000010168 coupling process Methods 0.000 description 3
- 238000005859 coupling reaction Methods 0.000 description 3
- 238000005516 engineering process Methods 0.000 description 3
- 238000012546 transfer Methods 0.000 description 3
- 230000001960 triggered effect Effects 0.000 description 3
- 238000004891 communication Methods 0.000 description 2
- 238000010586 diagram Methods 0.000 description 2
- 230000006870 function Effects 0.000 description 2
- 238000012552 review Methods 0.000 description 2
- 238000013459 approach Methods 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000003247 decreasing effect Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 235000019800 disodium phosphate Nutrition 0.000 description 1
- 238000001914 filtration Methods 0.000 description 1
- 239000003999 initiator Substances 0.000 description 1
- 238000013507 mapping Methods 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 238000007639 printing Methods 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/34—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
- G06F11/3438—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment monitoring of user actions
-
- Y—GENERAL 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
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Hardware Design (AREA)
- Quality & Reliability (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Debugging And Monitoring (AREA)
Abstract
本申请公开了一种操作请求的跟踪方法、跟踪装置及服务器,其中,该操作请求的跟踪方法包括:第一服务器拦截向其发起的第一操作请求;若第一操作请求中未携带操作标识,则为第一操作请求生成具有唯一性的操作标识;若第一操作请求中携带操作标识,则解析获得第一操作请求的操作标识;将生成或解析得到的操作标识存储于第一应用的全局存储对象中;当第一服务器需要向第二服务器发起第二操作请求时,将操作标识放入第二操作请求中,再向第二服务器发起第二操作请求;记录操作请求日志时,从全局存储对象中解析出操作标识,并将操作标识写入操作请求日志中。通过本申请方案,实现对用户发起的操作的追踪,以及时定位操作在执行过程中可能出现的问题。
Description
技术领域
本申请属于信息管理技术领域,尤其涉及操作请求的跟踪方法、操作请求的跟踪装置、服务器及计算机可读存储介质。
背景技术
目前针对用户在前台所发起的各项操作,往往采用log4j日志系统中的映射调试上下文(Mapped Diagnostic Context,MDC)对象进行存储,或者采用开源的第三方jar包进行存储。然而,上述两种方式均难以实现操作标识在不同线程之间的传递,这将导致后续无法在日志中对各个操作进行准确的定位及跟踪。
发明内容
有鉴于此,本申请提供了一种操作请求的跟踪方法、操作请求的跟踪装置、服务器及计算机可读存储介质,可实现在日志中对各个操作的准确定位及跟踪。
本申请的第一方面提供了一种操作请求的跟踪方法,包括:
第一服务器拦截向上述第一服务器发起的第一操作请求,上述第一操作请求向上述第一服务器请求第一应用;
若上述第一操作请求中未携带操作标识,则为上述第一操作请求生成具有唯一性的操作标识,并将上述操作标识存储于上述第一应用的全局存储对象中;
若上述第一操作请求中携带操作标识,则对上述第一操作请求进行解析,以获得上述第一操作请求的上述操作标识,并将上述操作标识存储于上述第一应用的全局存储对象中;
当上述第一服务器需要向第二服务器发起第二操作请求时,将上述操作标识放入上述第二操作请求的报文或HTTP请求头中,然后向上述第二服务器发起上述第二操作请求,上述第二操作请求向上述第二服务器请求第二应用;
记录操作请求日志时,从上述全局存储对象中解析出上述操作标识,并将上述操作标识写入上述操作请求日志中。
本申请的第二方面提供了一种操作请求的跟踪装置,上述操作请求的跟踪装置应用于第一服务器,包括:
拦截模块,用于拦截向上述第一服务器发起的第一操作请求,上述第一操作请求向上述第一服务器请求第一应用;
生成模块,用于若上述第一操作请求中未携带操作标识,则为上述第一操作请求生成具有唯一性的操作标识;
解析模块,用于若上述第一操作请求中携带操作标识,则对上述第一操作请求进行解析,以获得上述第一操作请求的上述操作标识;
存储模块,用于将生成模块生成得到的上述操作标识或者解析模块解析得到的上述操作标识存储于上述第一应用的全局存储对象中;
调用模块,用于当上述第一服务器需要向第二服务器发起第二操作请求时,将上述操作标识放入上述第二操作请求的报文或HTTP请求头中,然后向上述第二服务器发起上述第二操作请求,上述第二操作请求向上述第二服务器请求第二应用;
记录模块,用于在记录操作请求日志时,从上述全局存储对象中解析出上述操作标识,并将上述操作标识写入上述操作请求日志中。
本申请的第三方面提供了一种服务器,上述服务器包括存储器、处理器以及存储在上述存储器中并可在上述处理器上运行的计算机程序,上述处理器执行上述计算机程序时实现如上述第一方面的方法的步骤。
本申请的第四方面提供了一种计算机可读存储介质,上述计算机可读存储介质存储有计算机程序,上述计算机程序被处理器执行时实现如上述第一方面的方法的步骤。
本申请的第五方面提供了一种计算机程序产品,上述计算机程序产品包括计算机程序,上述计算机程序被一个或多个处理器执行时实现如上述第一方面的方法的步骤。
由上可见,在本申请方案中,第一服务器首先拦截向上述第一服务器发起的第一操作请求,上述第一操作请求向上述第一服务器请求第一应用,若上述第一操作请求中未携带操作标识,则为上述第一操作请求生成具有唯一性的操作标识,并将上述操作标识存储于上述第一应用的全局存储对象中,若上述第一操作请求中携带操作标识,则对上述第一操作请求进行解析,以获得上述第一操作请求的上述操作标识,并将上述操作标识存储于上述第一应用的全局存储对象中,当上述第一服务器需要向第二服务器发起第二操作请求时,将上述操作标识放入上述第二操作请求的报文或HTTP请求头中,然后向上述第二服务器发起上述第二操作请求,上述第二操作请求向上述第二服务器请求第二应用,最后在记录操作请求日志时,从上述全局存储对象中解析出上述操作标识,并将上述操作标识写入上述操作请求日志中。通过本申请方案,可根据前台用户所发起的操作生成相应的操作标识,并将该操作标志存储于全局存储对象中,使得该操作标识可以在父线程与子线程以及线程池中进行传递;其次,当用户所发起请求需要由多个服务器协调完成时,通过在先服务器在操作请求中插入上述相应的操作标识,使得该操作标识可以在不同服务器中进行传递;进一步地,操作请求日志中可以基于该操作标识检索得到相关日志信息,以实现对相应操作的定位及追踪。
附图说明
为了更清楚地说明本申请实施例中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1是本申请实施例提供的操作请求的跟踪方法的实现流程示意图;
图2是本申请实施例提供的操作请求的跟踪装置的结构框图;
图3是本申请实施例提供的服务器的示意图。
具体实施方式
以下描述中,为了说明而不是为了限定,提出了诸如特定系统结构、技术之类的具体细节,以便透彻理解本申请实施例。然而,本领域的技术人员应当清楚,在没有这些具体细节的其它实施例中也可以实现本申请。在其它情况中,省略对众所周知的系统、装置、电路以及方法的详细说明,以免不必要的细节妨碍本申请的描述。
为了说明本申请上述的技术方案,下面通过具体实施例来进行说明。
实施例一
下面对本申请实施例提供的一种操作请求的跟踪方法进行描述,请参阅图1,本申请实施例中的操作请求的跟踪方法包括:
在步骤101中,第一服务器拦截向上述第一服务器发起的第一操作请求;
在本申请实施例中,用户可以在客户端的前台所显示的界面中通过点击、双击、滑动或文字输入等各种方式,向后台的服务器请求对应应用,以触发该应用执行该请求对应的操作;或者,考虑到某些复杂的操作需要两个以上的应用协作完成,因而,其它服务器也可以向上述第一服务器发起第一操作请求,此处不对上述第一操作请求的发起者作出具体限定。具体地,上述第一操作请求用于向上述第一服务器请求第一应用,可以认为,在实际应用中,根据上述第一操作请求的作用,上述后台的任一服务器均可作为第一服务器来执行本步骤及后续步骤的操作。可选地,上述第一服务器可以预先声明一过滤器,该过滤器的作用是过滤外部请求调用,并且解析请求报文。上述第一服务器可以通过调用上述预先声明的过滤器对该第一操作请求进行拦截,并对拦截得到的上述第一操作请求中是否携带有操作标识进行检测。其中,上述操作标识指示了上述第一操作请求所请求的操作,每一操作都唯一的对应有一操作标识。通常来说,针对未携带有操作标识的操作请求,在日志中对该操作请求所对应的操作进行记录时,可能会与其他各个操作发生混淆的情况,这将不利于后续对该操作请求进行定位及追踪,基于此,在第一服务器响应所接收到的第一操作请求之前,可以先检测上述第一操作请求中是否携带有操作标识。
在步骤102中,若上述第一操作请求中未携带操作标识,则为上述第一操作请求生成具有唯一性的操作标识,并将上述操作标识存储于上述第一应用的全局存储对象中;
在本申请实施例中,当第一服务器所调用的过滤器检测到上述第一操作请求中未携带有操作标识时,服务器随即可以基于上述第一操作请求生成相应的操作标识,所生成的上述操作标识具有唯一性,可以唯一的表示上述第一操作请求。可选地,上述操作标识可以是由第一服务器所随机生成的一串字符串,在本申请实施例中,不对上述操作标识的生成过程及结构做出具体限定。需要注意的是,针对不同操作请求所发起的请求报文,其所对应生成的操作标识也不同,例如,若第一操作请求为触发A应用执行A1操作,则所对应生成的操作标识可以是aaaa,若第一操作请求为触发B应用执行B1操作,则所对应生成的操作标识可以是bbbb,也即是说,操作请求与操作标识之间呈一一对应的关系,每一操作标识可以唯一的表示一个操作请求。
而在存储操作标识时,具体可以采用第三方所提供的jar包实现操作标识的全局存储,例如,可以基于alibaba所提出的TransmittableThreadLocal技术设计上述全局存储对象,具体地,上述TransmittableThreadLocal技术是一种开源的、用于解决“在使用线程池等会缓存线程的组件情况下传递ThreadLocal”问题的InheritableThreadLocal的扩展,通过这一技术,可以使得父线程所创建的所有任务(也即子线程)都可以获得父线程中ThreadLocal中的值,且该过程不受其他任务的影响,这样一来,将上述操作标识存储于上述第一应用的全局存储对象中之后,即可实现该操作标识在当前线程和子线程以及线程池之间传递。
在步骤103中,若上述第一操作请求中携带操作标识,则对上述第一操作请求进行解析,以获得上述第一操作请求的上述操作标识,并将上述操作标识存储于上述第一应用的全局存储对象中;
在本申请实施例中,若是其它服务器试图通过上述第一操作请求调用上述第一服务器来触发第一应用,则所接收到第一操作请求往往已经经由上述其它服务器插入好了对应的操作标识。基于此,上述第一服务器在通过上述预设的过滤器拦截上述第一操作请求时,可以检测到上述第一操作请求中已携带有操作标识。此时,第一服务器不再需要为该第一操作请求重新生成操作标识,而只需要对上述第一操作请求进行解析,以获得上述第一操作请求所携带的操作标识,并将解析获得的上述操作标识存储于上述第一应用的全局存储对象中即可。上述存储操作标识的过程可参照步骤102,此处不再赘述。
在步骤104中,当上述第一服务器需要向第二服务器发起第二操作请求时,将上述操作标识放入上述第二操作请求的报文或HTTP请求头中,然后向上述第二服务器发起上述第二操作请求;
在本申请实施例中,也可以是由第一服务器调用其它服务器(例如第二服务器)来触发其它应用(例如第二应用)。当存在这一需求时,上述第一服务器可以将上标操作标识插入向上述第二服务器请求第二应用的第二操作请求中,使得上述第二操作请求能够携带对应的操作标识。进一步地,若上述第二操作请求为超文本传输协议(HyperText TransferProtocol,HTTP)请求,则可以选择在该HTTP请求的请求头中插入上述操作标识;若上述第二操作请求为其它类型的请求(也即非HTTP请求),则可以选择在该第二操作请求的报文中插入上述操作标识,此处不作限定。
在步骤105中,记录操作请求日志时,从上述全局存储对象中解析出上述操作标识,并将上述操作标识写入上述操作请求日志中。
在本申请实施例中,由于操作标识已经被存储到了第一服务器中的全局存储对象中,因而,上述第一服务器基于上述第一操作请求所创建的各个线程均可以基于上述全局存储对象进行追踪。基于此,在记录操作请求日志时,可以直接从上述全局存储对象中解析出上述操作标识,并将上述操作标识写入上述操作请求日志中,以方便用户在该操作请求日志中对上述操作标识所对应的操作请求进行定位及追踪。进一步地,本申请实施例还提出了一种操作标识占位符,则在将上述操作标识写入上述操作请求日志中时,可以先在上述操作请求日志中,查询预设的操作标识占位符,再基于上述操作标识对查询得到的各个操作标识占位符进行替换。可选地,上述操作标识符只是定义日志格式的一个符号,其具体的值是研发人员所预先设好的,此处不对其作出限定,例如,可以将上述操作标识占位符设定为%traceId。进一步地,为了实现对上述操作标识占位符的预设,研发人员可以预先定义一日志格式转化器,并以预设的格式声明上述操作标识占位符,随后基于上述操作标志占位符修改日志框架,以使得上述日志能够输出上述操作标识占位符,这样一来,在将上述操作标识写入上述操作请求日志中时,只需通过上述日志格式转化器将查询得到的上述操作请求日志中的各个操作标识占位符替换为上述操作标识即可。
可选地,上述操作请求的跟踪方法还包括:
当上述第一操作请求执行完毕后,确定上述第一操作请求的执行状态,上述执行状态包括执行失败或执行成功;
基于上述执行状态触发前台输出显示有上述操作标识的下拉弹框;
若接收到通过上述下拉弹框输入的基于上述操作标识的操作跟踪请求,则在上述操作请求日志中检索得到与上述操作标识相关的日志信息;
向上述前台发送上述日志信息。
其中,当上述第一操作请求执行完毕后,可以触发前台在其界面上显示一下拉弹框,通过该下拉弹框可以方便用户快速获知第一操作请求的执行状态。例如,假定用户本次所请求的是触发A应用执行A1操作,对应的操作标识为aaaa,则触发前台在其界面中输出下拉弹框,该下拉弹框中可显示上述操作标识aaaa供用户查阅,用户可以进一步点击该aaaa,以向第一服务器输入基于该操作标识“aaaa”的操作跟踪请求,第一服务器接收到上述操作跟踪请求后,可以在上述操作请求日志中检索得到与上述操作标识相关的日志信息,并随后向上述前台发送上述日志信息,供用户进一步查阅。可选地,考虑到用户通常仅在在操作执行失败时才会进一步查阅后台所记录的日志,以定位与本次操作执行失败所相关联的问题,基于此,在本步骤中,还可以同时输出上述执行状态,以使得用户可以及时获知本次第一操作请求是否执行成功,在本次操作执行失败时,用户可以选择通过上述下拉弹框所示出的操作标识来向第一服务器输入操作跟踪请求,以在后台庞大的日志中搜索本次操作相关的日志信息,实现问题的定位及追踪。可选地,考虑到操作请求日志往往是持续对第一服务器所进行的各项操作请求进行记录,因而,为了提高在上述操作请求日志中筛选所需的操作标识符并进行打印的效率,可以在第一服务器执行上述第一操作请求时,记录下执行的开始时刻及结束时刻,随后在该操作请求日志中基于该开始时刻及结束时刻进行操作请求日志的初步截取,并在截取得到的操作请求日志中检索得到与上述操作标识相关联的日志信息。
由上可见,通过本申请实施例,可根据前台用户所发起的操作生成相应的操作标识,并将该操作标志存储于全局存储对象中,使得该操作标识可以在父线程与子线程以及线程池中进行传递;其次,当用户所发起请求需要由多个服务器协调完成时,通过在先服务器在操作请求中插入上述相应的操作标识,使得该操作标识可以在不同服务器中进行传递;进一步地,操作请求日志中可以基于该操作标识检索得到相关日志信息,以实现对相应操作的定位及追踪。
应理解,上述实施例中各步骤的序号的大小并不意味着执行顺序的先后,各过程的执行顺序应以其功能和内在逻辑确定,而不应对本申请实施例的实施过程构成任何限定。
实施例二
本申请实施例二提供了一种操作请求的跟踪装置,上述操作请求的跟踪装置可集成于第一服务器中,如图2所示,本申请实施例中的操作请求的跟踪装置200包括:
拦截模块201,用于拦截向上述第一服务器发起的第一操作请求,上述第一操作请求向上述第一服务器请求第一应用;
生成模块202,用于若上述第一操作请求中未携带操作标识,则为上述第一操作请求生成具有唯一性的操作标识;
解析模块203,用于若上述第一操作请求中携带操作标识,则对上述第一操作请求进行解析,以获得上述第一操作请求的上述操作标识;
存储模块204,用于将生成模块202生成得到的上述操作标识或者解析模块203解析得到的上述操作标识存储于上述第一应用的全局存储对象中;
调用模块205,用于当上述第一服务器需要向第二服务器发起第二操作请求时,将上述操作标识放入上述第二操作请求的报文或HTTP请求头中,然后向上述第二服务器发起上述第二操作请求,上述第二操作请求向上述第二服务器请求第二应用;
记录模块206,用于在记录操作请求日志时,从上述全局存储对象中解析出上述操作标识,并将上述操作标识写入上述操作请求日志中。
可选地,上述记录模块206包括:
占位符查询单元,用于在上述操作请求日志中,查询预设的操作标识占位符;
占位符替换单元,用于基于上述操作标识对查询得到的各个操作标识占位符进行替换。
可选地,上述操作请求的跟踪装置200还包括:
设置模块,用于预先定义日志格式转化器,并以预设的格式声明上述操作标识占位符;
修改模块,用于基于上述操作标志占位符修改上述操作请求日志的框架,以使得上述操作请求日志能够输出上述操作标识占位符;
相应地,上述占位符替换单元,具体用于在上述操作请求日志中,通过上述日志格式转化器将查询得到的各个操作标识占位符替换为上述操作标识。
可选地,上述操作请求的跟踪装置200还包括:
确定模块,用于当上述第一操作请求执行完毕后,确定上述第一操作请求的执行状态,上述执行状态包括执行失败或执行成功;
触发模块,用于基于上述执行状态触发前台输出显示有上述操作标识的下拉弹框;
检索模块,用于若接收到通过上述下拉弹框输入的基于上述操作标识的操作跟踪请求,则在上述操作请求日志中检索得到与上述操作标识相关的日志信息;
发送模块,用于向上述前台发送上述日志信息。
可选地,上述拦截模块201,具体用于调用预设的过滤器拦截向上述第一服务器发起的第一操作请求,并检测拦截的上述第一操作请求中是否携带有操作标识。
由上可见,通过本申请实施例,操作请求的跟踪装置可根据前台用户所发起的操作生成相应的操作标识,并将该操作标志存储于全局存储对象中,使得该操作标识可以在父线程与子线程以及线程池中进行传递;其次,当用户所发起请求需要由多个服务器协调完成时,通过在先服务器在操作请求中插入上述相应的操作标识,使得该操作标识可以在不同服务器中进行传递;进一步地,操作请求日志中可以基于该操作标识检索得到相关日志信息,以实现对相应操作的定位及追踪。
实施例三
本申请实施例三提供了一种服务器,请参阅图3,本申请实施例中的服务器3包括:存储器301,一个或多个处理器302(图3中仅示出一个)及存储在存储器301上并可在处理器上运行的计算机程序。其中:存储器301用于存储软件程序以及模块,处理器302通过运行存储在存储器301的软件程序以及单元,从而执行各种功能应用以及数据处理,以获取上述预设事件对应的资源。具体地,以第一服务器指代上述服务器3,则处理器302通过运行存储在存储器301的上述计算机程序时实现以下步骤:
第一服务器拦截向上述第一服务器发起的第一操作请求,上述第一操作请求向上述第一服务器请求第一应用;
若上述第一操作请求中未携带操作标识,则为上述第一操作请求生成具有唯一性的操作标识,并将上述操作标识存储于上述第一应用的全局存储对象中;
若上述第一操作请求中携带操作标识,则对上述第一操作请求进行解析,以获得上述第一操作请求的上述操作标识,并将上述操作标识存储于上述第一应用的全局存储对象中;
当上述第一服务器需要向第二服务器发起第二操作请求时,将上述操作标识放入上述第二操作请求的报文或HTTP请求头中,然后向上述第二服务器发起上述第二操作请求,上述第二操作请求向上述第二服务器请求第二应用;
记录操作请求日志时,从上述全局存储对象中解析出上述操作标识,并将上述操作标识写入上述操作请求日志中。
假设上述为第一种可能的实施方式,则在第一种可能的实施方式作为基础而提供的第二种可能的实施方式中,上述将上述操作标识写入上述操作请求日志中,包括:
在上述操作请求日志中,查询预设的操作标识占位符;
基于上述操作标识对查询得到的各个操作标识占位符进行替换。
在上述第二种可能的实施方式作为基础而提供的第三种可能的实施方式中,处理器302通过运行存储在存储器301的上述计算机程序时还实现以下步骤:
预先定义日志格式转化器,并以预设的格式声明上述操作标识占位符;
基于上述操作标志占位符修改上述操作请求日志的框架,以使得上述操作请求日志能够输出上述操作标识占位符;
相应地,上述基于上述操作标识对查询得到的各个操作标识占位符进行替换,包括:
在上述操作请求日志中,通过上述日志格式转化器将查询得到的各个操作标识占位符替换为上述操作标识。
在上述第一种可能的实施方式作为基础,或者上述第二种可能的实施方式作为基础,或者上述第三种可能的实施方式作为基础而提供的第四种可能的实施方式中,处理器302通过运行存储在存储器301的上述计算机程序时还实现以下步骤:
当上述第一操作请求执行完毕后,确定上述第一操作请求的执行状态,上述执行状态包括执行失败或执行成功;
基于上述执行状态触发前台输出显示有上述操作标识的下拉弹框;
若接收到通过上述下拉弹框输入的基于上述操作标识的操作跟踪请求,则在上述操作请求日志中检索得到与上述操作标识相关的日志信息;
向上述前台发送上述日志信息。
在上述第一种可能的实施方式作为基础,或者上述第二种可能的实施方式作为基础,或者上述第三种可能的实施方式作为基础而提供的第五种可能的实施方式中,上述第一服务器拦截向上述第一服务器发起的第一操作请求,包括:
上述第一服务器调用预设的过滤器拦截向上述第一服务器发起的第一操作请求,并检测拦截的上述第一操作请求中是否携带有操作标识。
应当理解,在本申请实施例中,所称处理器302可以是中央处理单元(CentralProcessing Unit,CPU),该处理器还可以是其他通用处理器、数字信号处理器(DigitalSignal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
存储器301可以包括只读存储器和随机存取存储器,并向处理器302提供指令和数据。存储器301的一部分或全部还可以包括非易失性随机存取存储器。例如,存储器301还可以存储设备类型的信息。
由上可见,通过本申请实施例,服务器可根据前台用户所发起的操作生成相应的操作标识,并将该操作标志存储于全局存储对象中,使得该操作标识可以在父线程与子线程以及线程池中进行传递;其次,当用户所发起请求需要由多个服务器协调完成时,通过在先服务器在操作请求中插入上述相应的操作标识,使得该操作标识可以在不同服务器中进行传递;进一步地,操作请求日志中可以基于该操作标识检索得到相关日志信息,以实现对相应操作的定位及追踪。
所属领域的技术人员可以清楚地了解到,为了描述的方便和简洁,仅以上述各功能单元、模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能单元、模块完成,即将上述装置的内部结构划分成不同的功能单元或模块,以完成以上描述的全部或者部分功能。实施例中的各功能单元、模块可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中,上述集成的单元既可以采用硬件的形式实现,也可以采用软件功能单元的形式实现。另外,各功能单元、模块的具体名称也只是为了便于相互区分,并不用于限制本申请的保护范围。上述系统中单元、模块的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。
在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述或记载的部分,可以参见其它实施例的相关描述。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、或者外部设备软件和电子硬件的结合来实现。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本申请的范围。
在本申请所提供的实施例中,应该理解到,所揭露的装置和方法,可以通过其它的方式实现。例如,以上所描述的系统实施例仅仅是示意性的,例如,上述模块或单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通讯连接可以是通过一些接口,装置或单元的间接耦合或通讯连接,可以是电性,机械或其它的形式。
上述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。
上述集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读存储介质中。基于这样的理解,本申请实现上述实施例方法中的全部或部分流程,也可以通过计算机程序来指令相关的硬件来完成,上述的计算机程序可存储于一计算机可读存储介质中,该计算机程序在被处理器执行时,可实现上述各个方法实施例的步骤。其中,上述计算机程序包括计算机程序代码,上述计算机程序代码可以为源代码形式、对象代码形式、可执行文件或某些中间形式等。上述计算机可读存储介质可以包括:能够携带上述计算机程序代码的任何实体或装置、记录介质、U盘、移动硬盘、磁碟、光盘、计算机可读存储器、只读存储器(ROM,Read-Only Memory)、随机存取存储器(RAM,Random Access Memory)、电载波信号、电信信号以及软件分发介质等。需要说明的是,上述计算机可读存储介质包含的内容可以根据司法管辖区内立法和专利实践的要求进行适当的增减,例如在某些司法管辖区,根据立法和专利实践,计算机可读存储介质不包括是电载波信号和电信信号。
以上上述实施例仅用以说明本申请的技术方案,而非对其限制;尽管参照前述实施例对本申请进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本申请各实施例技术方案的精神和范围,均应包含在本申请的保护范围之内。
Claims (6)
1.一种操作请求的跟踪方法,其特征在于,包括:
第一服务器拦截向所述第一服务器发起的第一操作请求,所述第一操作请求向所述第一服务器请求第一应用;
若所述第一操作请求中未携带操作标识,则为所述第一操作请求生成具有唯一性的操作标识,并将所述操作标识存储于所述第一应用的全局存储对象中;
若所述第一操作请求中携带操作标识,则对所述第一操作请求进行解析,以获得所述第一操作请求的所述操作标识,并将所述操作标识存储于所述第一应用的全局存储对象中;
当所述第一服务器需要向第二服务器发起第二操作请求时,将所述操作标识放入所述第二操作请求的报文或HTTP请求头中,然后向所述第二服务器发起所述第二操作请求,所述第二操作请求向所述第二服务器请求第二应用;
记录操作请求日志时,从所述全局存储对象中解析出所述操作标识,并将所述操作标识写入所述操作请求日志中;
所述将所述操作标识写入所述操作请求日志中,包括:
在所述操作请求日志中,查询预设的操作标识占位符;
基于所述操作标识对查询得到的各个操作标识占位符进行替换;
所述操作请求的跟踪方法还包括:
预先定义日志格式转化器,并以预设的格式声明所述操作标识占位符;
基于所述操作标识占位符修改所述操作请求日志的框架,以使得所述操作请求日志能够输出所述操作标识占位符;
相应地,所述基于所述操作标识对查询得到的各个操作标识占位符进行替换,包括:
在所述操作请求日志中,通过所述日志格式转化器将查询得到的各个操作标识占位符替换为所述操作标识。
2.如权利要求1所述的操作请求的跟踪方法,其特征在于,所述操作请求的跟踪方法还包括:
当所述第一操作请求执行完毕后,确定所述第一操作请求的执行状态,所述执行状态包括执行失败或执行成功;
基于所述执行状态触发前台输出显示有所述操作标识的下拉弹框;
若接收到通过所述下拉弹框输入的基于所述操作标识的操作跟踪请求,则在所述操作请求日志中检索得到与所述操作标识相关的日志信息;
向所述前台发送所述日志信息。
3.如权利要求1所述的操作请求的跟踪方法,其特征在于,所述第一服务器拦截向所述第一服务器发起的第一操作请求,包括:
所述第一服务器调用预设的过滤器拦截向所述第一服务器发起的第一操作请求,并检测拦截的所述第一操作请求中是否携带有操作标识。
4.一种操作请求的跟踪装置,其特征在于,所述操作请求的跟踪装置应用于第一服务器,包括:
拦截模块,用于拦截向所述第一服务器发起的第一操作请求,所述第一操作请求向所述第一服务器请求第一应用;
生成模块,用于若所述第一操作请求中未携带操作标识,则为所述第一操作请求生成具有唯一性的操作标识;
解析模块,用于若所述第一操作请求中携带操作标识,则对所述第一操作请求进行解析,以获得所述第一操作请求的所述操作标识;
存储模块,用于将生成模块生成得到的所述操作标识或者解析模块解析得到的所述操作标识存储于所述第一应用的全局存储对象中;
调用模块,用于当所述第一服务器需要向第二服务器发起第二操作请求时,将所述操作标识放入所述第二操作请求的报文或HTTP请求头中,然后向所述第二服务器发起所述第二操作请求,所述第二操作请求向所述第二服务器请求第二应用;
记录模块,用于在记录操作请求日志时,从所述全局存储对象中解析出所述操作标识,并将所述操作标识写入所述操作请求日志中;
所述记录模块包括:
占位符查询单元,用于在所述操作请求日志中,查询预设的操作标识占位符;
占位符替换单元,用于基于所述操作标识对查询得到的各个操作标识占位符进行替换;
所述操作请求的跟踪装置还包括:
设置模块,用于预先定义日志格式转化器,并以预设的格式声明所述操作标识占位符;
修改模块,用于基于所述操作标识占位符修改所述操作请求日志的框架,以使得所述操作请求日志能够输出所述操作标识占位符;
相应地,所述占位符替换单元,具体用于在所述操作请求日志中,通过所述日志格式转化器将查询得到的各个操作标识占位符替换为所述操作标识。
5.一种服务器,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,其特征在于,所述处理器执行所述计算机程序时实现如权利要求1至3任一项所述方法的步骤。
6.一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现如权利要求1至3任一项所述方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910649631.9A CN110489315B (zh) | 2019-07-18 | 2019-07-18 | 一种操作请求的跟踪方法、跟踪装置及服务器 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910649631.9A CN110489315B (zh) | 2019-07-18 | 2019-07-18 | 一种操作请求的跟踪方法、跟踪装置及服务器 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN110489315A CN110489315A (zh) | 2019-11-22 |
CN110489315B true CN110489315B (zh) | 2024-01-12 |
Family
ID=68547439
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910649631.9A Active CN110489315B (zh) | 2019-07-18 | 2019-07-18 | 一种操作请求的跟踪方法、跟踪装置及服务器 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110489315B (zh) |
Families Citing this family (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112118286B (zh) * | 2020-08-04 | 2021-08-17 | 紫光云(南京)数字技术有限公司 | 基于mdc多线程链路追踪方法、装置及计算机可读存储介质 |
CN112015663B (zh) * | 2020-09-15 | 2024-03-15 | 平安银行股份有限公司 | 测试数据录制方法、装置、设备及介质 |
CN112286776A (zh) * | 2020-11-04 | 2021-01-29 | 中国电力财务有限公司 | 一种微服务链路追踪的方法及系统 |
CN113434464A (zh) * | 2021-06-24 | 2021-09-24 | 江苏创源电子有限公司 | 一种分布式日志处理系统和方法 |
CN115022410A (zh) * | 2022-05-27 | 2022-09-06 | 北京有竹居网络技术有限公司 | 一种网络请求追踪方法、装置及设备 |
CN116881040A (zh) * | 2023-09-08 | 2023-10-13 | 杭州小电科技股份有限公司 | 一种业务操作处理方法、装置、电子装置和存储介质 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106487596A (zh) * | 2016-10-26 | 2017-03-08 | 宜人恒业科技发展(北京)有限公司 | 分布式服务跟踪实现方法 |
CN108038145A (zh) * | 2017-11-23 | 2018-05-15 | 携程旅游网络技术(上海)有限公司 | 分布式服务跟踪方法、系统、存储介质和电子设备 |
-
2019
- 2019-07-18 CN CN201910649631.9A patent/CN110489315B/zh active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN106487596A (zh) * | 2016-10-26 | 2017-03-08 | 宜人恒业科技发展(北京)有限公司 | 分布式服务跟踪实现方法 |
CN108038145A (zh) * | 2017-11-23 | 2018-05-15 | 携程旅游网络技术(上海)有限公司 | 分布式服务跟踪方法、系统、存储介质和电子设备 |
Non-Patent Citations (1)
Title |
---|
替换String中的占位符标志位{placeholder};佚名;《http://blog.csdn.net/weixin_33695082/article/details/85959283》;20171129;第1-6页 * |
Also Published As
Publication number | Publication date |
---|---|
CN110489315A (zh) | 2019-11-22 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110489315B (zh) | 一种操作请求的跟踪方法、跟踪装置及服务器 | |
CN108459939B (zh) | 一种日志收集方法、装置、终端设备及存储介质 | |
US11792291B1 (en) | Proxying hypertext transfer protocol (HTTP) requests for microservices | |
US11178167B2 (en) | Graphical display suppressing events indicating security threats in an information technology system | |
WO2020233015A1 (zh) | 一种链路跟踪方法及装置 | |
US11803548B1 (en) | Automated generation of metrics from log data | |
EP3537325B1 (en) | Interactive user interfaces | |
CN110650128B (zh) | 一种检测以太坊数字货币盗取攻击的系统及方法 | |
US11775501B2 (en) | Trace and span sampling and analysis for instrumented software | |
US11860717B1 (en) | Graphical user interface for presenting crash data | |
JP2019517040A (ja) | クラウドプラットフォームベースのクライアントアプリケーション情報統計方法および装置 | |
CN107341395B (zh) | 一种拦截爬虫的方法 | |
CN107977473B (zh) | 基于Logback的分布式系统日志的检索方法和系统 | |
US11755531B1 (en) | System and method for storage of data utilizing a persistent queue | |
US10880366B1 (en) | Enabling stateless status checks using collector redirection | |
CN111241125A (zh) | 一种记录操作日志的方法、装置、电子设备和存储介质 | |
CN108228322B (zh) | 一种分布式链路跟踪、分析方法及服务器、全局调度器 | |
US11178160B2 (en) | Detecting and mitigating leaked cloud authorization keys | |
CN115408193A (zh) | 多模块间错误码处理方法及装置 | |
CN110134538B (zh) | 快速定位问题日志的方法、装置、介质和电子设备 | |
US9736215B1 (en) | System and method for correlating end-user experience data and backend-performance data | |
CN112671878B (zh) | 一种区块链的信息订阅方法、装置、服务器和存储介质 | |
CN107330031A (zh) | 一种数据存储的方法、装置及电子设备 | |
CN104317820B (zh) | 报表的统计方法和装置 | |
CN116028479A (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 |