CN113377434A - 命令响应时长的确定方法、装置和存储介质 - Google Patents

命令响应时长的确定方法、装置和存储介质 Download PDF

Info

Publication number
CN113377434A
CN113377434A CN202110640206.0A CN202110640206A CN113377434A CN 113377434 A CN113377434 A CN 113377434A CN 202110640206 A CN202110640206 A CN 202110640206A CN 113377434 A CN113377434 A CN 113377434A
Authority
CN
China
Prior art keywords
command
time information
execution result
network queue
output buffer
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.)
Pending
Application number
CN202110640206.0A
Other languages
English (en)
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.)
Beijing Kingsoft Cloud Network Technology Co Ltd
Original Assignee
Beijing Kingsoft Cloud Network 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 Beijing Kingsoft Cloud Network Technology Co Ltd filed Critical Beijing Kingsoft Cloud Network Technology Co Ltd
Priority to CN202110640206.0A priority Critical patent/CN113377434A/zh
Publication of CN113377434A publication Critical patent/CN113377434A/zh
Pending legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/30Arrangements for executing machine instructions, e.g. instruction decode
    • G06F9/30003Arrangements for executing specific machine instructions
    • G06F9/3004Arrangements for executing specific machine instructions to perform operations on memory
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording 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/3409Recording 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 for performance assessment
    • G06F11/3419Recording 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 for performance assessment by assessing time

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Software Systems (AREA)
  • Computer Hardware Design (AREA)
  • Quality & Reliability (AREA)
  • Debugging And Monitoring (AREA)

Abstract

本公开提供了命令响应时长的确定方法、装置和存储介质,涉及计算机技术领域。具体实现方案为:从网络队列中读取命令到输入缓冲区,并记录接收命令的起始时间信息,并从输入缓冲区中读取命令,并执行命令,以得到命令的执行结果,将执行结果写入到输出缓冲区中,以及将输出缓冲区的执行结果写入到网络队列时所对应的时间信息作为处理命令的结束时间信息,并根据结束时间信息和起始时间信息,确定命令的响应时长。由此,根据命令的起始时间信息和处理该命令的结束时间信息,确定该命令的响应时长,提高了命令的响应时长的准确性,进而可提高后续基于命令的响应时长所进行地数据分析的准确性。

Description

