远程字典服务优化方法及相关设备
技术领域
本公开涉及计算机和通信技术领域,具体而言,涉及一种远程字典服务优化方法及装置、计算机可读存储介质和电子设备。
背景技术
从数据规模的角度,因远程字典服务数据是存放在内存中,当数据量非常庞大的时候,完全依赖远程字典服务会产生较高的经济成本。从数据冷热的角度,因远程字典服务读写速度极快,所以适合存放操作频繁的数据,不适合存放冷数据。
现有技术中缺少针对远程字典服务缓存数据分布、数据空闲情况、数据过期设置的分析工具,使得无法对远程字典服务缓存数据存储情况进行监控,可能导致远程字典服务缓存中存储了大量无效的、空闲的数据,从而影响远程字典服务的存储效率,无法更好地发挥远程字典服务的优势,更无法根据远程字典服务缓存的数据存储情况对远程字典服务缓存进行空间释放,最终也就无法达到提高远程字典服务缓存存储效率的目的。
需要说明的是,在上述背景技术部分公开的信息仅用于加强对本公开的背景的理解,因此可以包括不构成对本领域普通技术人员已知的现有技术的信息。
发明内容
本公开实施例提供一种远程字典服务优化方法及装置、计算机可读存储介质和电子设备,能够对远程字典服务进行优化。
本公开的其他特性和优点将通过下面的详细描述变得显然,或部分地通过本公开的实践而习得。
根据本公开的一个方面,提供一种远程字典服务的优化方法,包括:
通过扫描工具扫描远程字典服务的缓存数据;
根据所述缓存数据的分布获取所述缓存数据中的无效数据;
通过扫描过滤工具获取所述缓存数据中的空闲数据;以及
对所述无效数据和所述空闲数据进行优化。
在一个实施例中,还包括:
通过所述扫描过滤工具获取未设置过期时间的数据;以及
对所述未设置过期时间的数据进行优化。
在一个实施例中,根据所述缓存数据的分布获取所述缓存数据中的无效数据包括:
根据所述缓存数据的名称前缀获取所述缓存数据中的所述无效数据;
在一个实施例中,通过扫描过滤工具获取空闲数据包括:
通过所述扫描过滤工具获取长期不使用的空闲数据和正在使用的数据中的空闲数据。
在一个实施例中,对所述无效数据和所述空闲数据进行优化包括:
删除所述长期不使用的空闲数据,将所述正在使用的数据中的空闲数据存储至内存之外的其他存储器。
在一个实施例中,对所述无效数据和所述空闲数据进行优化包括:
删除所述无效数据。
在一个实施例中,对所述未设置过期时间的数据进行优化包括:
删除所述未设置过期时间的数据中的可删除数据;以及
完善设计避免出现所述未设置过期时间的数据。
根据本公开的一个方面,提供一种远程字典服务的优化装置,包括:
扫描模块,配置为通过扫描工具扫描远程字典服务中的缓存数据;
获取模块,配置为根据所述缓存数据的分布获取所述缓存数据中的无效数据,通过扫描过滤工具获取空闲数据;以及
优化模块,配置为对所述无效数据和所述空闲数据进行优化。
根据本公开的一个方面,提供一种电子设备,包括:
一个或多个处理器;
存储装置,配置为存储一个或多个程序,当所述一个或多个程序被所述一个或多个处理器执行时,使得所述一个或多个处理器实现上述方法中任一项所述的方法。
根据本公开的一个方面,提供一种计算机可读存储介质,所述计算机可读存储介质存储有计算机程序,所述计算机程序被处理器执行时实现上述方法中任一项所述的方法。
本公开能够通过扫描工具扫描远程字典服务的缓存数据;根据所述缓存数据的分布获取所述缓存数据中的无效数据;通过扫描过滤工具获取所述缓存数据中的空闲数据;以及对所述无效数据和所述空闲数据进行优化,可以对远程字典服务进行优化,提高使用效率和功能。。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理。显而易见地,下面描述中的附图仅仅是本公开的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。在附图中:
图1示出了可以应用本公开实施方式的远程字典服务的优化方法或远程字典服务的优化装置的示例性系统架构的示意图;
图2示出了适于用来实现本公开实施方式的电子设备的计算机系统的结构示意图;
图3示意性示出了根据本公开的一实施方式的远程字典服务优化方法的流程图;
图4示意性示出了根据本公开的一实施方式的远程字典服务优化装置的框图;
图5示意性示出了根据本发明的另一个实施方式的远程字典服务优化装置的方框图;
图6示意性示出了根据本发明的另一个实施方式的远程字典服务优化装置的方框图。
具体实施方式
现在将参考附图更全面地描述示例实施方式。然而,示例实施方式能够以多种形式实施,且不应被理解为限于在此阐述的范例;相反,提供这些实施方式使得本公开将更加全面和完整,并将示例实施方式的构思全面地传达给本领域的技术人员。
此外,所描述的特征、结构或特性可以以任何合适的方式结合在一个或更多实施方式中。在下面的描述中,提供许多具体细节从而给出对本公开的实施方式的充分理解。然而,本领域技术人员将意识到,可以实践本公开的技术方案而没有特定细节中的一个或更多,或者可以采用其它的方法、组元、装置、步骤等。在其它情况下,不详细示出或描述公知方法、装置、实现或者操作以避免模糊本公开的各方面。
附图中所示的方框图仅仅是功能实体,不一定必须与物理上独立的实体相对应。即,可以采用软件形式来实现这些功能实体,或在一个或多个硬件模块或集成电路中实现这些功能实体,或在不同网络和/或处理器装置和/或微控制器装置中实现这些功能实体。
附图中所示的流程图仅是示例性说明,不是必须包括所有的内容和操作/步骤,也不是必须按所描述的顺序执行。例如,有的操作/步骤还可以分解,而有的操作/步骤可以合并或部分合并,因此实际执行的顺序有可能根据实际情况改变。
图1示出了可以应用本公开实施方式的远程字典服务的优化方法或远程字典服务的优化装置的示例性系统架构100的示意图。
如图1所示,系统架构100可以包括终端设备101、102、103中的一种或多种,网络104和服务器105。网络104是用以在终端设备101、102、103和服务器105之间提供通信链路的介质。网络104可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等等。
应该理解,图1中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。比如服务器105可以是多个服务器组成的服务器集群等。
用户可以使用终端设备101、102、103通过网络104与服务器105交互,以接收或发送消息等。终端设备101、102、103可以是具有显示屏的各种电子设备,包括但不限于智能手机、平板电脑、便携式计算机和台式计算机、数字电影放映机等等。
服务器105可以是提供各种服务的服务器。例如用户利用终端设备103(也可以是终端设备101或102)向服务器105发送远程字典服务(Redis)优化请求。或者是终端设备103自动实时发送远程字典服务的优化请求至服务器105。服务器105可以基于远程字典服务的优化请求,通过扫描工具(prefix)扫描远程字典服务的缓存数据;根据所述缓存数据的分布获取所述缓存数据中的无效数据;通过扫描过滤工具(scan-filter)获取所述缓存数据中的空闲数据;以及对所述无效数据和所述空闲数据进行优化。
又如终端设备103(也可以是终端设备101或102)可以是智能电视、VR(VirtualReality,虚拟现实)/AR(Augmented Reality,增强现实)头盔显示器、或者其上安装有导航、网约车、即时通讯、视频应用程序(application,APP)等的移动终端例如智能手机、平板电脑等,用户可以通过该智能电视、VR/AR头盔显示器或者该导航、网约车、即时通讯、视频APP向服务器105发送远程字典服务的优化请求。服务器105可以基于该远程字典服务的优化请求,获得远程字典服务的对应的优化方案,并将远程字典服务的对应的优化方案返回给该智能电视、VR/AR头盔显示器或者该导航、网约车、即时通讯、视频APP,进而通过该智能电视、VR/AR头盔显示器或者该导航、网约车、即时通讯、视频APP将返回的远程字典服务的对应的优化方案进行显示。
图2示出了适于用来实现本公开实施方式的电子设备的计算机系统的结构示意图。
需要说明的是,图2示出的电子设备的计算机系统200仅是一个示例,不应对本公开实施方式的功能和使用范围带来任何限制。
如图2所示,计算机系统200包括中央处理单元(CPU,Central Processing Unit)201,其可以根据存储在只读存储器(ROM,Read-Only Memory)202中的程序或者从储存部分208加载到随机访问存储器(RAM,Random Access Memory)203中的程序而执行各种适当的动作和处理。在RAM 203中,还存储有系统操作所需的各种程序和数据。CPU 201、ROM 202以及RAM 203通过总线204彼此相连。输入/输出(I/O)接口205也连接至总线204。
以下部件连接至I/O接口205:包括键盘、鼠标等的输入部分206;包括诸如阴极射线管(CRT,Cathode Ray Tube)、液晶显示器(LCD,Liquid Crystal Display)等以及扬声器等的输出部分207;包括硬盘等的储存部分208;以及包括诸如LAN(Local Area Network,局域网)卡、调制解调器等的网络接口卡的通信部分209。通信部分209经由诸如因特网的网络执行通信处理。驱动器210也根据需要连接至I/O接口205。可拆卸介质211,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器210上,以便于从其上读出的计算机程序根据需要被安装入储存部分208。
特别地,根据本公开的实施方式,下文参考流程图描述的过程可以被实现为计算机软件程序。例如,本公开的实施方式包括一种计算机程序产品,其包括承载在计算机可读存储介质上的计算机程序,该计算机程序包含用于执行流程图所示的方法的程序代码。在这样的实施方式中,该计算机程序可以通过通信部分209从网络上被下载和安装,和/或从可拆卸介质211被安装。在该计算机程序被中央处理单元(CPU)201执行时,执行本申请的方法和/或装置中限定的各种功能。
需要说明的是,本公开所示的计算机可读存储介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM(Erasable Programmable Read Only Memory,可擦除可编程只读存储器)或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本公开中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。而在本公开中,计算机可读的信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述的任意合适的组合。计算机可读的信号介质还可以是计算机可读存储介质以外的任何计算机可读存储介质,该计算机可读存储介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读存储介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF(RadioFrequency,射频)等等,或者上述的任意合适的组合。
附图中的流程图和框图,图示了按照本公开各种实施方式的方法、装置和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,上述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图或流程图中的每个方框、以及框图或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本公开实施方式中所涉及到的模块和/或单元和/或子单元可以通过软件的方式实现,也可以通过硬件的方式来实现,所描述的模块和/或单元和/或子单元也可以设置在处理器中。其中,这些模块和/或单元和/或子单元的名称在某种情况下并不构成对该模块和/或单元和/或子单元本身的限定。
作为另一方面,本申请还提供了一种计算机可读存储介质,该计算机可读存储介质可以是上述实施方式中描述的电子设备中所包含的;也可以是单独存在,而未装配入该电子设备中。上述计算机可读存储介质承载有一个或者多个程序,当上述一个或者多个程序被一个该电子设备执行时,使得该电子设备实现如下述实施方式中所述的方法。例如,所述的电子设备可以实现如图3所示的各个步骤。
相关技术中,例如可以采用机器学习方法、深度学习方法等进行远程字典服务优化,不同方法适用的范围不同。
图3示意性示出了根据本公开的一实施方式的远程字典服务优化方法的流程图。本公开实施方式的方法步骤可以由终端设备执行,也可以由服务端执行,或者由终端设备和服务端交互执行,例如,可以由上述图1中的服务器105执行,但本公开并不限定于此。
在步骤S310中,通过扫描工具扫描远程字典服务的缓存数据。
在该步骤中,终端或处理器通过扫描工具扫描远程字典服务的缓存数据。在一个实施例中,可以利用分析工具,对Redis缓存进行数据分布分析,此时可根据分析结果判断是否存在无效数据。在一个实施例中,利用工具(prefix)进行数据分布统计。
在步骤S320中,根据所述缓存数据的分布获取所述缓存数据中的无效数据。
在该步骤中,终端或处理器根据所述缓存数据的分布获取所述缓存数据中的无效数据。在一个实施例中,在利用工具(prefix)进行数据分布统计后,根据所述缓存数据的名称前缀获取所述缓存数据中的所述无效数据。
在步骤S330中,通过扫描过滤工具获取所述缓存数据中的空闲数据。
在该步骤中,终端或处理器通过扫描过滤工具(scan-filter)获取所述缓存数据中的空闲数据。在一个实施例中,通过所述扫描过滤工具获取长期不使用的空闲数据和正在使用的数据中的空闲数据。
在步骤S340中,对所述无效数据和所述空闲数据进行优化。
在该步骤中,终端或处理器通对所述无效数据和所述空闲数据进行优化。在一个实施例中,删除所述无效数据。在一个实施例中,删除所述长期不使用的空闲数据,将所述正在使用的数据中的空闲数据存储至内存之外的其他存储器。
在一个实施例中,图3中示出的方法还包括以下步骤:通过所述扫描过滤工具获取未设置过期时间的数据;以及对所述未设置过期时间的数据进行优化。在一个实施例中,删除所述未设置过期时间的数据中的可删除数据;以及完善设计以避免出现所述未设置过期时间的数据。
在一个实施例中,对于历史数据,由于长期不再使用,确认可进行删除;对于正常使用数据,但是明显其部分数据也存在空闲情况,使用人需要针对不同的调用场景,进一步优化代码逻辑,将热数据保持在Redis缓存中,将冷数据转移至其他数据存储,尤其是其他相对成本较低的数据存储。
在一个实施例中,利用Redis Scan遍历数据的方法,对Redis中的全量数据进行遍历,过程中获取以下三类数据:(1)数据名称,用于进行数据分布分析;(2)数据空闲时间,用于进行数据空闲情况分析;(3)数据剩余过期时间,用于进行数据过期设置分析。
在一个实施例中,利用Redis不同数据结构的数据删除命令,设计了对应的数据删除方法,从而支持针对上述数据分析结果进行无效的、空闲的数据删除。
在一个实施例中,利用分析工具,针对Redis缓存进行数据分布分析,此时可根据结果判断是否存在无效数据。
在一个实施例中,利用分析工具,进一步进行数据空闲情况统计,若统计结果中存在空闲数据,此时可评估是否为无效数据;同时可进行数据过期设置统计,判断是否因为未正确设置过期时间造成的数据空闲,若是,可指导后续进行设计优化,同时可针对统计结果确认下是否存在其他未正确设置过期时间的数据,一并可指导后续进行设计优化。
在一个实施例中,存在无效的、空闲的数据可删除的情况下,则执行删除操作,此时Redis缓存内存容量空间将得到释放。
在一个实施例中,选取缓存示例节点,获取节点当前数据存储量、内存使用量信息。
本申请通过扫描工具扫描远程字典服务的缓存数据;根据所述缓存数据的分布获取所述缓存数据中的无效数据;通过扫描过滤工具获取所述缓存数据中的空闲数据;以及对所述无效数据和所述空闲数据进行优化,可以对远程字典服务进行优化,提高使用效率和功能。
图4示意性示出了根据本公开的一实施方式的远程字典服务优化装置的框图。本公开实施方式提供的远程字典服务优化装置400可以设置在终端设备上,也可以设置在服务器端上,或者部分设置在终端设备上,部分设置在服务器端上,例如,可以设置在图1中的服务器105,但本公开并不限定于此。
本公开实施方式提供的远程字典服务优化装置400可以包括扫描模块410、获取模块420以及优化模块430。
其中,扫描模块410配置为通过扫描工具扫描远程字典服务中的缓存数据;获取模块420配置为根据所述缓存数据的分布获取所述缓存数据中的无效数据,通过扫描过滤工具获取空闲数据;以及优化模块430配置为对所述无效数据和所述空闲数据进行优化。
该远程字典服务优化装置400通过扫描工具扫描远程字典服务的缓存数据;根据所述缓存数据的分布获取所述缓存数据中的无效数据;通过扫描过滤工具获取所述缓存数据中的空闲数据;以及对所述无效数据和所述空闲数据进行优化,可以对远程字典服务进行优化,提高使用效率和功能。
根据本公开的实施方式,上述远程字典服务优化装置400可以用于实现图3实施方式描述的远程字典服务优化方法。
图5示意性示出了根据本发明的另一个实施方式的远程字典服务优化装置500的方框图。
如图5所示,除了图4实施方式描述的扫描模块410、获取模块420以及优化模块430之外,该远程字典服务优化装置500还包括显示模块510。
具体地,显示模块510在扫描模块430完成扫描后,以将扫描结果显示于所述终端;显示模块510在优化模块430完成优化后,以将优化结果显示于所述终端。
在该远程字典服务优化装置500中,通过显示模块510可以完成结果的直观显示。
图6示意性示出了根据本发明的另一个实施方式的远程字典服务优化装置600的方框图。
如图6所示,除了图4实施方式描述的扫描模块410、获取模块420以及优化模块430之外,远程字典服务优化装置600还包括存储模块610。
具体地,存储模块610,用于将所述远程字典服务的扫描结果以及远程字典服务的优化结果进行存储,以方便工作人员或服务器进行调用和参考。
可以理解的是,扫描模块410、获取模块420、优化模块430、显示模块510以及存储模块610可以合并在一个模块中实现,或者其中的任意一个模块可以被拆分成多个模块。或者,这些模块中的一个或多个模块的至少部分功能可以与其他模块的至少部分功能相结合,并在一个模块中实现。根据本发明的实施方式,扫描模块410、获取模块420、优化模块430、显示模块510以及存储模块610的至少一个可以至少被部分地实现为硬件电路,例如现场可编程门阵列(FPGA)、可编程逻辑阵列(PLA)、片上系统、基板上的系统、封装上的系统、专用集成电路(ASIC),或可以以对电路进行集成或封装的任何其他的合理方式等硬件或固件来实现,或以软件、硬件以及固件三种实现方式的适当组合来实现。或者,扫描模块410、获取模块420、优化模块430、显示模块510以及存储模块610中的至少一个可以至少被部分地实现为计算机程序模块,当该程序被计算机运行时,可以执行相应模块的功能。
由于本发明的示例实施方式的远程字典服务优化装置的各个模块可以用于实现上述图3描述的远程字典服务优化方法的示例实施方式的步骤,因此对于本发明装置实施方式中未披露的细节,请参照本发明上述的远程字典服务优化方法的实施方式。
本公开实施方式提供的远程字典服务优化装置,通过扫描工具扫描远程字典服务的缓存数据;根据所述缓存数据的分布获取所述缓存数据中的无效数据;通过扫描过滤工具获取所述缓存数据中的空闲数据;以及对所述无效数据和所述空闲数据进行优化,可以对远程字典服务进行优化,提高使用效率和功能。
本公开实施方式提供的远程字典服务优化装置中的各个模块、单元和子单元的具体实现可以参照上述远程字典服务优化方法中的内容,在此不再赘述。
应当注意,尽管在上文详细描述中提及了用于动作执行的设备的若干模块、单元和子单元,但是这种划分并非强制性的。实际上,根据本公开的实施方式,上文描述的两个或更多模块、单元和子单元的特征和功能可以在一个模块、单元和子单元中具体化。反之,上文描述的一个模块、单元和子单元的特征和功能可以进一步划分为由多个模块、单元和子单元来具体化。
通过以上的实施方式的描述,本领域的技术人员易于理解,这里描述的示例实施方式可以通过软件实现,也可以通过软件结合必要的硬件的方式来实现。因此,根据本公开实施方式的技术方案可以以软件产品的形式体现出来,该软件产品可以存储在一个非易失性存储介质(可以是CD-ROM,U盘,移动硬盘等)中或网络上,包括若干指令以使得一台计算设备(可以是个人计算机、服务器、触控终端、或者网络设备等)执行根据本公开实施方式的方法。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本公开的其它实施方案。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施方式仅被视为示例性的,本公开的真正范围和精神由下面的权利要求指出。
应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限制。