命令响应时长的确定方法、装置和存储介质
技术领域
本公开涉及计算机技术领域,尤其涉及一种命令响应时长的确定方法、装置和存储介质。
背景技术
相关技术中,通常是基于数据缓冲redis服务器中所给出命令的执行消耗时间进行数据分析,例如,来对处理器CPU(central processing unit)的平均负载进行分析。准确确定命令的执行消耗时间,对于准确进行数据分析是十分重要的。因此,如何准确确定出命令的执行消耗时间是目前亟需解决的技术问题。
发明内容
本公开提供了一种命令响应时长的确定方法、装置、设备以及存储介质。
根据本公开的一方面,提供了一种命令响应时长的确定方法,包括:从网络队列中读取命令到输入缓冲区,并记录接收所述命令的起始时间信息;从所述输入缓冲区中读取所述命令,并执行所述命令,以得到所述命令的执行结果;将所述执行结果写入到输出缓冲区中;将所述输出缓冲区的所述执行结果写入到所述网络队列时所对应的时间信息作为处理所述命令的结束时间信息;根据所述结束时间信息和所述起始时间信息,确定所述命令的响应时长。
根据本公开的另一方面,提供了一种命令响应时长的确定装置,包括:读取模块,用于从网络队列中读取命令到输入缓冲区,并记录接收所述命令的起始时间信息;执行模块,用于从所述输入缓冲区中读取所述命令,并执行所述命令,以得到所述命令的执行结果;写入模块,用于将所述执行结果写入到输出缓冲区中;获取模块,用于将所述输出缓冲区的所述执行结果写入到所述网络队列时所对应的时间信息作为处理所述命令的结束时间信息;确定模块,用于根据所述结束时间信息和所述起始时间信息,确定所述命令的响应时长。
根据本公开的另一方面,提供了一种数据缓存服务器,包括:至少一个处理器;以及与所述至少一个处理器通信连接的存储器;其中,所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行第一方面所述的方法。
根据本公开的另一方面,提供了一种存储有计算机指令的非瞬时计算机可读存储介质,其中,所述计算机指令用于使所述计算机执行第一方面所述的方法。
根据本公开的另一方面,提供了一种计算机程序产品,包括计算机程序,所述计算机程序在被处理器执行时实现第一方面所述的方法。
本实施例所提供的技术方案,可以包含如下的有益效果:
从网络队列中读取命令到输入缓冲区,并记录接收命令的起始时间信息,并从输入缓冲区中读取命令,并执行命令,以得到命令的执行结果,将执行结果写入到输出缓冲区中,以及将输出缓冲区的执行结果写入到网络队列时所对应的时间信息作为处理命令的结束时间信息,并根据结束时间信息和起始时间信息,确定命令的响应时长。由此,根据命令的起始时间信息和处理该命令的结束时间信息,确定该命令的响应时长,提高了命令的响应时长的准确性,进而可提高后续基于命令的响应时长所进行地数据分析的准确性。
应当理解,本部分所描述的内容并非旨在标识本公开的实施例的关键或重要特征,也不用于限制本公开的范围。本公开的其它特征将通过以下的说明书而变得容易理解。
附图说明
附图用于更好地理解本方案,不构成对本公开的限定。其中:
图1为本公开实施例提供的一种命令响应时长的确定方法的流程示意图;
图2为本公开实施例提供的另一种命令响应时长的确定方法的流程示意图;
图3为本公开实施例提供的另一种命令响应时长的确定方法的流程示意图;
图4为本公开实施例提供的另一种命令响应时长的确定方法的流程示意图;
图5为本公开实施例提供的一种命令响应时长的确定装置的结构示意图;
图6为本公开实施例提供的另一种命令响应时长的确定装置的结构示意图;
图7为本公开实施例提供的数据缓存服务器的示意性框图。
具体实施方式
以下结合附图对本公开的示范性实施例做出说明,其中包括本公开实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本公开的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
相关技术中,在确定命令的执行消耗时间,通常只统计了命令具体执行处理阶段的消耗时间,并不能准确反映出处理该指令的整个时间,从而将影响后续数据分析的准确性。因此,如何准确确定命令的整个处理时间是目前亟需解决的技术问题。
为了解决该技术问题,本公开提出了一种命令响应时长的确定方法,该方法,从网络队列中读取命令到输入缓冲区,并记录接收命令的起始时间信息,并从输入缓冲区中读取命令,并执行命令,以得到命令的执行结果,将执行结果写入到输出缓冲区中,以及将输出缓冲区的执行结果写入到网络队列时所对应的时间信息作为处理命令的结束时间信息,并根据结束时间信息和起始时间信息,确定命令的响应时长。由此,根据命令的起始时间信息和处理该命令的结束时间信息,确定该命令的响应时长,提高了命令的响应时长的准确性,进而可提高后续基于命令的响应时长所进行地数据分析的准确性。
下面参考附图描述本公开实施例的命令响应时长的确定方法、装置和存储介质。
图1为本公开实施例提供的一种命令响应时长的确定方法的流程示意图。
其中,需要说明的是,本实施例提供的命令响应时长的确定方法,执行主体为命令响应时长的确定装置,该命令响应时长的确定装置可以配置在数据缓存服务器,通过该命令时长的确定装置可准确确定出命令的响应时长。
如图1所示,该命令响应时长的确定方法,可以包括以下步骤:
步骤101,从网络队列中读取命令到输入缓冲区,并记录接收命令的起始时间信息。
在示例性实施方式中,在从网络队列中读取命令到输入缓冲区的过程中,可获取接收到该命令的起始时间信息,并记录该命令的起始时间信息。
步骤102,从输入缓冲区中读取命令,并执行命令,以得到命令的执行结果。
具体地,可依次读取输入缓冲区的命令,并执行所读取的命令,以得到该命令的执行结果。
其中,可以理解的是,不同命令所执行的处理是不同的,对应地,执行结果也是不同的,该实施例对命令以及命令对应的执行结果不作具体限定,可根据实际应用需求设置可执行的命令。
步骤103,将执行结果写入到输出缓冲区中。
在示例性实施例中,为了减少处理压力,可将该命令的执行结果写入到输出缓冲区中。
步骤104,将输出缓冲区的执行结果写入到网络队列时所对应的时间信息作为处理命令的结束时间信息。
步骤105,根据结束时间信息和起始时间信息,确定命令的响应时长。
在示例性的实施方式中,可获取结束时间信息减去起始时间信息所得到的时间差,并将所得到的时间差作为该命令的响应时长。也就是说,可将所得到的时间差作为数据缓存服务器处理该命令所消耗的时间。
本实施例的命令响应时长的确定方法中,该方法从网络队列中读取命令到输入缓冲区,并记录接收命令的起始时间信息,并从输入缓冲区中读取命令,并执行命令,以得到命令的执行结果,将执行结果写入到输出缓冲区中,以及将输出缓冲区的执行结果写入到网络队列时所对应的时间信息作为处理命令的结束时间信息,并根据结束时间信息和起始时间信息,确定命令的响应时长。由此,根据命令的起始时间信息和处理该命令的结束时间信息,确定该命令的响应时长,提高了命令的响应时长的准确性,进而可提高后续基于命令的响应时长所进行地数据分析的准确性。
基于上述实施例的基础上,为了可以准确确定出该命令的结束时间信息,下面结合图2,对将输出缓冲区的执行结果写入到网络队列时所对应的时间信息作为处理命令的结束时间信息的一种示例性的实施方式进行示例性描述,如图2所示,可以包括:
步骤201,获取执行结果在输出缓冲区的结束位置。
在一些实施例中,上述获取执行结果在输出缓冲区的结束位置的一种可能实现方式为:获取命令所对应的结构体信息,从结构体信息中,获取执行结果在输出缓冲区的结束位置。
其中,该结构体信息中包括该命令的执行结果在输出缓冲区的结束位置。
在另一些实施例中,可以通过该结构体信息确定命令的起始时间信息。也就是说,上述结构体信息中还可以包括命令的起始时间信息。
在一种示例性的实施方式中,上述命令的结构体信息CommandDelayStat的示例如下:
CommandDelayStat
typedefsturctCommandDelayStat{
int begin;命令的执行结果在输出缓冲区中的结束位置。
sdscmd;//要执行的命令名
intcreatetime;//从网络队列中接收命令的起始时间。
};
步骤202,将输出缓冲区中的内容写入到网络队列中。
在一些实施例中,可通过写入事件处理器将输出缓冲区中的内容写入到网络队列中。
在一些可能的实施例中,为了可通过写入事件处理器将输出缓冲区中的内容写入到网络队列中,可预先对写入事件处理器进行注册。也就是说,可在通过写入事件处理器将输出缓冲区中的内容写入到网络队列中之前,还可以注册写入事件处理器。
步骤203,在检测到结束位置上的内容写入到网络队列时,确定执行结果写入到网络队列,并获取结束位置上的内容写入到网络队列时所对应的时间信息,并将所获取到的时间信息作为处理该命令的结束时间信息。
在本实施例中,将输出缓冲区中的内容写入到网络队列中,并在检测到执行结果在输出缓冲区的结束位置上的内容写入到网络队列的情况下,获取当前时间信息,并将当前时间信息作为处理该命令的结束时间信息,从而方便后续就该结束时间信息和起始时间信息,准确确定出该命令的响应时长。
图3为本公开实施例提供的另一种命令响应时长的确定方法的流程示意图。
如图3所示,该命令响应时长的确定方法包含以下步骤:
步骤301,控制读取事件处理器从网络队列中读取命令,并将该命令保存到输入缓冲区。
在一些实施例中,为了可通过读取事件处理器从网络队列中读取命令,可预先对读取事件处理器进行注册,也就是说,在控制读取事件处理器从网络队列中读取命,还可以注册读取事件处理器。
步骤302,从输入缓冲区中读取命令,并执行命令,以得到命令的执行结果。
步骤303,将执行结果写入到输出缓冲区中。
步骤304,获取执行结果在输出缓冲区的结束位置。
步骤305,将输出缓冲区中的内容写入到网络队列中。
步骤306,在检测到结束位置上的内容写入到网络队列时,确定执行结果写入到网络队列,并获取结束位置上的内容写入到网络队列时所对应的时间信息,并将所获取到的时间信息作为处理该命令的结束时间信息。
步骤307,根据结束时间信息和起始时间信息,确定命令的响应时长。
本实施例的命令响应时长的确定方法,该方法控制读取事件处理器网络队列中读取命令到输入缓冲区,并记录接收命令的起始时间信息,并从输入缓冲区中读取命令,并执行命令,以得到命令的执行结果,将执行结果写入到输出缓冲区中,以及获取执行结果在输出缓冲区的结束位置;将输出缓冲区中的内容写入到网络队列中;在检测到结束位置上的内容写入到网络队列时,确定执行结果写入到网络队列,并获取结束位置上的内容写入到网络队列时所对应的时间信息,并根据结束时间信息和起始时间信息,确定命令的响应时长。由此,根据命令的起始时间信息和处理该命令的结束时间信息,确定该命令的响应时长,提高了命令的响应时长的准确性,进而可提高后续基于命令的响应时长所进行地数据分析的准确性。
为了使得本领域的技术人员可以清楚了解本申请下面结合图4对该实施例的命令响应时长的确定方法进行描述。如图4所示,可以包括:
步骤401,启动数据缓存服务器。
步骤402,注册套接字socket连接事件处理器。
步骤403,通过socket连接事件处理器,建立数据缓存服务器与客户端Client之间的socket连接。
步骤404,注册socket读取事件处理器。
在本实施例中,为了使得数据缓存服务器可从socket网络队列读取客户端通过socket连接发送的命令,可预先注册socket读取事件处理器。
步骤405,通过socket读取事件处理器从socket网络队列读取客户端通过socket连接发送的命令,并将读取到的命令保存到输入缓冲区中,并记录接收到该命令的起始时间信息。
步骤406,解析输入缓冲区重点数据,以获取该命令。
步骤407,执行该命令,以得到该命令的执行结果,并传输该起始时间信息。
步骤408,将执行结果写入到输出缓冲区中,并基于执行结果在输出缓冲区的结束位置信息和上述起始时间信息,生成该命令的命令耗时统计结构体信息。
作为一种示例性的实施方式,上述命令的命令耗时统计结构体信息CommandDelayStat的示例如下:
CommandDelayStat
typedefsturctCommandDelayStat{
intbegin;命令的执行结果在输出缓冲区中的结束位置。
sdscmd;//要执行的命令名
intcreatetime;//从网络队列中接收命令的起始时间。
};
步骤409,将命令耗时统计结构体信息添加到统计列表中。
步骤410,注册socket写入事件处理器。
步骤411,基于socket写入事件处理器,将输出缓冲区的内容写入到socket网络队列中,并基于统计列表,获取该命令的命令耗时统计结构体信息,并基于命令耗时统计结构体信息确定该命令的响应耗时时长。
在一些示例性的实施方式中,上述基于统计列表,获取该命令的命令耗时统计结构体信息的实现方式可以为:根据该命令的命令名称,查询该统计表,以得到该命令的命令耗时统计结构体信息。
在一些示例性的实施方式中,可基于命令耗时统计结构体信息确定该命令的响应耗时时长的具体实现方式为:可从命令耗时统计结构体信息,获取接收该命令的起始时间信息和执行结果在输出缓冲区的结束位置信息,然后,该结束位置信息,获取将该结束位置信息上的内容发送到socket网络队列时所对应的时间信息,并将所获取到的时间信息作为处理该命令的结束时间信息;以及根据起始时间信息和结束时间信息,确定该命令的响应耗时时长。由此,结合接收该命令的起始时间和处理该命令的结束时间信息,准确确定出了该命令的整个处理时间数据,通过整个处理时间数据可准确反映该指令的响应耗时。
步骤412,关闭客户端Client。
基于上述实施例的基础上,可通过本实施例所提供的方法,确定数据缓存服务器所处理的每个命令的响应时长,并基于每个命令的响应时长进行数据分析,或者问题分析等。作为一种示例,可基于每个命令的响应时长,来确定数据缓存服务器中的处理器负载情况。
为了实现上述实施例,本实施例提供了一种命令响应时长的确定装置。
图5为本公开实施例提供的一种命令响应时长的确定装置的结构示意图,如图5所示,该装置包括:读取模块501、执行模块502、写入模块503、获取模块504和确定模块505,其中:
读取模块501,用于从网络队列中读取命令到输入缓冲区,并记录接收命令的起始时间信息。
执行模块502,用于从输入缓冲区中读取命令,并执行命令,以得到命令的执行结果。
写入模块503,用于将执行结果写入到输出缓冲区中。
获取模块504,用于将输出缓冲区的执行结果写入到网络队列时所对应的时间信息作为处理命令的结束时间信息。
确定模块505,用于根据结束时间信息和起始时间信息,确定命令的响应时长。
在本公开的一些实施例中,参考图6,获取模块504,包括:
第一获取单元5041,用于获取执行结果在输出缓冲区的结束位置;
写入单元5042,用于将输出缓冲区中的内容写入到网络队列中;
第二获取单元5043,用于在检测到结束位置上的内容写入到网络队列时,确定执行结果写入到网络队列,并获取结束位置上的内容写入到网络队列时所对应的时间信息,并将所获取到的时间信息作为结束时间信息。
在一种可能的实现方式中,上述第一获取单元5041,具体用于:获取命令所对应的结构体信息;从结构体信息中,获取执行结果在输出缓冲区的结束位置。
在本公开的一些示例性的实施方式中,上述读取模块501,具体用于:控制读取事件处理器从网络队列中读取命令,并将命令保存到输入缓冲区。
如图6所示,该装置还可以包括:
第一注册模块506,用于注册读取事件处理器。
在一些实施例中,上述写入单元5042,具体用于:通过写入事件处理器将输出缓冲区中的内容写入到网络队列中。
如图6所示,该装置还可以包括:第二注册模块507,用于注册写入事件处理器。
需要说明的是,前述对方法实施例的解释说明,也适用于本实施例的装置,原理相同,本实施例中不再赘述。
本实施例的命令响应时长的确定装置,从网络队列中读取命令到输入缓冲区,并记录接收命令的起始时间信息,并从输入缓冲区中读取命令,并执行命令,以得到命令的执行结果,将执行结果写入到输出缓冲区中,以及将输出缓冲区的执行结果写入到网络队列时所对应的时间信息作为处理命令的结束时间信息,并根据结束时间信息和起始时间信息,确定命令的响应时长。由此,根据命令的起始时间信息和处理该命令的结束时间信息,确定该命令的响应时长,提高了命令的响应时长的准确性,进而可提高后续基于命令的响应时长所进行地数据分析的准确性。
为了实现上述实施例,本实施例提供了一种数据缓存服务器,包括:
至少一个处理器;以及
与至少一个处理器通信连接的存储器;其中,
存储器存储有可被至少一个处理器执行的指令,指令被至少一个处理器执行,以使至少一个处理器能够执行前述方法实施例的方法。
为了实现上述实施例,本实施例提供了一种存储有计算机指令的非瞬时计算机可读存储介质,其中,计算机指令用于使计算机执行前述方法实施例的方法。
为了实现上述实施例,本实施例提供了一种计算机程序产品,包括计算机程序,计算机程序在被处理器执行时实现前述方法实施例的方法。
图7为本公开实施例提供的数据缓存服务器的示意性框图。数据缓存服务器旨在表示各种形式的数字计算机,诸如,膝上型计算机、台式计算机、工作台、个人数字助理、服务器、刀片式服务器、大型计算机、和其它适合的计算机。本文所示的部件、它们的连接和关系、以及它们的功能仅仅作为示例,并且不意在限制本文中描述的和/或者要求的本公开的实现。
如图7所示,设备700包括计算单元701,其可以根据存储在ROM(Read-OnlyMemory,只读存储器)702中的计算机程序或者从存储单元708加载到RAM(RandomAccessMemory,随机访问/存取存储器)703中的计算机程序,来执行各种适当的动作和处理。在RAM703中,还可存储设备700操作所需的各种程序和数据。计算单元701、ROM702以及RAM703通过总线704彼此相连。I/O(Input/Output,输入/输出)接口705也连接至总线704。
设备700中的多个部件连接至I/O接口705,包括:输入单元706,例如键盘、鼠标等;输出单元707,例如各种类型的显示器、扬声器等;存储单元708,例如磁盘、光盘等;以及通信单元709,例如网卡、调制解调器、无线通信收发机等。通信单元709允许设备700通过诸如因特网的计算机网络和/或各种电信网络与其他设备交换信息/数据。
计算单元701可以是各种具有处理和计算能力的通用和/或专用处理组件。计算单元701的一些示例包括但不限于CPU(CentralProcessingUnit,中央处理单元)、GPU(GraphicProcessingUnits,图形处理单元)、各种专用的AI(ArtificialIntelligence,人工智能)计算芯片、各种运行机器学习模型算法的计算单元、DSP(DigitalSignalProcessor,数字信号处理器)、以及任何适当的处理器、控制器、微控制器等。计算单元701执行上文所描述的各个方法和处理,例如命令响应时长的确定方法。例如,在一些实施例中,命令响应时长的确定方法可被实现为计算机软件程序,其被有形地包含于机器可读介质,例如存储单元708。在一些实施例中,计算机程序的部分或者全部可以经由ROM702和/或通信单元709而被载入和/或安装到设备700上。当计算机程序加载到RAM703并由计算单元701执行时,可以执行上文描述的命令响应时长的确定方法的一个或多个步骤。备选地,在其他实施例中,计算单元701可以通过其他任何适当的方式(例如,借助于固件)而被配置为执行命令响应时长的确定方法。
本文中以上描述的系统和技术的各种实施方式可以在数字电子电路系统、集成电路系统、FPGA(FieldProgrammableGateArray,现场可编程门阵列)、ASIC(Application-SpecificIntegratedCircuit,专用集成电路)、ASSP(ApplicationSpecificStandardProduct,专用标准产品)、SOC(SystemOnChip,芯片上系统的系统)、CPLD(ComplexProgrammableLogicDevice,复杂可编程逻辑设备)、计算机硬件、固件、软件、和/或它们的组合中实现。这些各种实施方式可以包括:实施在一个或者多个计算机程序中,该一个或者多个计算机程序可在包括至少一个可编程处理器的可编程系统上执行和/或解释,该可编程处理器可以是专用或者通用可编程处理器,可以从存储系统、至少一个输入装置、和至少一个输出装置接收数据和指令,并且将数据和指令传输至该存储系统、该至少一个输入装置、和该至少一个输出装置。
用于实施本公开的方法的程序代码可以采用一个或多个编程语言的任何组合来编写。这些程序代码可以提供给通用计算机、专用计算机或其他可编程数据处理装置的处理器或控制器,使得程序代码当由处理器或控制器执行时使流程图和/或框图中所规定的功能/操作被实施。程序代码可以完全在机器上执行、部分地在机器上执行,作为独立软件包部分地在机器上执行且部分地在远程机器上执行或完全在远程机器或服务器上执行。
在本公开的上下文中,机器可读介质可以是有形的介质,其可以包含或存储以供指令执行系统、装置或设备使用或与指令执行系统、装置或设备结合地使用的程序。机器可读介质可以是机器可读信号介质或机器可读储存介质。机器可读介质可以包括但不限于电子的、磁性的、光学的、电磁的、红外的、或半导体系统、装置或设备,或者上述内容的任何合适组合。机器可读存储介质的更具体示例会包括基于一个或多个线的电气连接、便携式计算机盘、硬盘、RAM、ROM、EPROM(ElectricallyProgrammableRead-Only-Memory,可擦除可编程只读存储器)或快闪存储器、光纤、CD-ROM(CompactDiscRead-OnlyMemory,便捷式紧凑盘只读存储器)、光学储存设备、磁储存设备、或上述内容的任何合适组合。
为了提供与用户的交互,可以在计算机上实施此处描述的系统和技术,该计算机具有:用于向用户显示信息的显示装置(例如,CRT(Cathode-RayTube,阴极射线管)或者LCD(LiquidCrystalDisplay,液晶显示器)监视器);以及键盘和指向装置(例如,鼠标或者轨迹球),用户可以通过该键盘和该指向装置来将输入提供给计算机。其它种类的装置还可以用于提供与用户的交互;例如,提供给用户的反馈可以是任何形式的传感反馈(例如,视觉反馈、听觉反馈、或者触觉反馈);并且可以用任何形式(包括声输入、语音输入或者、触觉输入)来接收来自用户的输入。
可以将此处描述的系统和技术实施在包括后台部件的计算系统(例如,作为数据服务器)、或者包括中间件部件的计算系统(例如,应用服务器)、或者包括前端部件的计算系统(例如,具有图形用户界面或者网络浏览器的用户计算机,用户可以通过该图形用户界面或者该网络浏览器来与此处描述的系统和技术的实施方式交互)、或者包括这种后台部件、中间件部件、或者前端部件的任何组合的计算系统中。可以通过任何形式或者介质的数字数据通信(例如,通信网络)来将系统的部件相互连接。通信网络的示例包括:LAN(LocalAreaNetwork,局域网)、WAN(WideAreaNetwork,广域网)、互联网和区块链网络。
计算机系统可以包括客户端和服务器。客户端和服务器一般远离彼此并且通常通过通信网络进行交互。通过在相应的计算机上运行并且彼此具有客户端-服务器关系的计算机程序来产生客户端和服务器的关系。服务器可以是云服务器,又称为云计算服务器或云主机,是云计算服务体系中的一项主机产品,以解决了传统物理主机与VPS服务("VirtualPrivateServer",或简称"VPS")中,存在的管理难度大,业务扩展性弱的缺陷。服务器也可以为分布式系统的服务器,或者是结合了区块链的服务器。
应该理解,可以使用上面所示的各种形式的流程,重新排序、增加或删除步骤。例如,本发公开中记载的各步骤可以并行地执行也可以顺序地执行也可以不同的次序执行,只要能够实现本公开公开的技术方案所期望的结果,本文在此不进行限制。
上述具体实施方式,并不构成对本公开保护范围的限制。本领域技术人员应该明白的是,根据设计要求和其他因素,可以进行各种修改、组合、子组合和替代。任何在本公开的精神和原则之内所作的修改、等同替换和改进等,均应包含在本公开保护范围之内。

Claims (13)

1.一种命令响应时长的确定方法,其特征在于,所述方法包括;
从网络队列中读取命令到输入缓冲区,并记录接收所述命令的起始时间信息;
从所述输入缓冲区中读取所述命令,并执行所述命令,以得到所述命令的执行结果;
将所述执行结果写入到输出缓冲区中;
将所述输出缓冲区的所述执行结果写入到所述网络队列时所对应的时间信息作为处理所述命令的结束时间信息;
根据所述结束时间信息和所述起始时间信息,确定所述命令的响应时长。
2.如权利要求1所述的方法,其特征在于,所述将所述输出缓冲区的所述执行结果写入到所述网络队列时所对应的时间信息作为处理所述命令的结束时间信息,包括:
获取所述执行结果在所述输出缓冲区的结束位置;
将所述输出缓冲区中的内容写入到所述网络队列中;
在检测到所述结束位置上的内容写入到所述网络队列时,确定所述执行结果写入到所述网络队列,并获取所述结束位置上的内容写入到所述网络队列时所对应的时间信息,并将所获取到的时间信息作为所述结束时间信息。
3.如权利要求2所述的方法,其特征在于,所述获取所述执行结果在所述输出缓冲区的结束位置,包括:
获取所述命令所对应的结构体信息;
从所述结构体信息中,获取所述执行结果在所述输出缓冲区的结束位置。
4.如权利要求1所述的方法,其特征在于,在所述从网络队列中读取命令到输入缓冲区,包括:
控制读取事件处理器从网络队列中读取所述命令,并将所述命令保存到所述输入缓冲区。
5.如权利要求2所述的方法,其特征在于,所述将所述输出缓冲区中的内容写入到所述网络队列中,包括:
通过写入事件处理器将所述输出缓冲区中的内容写入到所述网络队列中。
6.一种命令响应时长的确定装置,其特征在于,所述装置包括;
读取模块,用于从网络队列中读取命令到输入缓冲区,并记录接收所述命令的起始时间信息;
执行模块,用于从所述输入缓冲区中读取所述命令,并执行所述命令,以得到所述命令的执行结果;
写入模块,用于将所述执行结果写入到输出缓冲区中;
获取模块,用于将所述输出缓冲区的所述执行结果写入到所述网络队列时所对应的时间信息作为处理所述命令的结束时间信息;
确定模块,用于根据所述结束时间信息和所述起始时间信息,确定所述命令的响应时长。
7.如权利要求6所述的装置,其特征在于,所述获取模块,包括:
第一获取单元,用于获取所述执行结果在所述输出缓冲区的结束位置;
写入单元,用于将所述输出缓冲区中的内容写入到所述网络队列中;
第二获取单元,用于在检测到所述结束位置上的内容写入到所述网络队列时,确定所述执行结果写入到所述网络队列,并获取所述结束位置上的内容写入到所述网络队列时所对应的时间信息,并将所获取到的时间信息作为所述结束时间信息。
8.如权利要求7所述的装置,其特征在于,所述读取模块,具体用于:
获取所述命令所对应的结构体信息;
从所述结构体信息中,获取所述执行结果在所述输出缓冲区的结束位置。
9.如权利要求6所述的装置,其特征在于,所述第一获取单元,具体用于:
控制读取事件处理器从网络队列中读取所述命令,并将所述命令保存到所述输入缓冲区。
10.如权利要求7所述的装置,其特征在于,所述写入单元,具体用于:
通过写入事件处理器将所述输出缓冲区中的内容写入到所述网络队列中。
11.一种数据缓存服务器,其特征在于,包括:
存储器、处理器及存储在存储器上并可在处理器上运行的计算机程序,其特征在于,所述处理器执行所述程序时实现如权利要求1-5中任一所述的方法。
12.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,该程序被处理器执行时实现如权利要求1-5中任一所述的方法。
13.一种计算机程序产品,包括计算机程序,所述计算机程序在被处理器执行时实现根据权利要求1-5中任一项所述的方法。
CN202110640206.0A 2021-06-08 2021-06-08 命令响应时长的确定方法、装置和存储介质 Pending CN113377434A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202110640206.0A CN113377434A (zh) 2021-06-08 2021-06-08 命令响应时长的确定方法、装置和存储介质

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202110640206.0A CN113377434A (zh) 2021-06-08 2021-06-08 命令响应时长的确定方法、装置和存储介质

Publications (1)

Publication Number Publication Date
CN113377434A true CN113377434A (zh) 2021-09-10

Family

ID=77573076

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202110640206.0A Pending CN113377434A (zh) 2021-06-08 2021-06-08 命令响应时长的确定方法、装置和存储介质

Country Status (1)

Country Link
CN (1) CN113377434A (zh)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114827035A (zh) * 2022-05-05 2022-07-29 浪潮通信信息系统有限公司 一种网元通信方法、装置及计算机介质

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060184729A1 (en) * 2005-02-17 2006-08-17 Fujitsu Limited Device, method, and computer product for disk management
CN107463612A (zh) * 2017-06-29 2017-12-12 北京北信源软件股份有限公司 高并发redis数据库操作方法及系统
CN111427747A (zh) * 2020-03-24 2020-07-17 京东数字科技控股有限公司 一种Redis客户端性能监测方法及装置

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060184729A1 (en) * 2005-02-17 2006-08-17 Fujitsu Limited Device, method, and computer product for disk management
CN107463612A (zh) * 2017-06-29 2017-12-12 北京北信源软件股份有限公司 高并发redis数据库操作方法及系统
CN111427747A (zh) * 2020-03-24 2020-07-17 京东数字科技控股有限公司 一种Redis客户端性能监测方法及装置

Non-Patent Citations (4)

* Cited by examiner, † Cited by third party
Title
HELLO-WORLD3: "read()/fread()/mmap()执行效率对比", pages 1 - 15, Retrieved from the Internet <URL:https://www.cnblogs.com/hellokitty2/p/7440702.html> *
刘景云;: "单位Redis反应迟缓", 网络安全和信息化, vol. 978, no. 03, pages 383 *
小闹2333: "Redis-4 事件处理机制", Retrieved from the Internet <URL:https://zhuanlan.zhihu.com/p/345278827> *
潘少: "Linux I/O 原理和 Zero-copy 技术全面揭秘", Retrieved from the Internet <URL:https://zhuanlan.zhihu.com/p/296207162> *

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN114827035A (zh) * 2022-05-05 2022-07-29 浪潮通信信息系统有限公司 一种网元通信方法、装置及计算机介质

Similar Documents

Publication Publication Date Title
CN112540806A (zh) 一种小程序页面渲染方法、装置、电子设备及存储介质
CN113392974A (zh) 模型训练方法、装置、电子设备以及存储介质
CN113377434A (zh) 命令响应时长的确定方法、装置和存储介质
CN114417780A (zh) 状态同步方法、装置、电子设备及存储介质
CN115756322A (zh) 数据存储方法、装置、电子设备及存储介质
CN116578502A (zh) 访问请求处理装置、处理方法、设备及存储介质
CN115639966A (zh) 一种数据写入方法、装置、终端设备及存储介质
CN114168119B (zh) 代码文件编辑方法、装置、电子设备以及存储介质
CN115729742A (zh) 一种错误处理方法、装置、电子设备及存储介质
CN115061921A (zh) 自动测试方法、装置、电子设备及可读存储介质
CN115617549A (zh) 线程解耦方法、装置、电子设备及存储介质
CN115617800A (zh) 数据读取方法、装置、电子设备及存储介质
CN113918382A (zh) 用于复位的方法、装置、设备和可读存储介质
CN114475631B (zh) 驾驶数据处理方法装置、设备、自动驾驶车辆介质及产品
CN112527537B (zh) 在线服务系统的质量监控方法、装置、设备和介质
CN113961405B (zh) 状态切换指令验证方法、装置、电子设备及存储介质
CN117234593A (zh) 一种原子加操作方法、装置、芯片及存储介质
CN114328224A (zh) 异常请求的复现方法、装置、电子设备和存储介质
CN115543748A (zh) 一种信号测试方法、装置、设备及存储介质
CN114064411A (zh) 一种组件检测方法、装置、设备及存储介质
CN115202791A (zh) 首屏加载资源确定方法、装置、服务器及存储介质
CN114721895A (zh) 待测设计的验证方法、平台、设备和介质
CN113934581A (zh) 存储系统磁盘故障信息获取方法、装置、电子设备和介质
CN115509865A (zh) 流数据回溯方法、装置、电子设备及存储介质
CN113641639A (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