CN118152340A - Es操作方法和装置 - Google Patents

Es操作方法和装置 Download PDF

Info

Publication number
CN118152340A
CN118152340A CN202211508988.3A CN202211508988A CN118152340A CN 118152340 A CN118152340 A CN 118152340A CN 202211508988 A CN202211508988 A CN 202211508988A CN 118152340 A CN118152340 A CN 118152340A
Authority
CN
China
Prior art keywords
message
delay
time information
delay message
target document
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
CN202211508988.3A
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 Jingdong Century Trading Co Ltd
Beijing Wodong Tianjun Information Technology Co Ltd
Original Assignee
Beijing Jingdong Century Trading Co Ltd
Beijing Wodong Tianjun Information 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 Jingdong Century Trading Co Ltd, Beijing Wodong Tianjun Information Technology Co Ltd filed Critical Beijing Jingdong Century Trading Co Ltd
Priority to CN202211508988.3A priority Critical patent/CN118152340A/zh
Publication of CN118152340A publication Critical patent/CN118152340A/zh
Pending legal-status Critical Current

Links

Classifications

    • 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
    • Y02DCLIMATE 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/00Energy efficient computing, e.g. low power processors, power management or thermal management

Landscapes

  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本发明公开了一种ES操作方法和装置,涉及计算机技术领域。该方法的一具体实施方式包括:获取第一应用程序在ES关联的内存缓冲区中写入目标文档后发出的延迟消息;延迟消息中含有目标文档的标识以及写入的执行时间信息;根据目标文档的延迟查询时长以及执行时间信息确定延迟消息的投递时间信息,并将延迟消息存储在本地预设的第一主题;响应于检测到当前时刻达到第一主题中延迟消息的投递时间信息,将延迟消息存储在本地预设的第二主题,以使延迟消息从第二主题被获取之后、第二应用程序可从ES中查询到目标文档。该实施方式能够提高ES的查询准确率。

Description

ES操作方法和装置
技术领域
本发明涉及计算机技术领域,尤其涉及一种ES操作方法和装置。
背景技术
ElasticSearch(弹性搜索,简称为ES)是一种近实时的分布式搜索和分析引擎,在其中写入待查询的文档时,为了保障***性能,首先写入内存缓冲区,在一定时长之后再从内存缓冲区写入文件***缓存,此后才能对此文档进行查询。如此,如果某应用程序将文档写入内存缓冲区之后,另一应用程序立即从ES中进行查询,则无法查询到刚才写入的文档,这就是称ES为“近实时”的原因。ES的以上特点导致查询准确率不足的问题。
发明内容
有鉴于此,本发明实施例提供一种ES操作方法和装置,能够提高ES的查询准确率。
为实现上述目的,根据本发明的一个方面,提供了一种ES操作方法。
本发明实施例的ES操作方法由预设的消息队列服务器执行,所述方法包括:获取预设的第一应用程序在弹性搜索ES关联的内存缓冲区中写入目标文档后发出的延迟消息;其中,所述延迟消息中含有目标文档的标识以及所述写入的执行时间信息;根据预设的、所述目标文档的延迟查询时长以及所述执行时间信息确定所述延迟消息的投递时间信息,并将所述延迟消息存储在本地预设的第一主题;响应于检测到当前时刻达到第一主题中所述延迟消息的所述投递时间信息,将所述延迟消息存储在本地预设的第二主题,以使所述延迟消息从第二主题被获取之后、第二应用程序可从所述ES中查询到所述目标文档。
可选地,所述写入目标文档后发出的延迟消息是第一应用程序向消息队列生产者发送的;以及,所述获取预设的第一应用程序在弹性搜索ES关联的内存缓冲区中写入目标文档后发出的延迟消息,包括:获取消息队列生产者发送的延迟消息。
可选地,所述方法进一步包括:在所述确定所述延迟消息的投递时间信息之后,将所述投递时间信息标记在所述延迟消息;以及,所述将所述延迟消息存储在本地预设的第一主题,包括:将标记有所述投递时间信息的所述延迟消息存储在第一主题;所述将所述延迟消息存储在本地预设的第二主题,包括:将标记有所述投递时间信息的所述延迟消息存储在第二主题。
可选地,所述延迟查询时长不小于所述ES中从文档被写入所述内存缓冲区到被写入所述文件***缓存之间的默认时长;以及,所述根据预设的、所述目标文档的延迟查询时长以及所述执行时间信息确定所述延迟消息的投递时间信息,包括:将所述延迟查询时长与所述执行时间信息相加,得到所述投递时间信息。
可选地,第二主题预先被消息队列消费者订阅;以及,所述延迟消息从第二主题被获取之后、第二应用程序可从所述ES中查询到所述目标文档,包括:所述消息队列消费者从第二主题中获得所述延迟消息之后,向第二应用程序发送携带有目标文档标识的通知,以使第二应用程序在接收到所述通知之后可从所述ES中查询到所述目标文档。
根据本发明的另一方面,提供了一种ES操作装置。
本发明实施例的ES操作装置设置在预设的消息队列服务器中,所述装置可以包括:延迟消息获取单元,用于:获取预设的第一应用程序在弹性搜索ES关联的内存缓冲区中写入目标文档后发出的延迟消息;其中,所述延迟消息中含有目标文档的标识以及所述写入的执行时间信息;延迟消息处理单元,用于:根据预设的、所述目标文档的延迟查询时长以及所述执行时间信息确定所述延迟消息的投递时间信息,并将所述延迟消息存储在本地预设的第一主题;延迟消息发布单元,用于:响应于检测到当前时刻达到第一主题中所述延迟消息的所述投递时间信息,将所述延迟消息存储在本地预设的第二主题,以使所述延迟消息从第二主题被获取之后、第二应用程序可从所述ES中查询到所述目标文档。
可选地,所述写入目标文档后发出的延迟消息是第一应用程序向消息队列生产者发送的,第二主题预先被消息队列消费者订阅;以及,所述延迟消息获取单元进一步用于:获取消息队列生产者发送的延迟消息;所述消息队列消费者从第二主题中获得所述延迟消息之后,向第二应用程序发送携带有目标文档标识的通知,以使第二应用程序在接收到所述通知之后可从所述ES中查询到所述目标文档。
可选地,所述延迟查询时长不小于所述ES中从文档被写入所述内存缓冲区到被写入所述文件***缓存之间的默认时长;以及,所述延迟消息处理单元进一步用于:将所述延迟查询时长与所述执行时间信息相加,得到所述投递时间信息;将所述投递时间信息标记在所述延迟消息,将标记有所述投递时间信息的所述延迟消息存储在第一主题;所述延迟消息发布单元进一步用于:将标记有所述投递时间信息的所述延迟消息存储在第二主题。
为实现上述目的,根据本发明的又一方面,提供了一种电子设备。
本发明的一种电子设备包括:一个或多个处理器;存储装置,用于存储一个或多个程序,当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现本发明所提供的ES操作方法。
为实现上述目的,根据本发明的再一方面,提供了一种计算机可读存储介质。
本发明的一种计算机可读存储介质,其上存储有计算机程序,所述程序被处理器执行时实现本发明所提供的ES操作方法。
根据本发明的技术方案,上述发明中的实施例具有如下优点或有益效果:
通过设置消息队列执行写入文档后查询指令的延迟,来提高ES的查询准确率。具体地,消息队列服务器在获取到第一应用程序在ES关联的内存缓冲区中写入目标文档后发出的延迟消息之后,根据其中携带的以上写入的执行时间信息以及预设的目标文档的延迟查询时长确定延迟消息的投递时间信息,并将标记有以上投递时间信息的延迟消息存储在本地预设的第一主题;以上延迟查询时长被配置为不小于ES中从文档被写入内存缓冲区到被写入文件***缓存之间的默认时长。此后,当消息队列服务器监测到当前时刻达到第一主题中延迟消息的投递时间信息时,将标记有以上投递时间信息的延迟消息存储在消息队列消费者预先订阅的第二主题,消息队列消费者在获取到第二主题中的延迟消息之后,向第二应用程序发送通知,以使第二应用程序可从ES中查询到目标文档。这样,可以针对每一待写入ES的文档通过消息队列的以上机制将第二应用程序的查询指令延迟一段时间,以便使第二应用程序执行查询时不会遗漏刚才写入ES的文档,从而在不影响ES原有工作流程的基础上提高ES***的查询准确率,并且,以上延迟查询时长可以针对不同待写入文档灵活配置,能够减轻高并发查询场景对ES***带来的压力,提升ES***的查询性能。
上述的非惯用的可选方式所具有的进一步效果将在下文中结合具体实施方式加以说明。
附图说明
附图用于更好地理解本发明,不构成对本发明的不当限定。其中:
图1是现有技术中ES的文档写入示意图;
图2是本发明实施例中ES操作方法的主要步骤示意图;
图3是本发明实施例中ES操作方法的执行架构示意图;
图4是本发明实施例中ES操作装置的组成部分示意图;
图5是根据本发明实施例可以应用于其中的示例性***架构图;
图6是用来实现本发明实施例中ES操作方法的电子设备结构示意图。
具体实施方式
以下结合附图对本发明的示范性实施例做出说明,其中包括本发明实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本发明的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
图1是现有技术中ES的文档写入示意图,参见图1,在ES中写入待查询的文档时,为了保障***性能,首先写入内存缓冲区(buffer),写入之后将文档的相关信息记录在translog。在一定时长(例如1秒)之后再将文档从内存缓冲区写入文件***缓存(filesystem cache,此过程为刷新refresh),此后才能对此文档进行查询。在较长时间(如半小时)之后将文档写入磁盘进行持久化(此过程为flush),flush完成之后清空translog。如此,如果某应用程序将文档写入内存缓冲区之后,另一应用程序立即从ES中进行查询,则无法查询到刚才写入的文档,由此导致ES的查询准确率不足。本发明尝试对此问题进行解决,首先建立消息队列执行查询操作的延迟以便提高ES的查询准确率。在本文中,将用于在ES中写入文档的应用称为第一应用程序,将用于在ES中进行查询文档的应用称为第二应用程序,这两个应用程序可以是同一应用程序,也可以是不同的应用程序。
需要指出的是,在不冲突的情况下,本发明的实施例以及实施例中的技术特征可以相互结合。
图2是根据本发明实施例中ES操作方法的主要步骤示意图。如图2所示,本发明实施例的ES操作方法由以上消息队列的消息队列服务器(broker)执行,执行步骤如下:
步骤S101:获取预设的第一应用程序在ES关联的内存缓冲区中写入目标文档后发出的延迟消息。
在本步骤中,第一应用程序可以不作为消息队列生产者,也可以作为消息队列生产者。在前一情况下,第一应用程序首先在ES的内存缓冲区写入目标文档(即待写入的文档),写入成功之后,向消息队列生产者发送延迟消息,该消息中含有目标文档的标识以及以上写入的执行时间信息(即写入操作的时间戳)。在后一情况下,第一应用程序在ES的内存缓冲区写入目标文档之后直接向消息队列服务器发送延迟消息。
步骤S102:根据预设的、目标文档的延迟查询时长以及执行时间信息确定延迟消息的投递时间信息,并将延迟消息存储在本地预设的第一主题。
以上延迟查询时长用于针对相应的待写入文档的查询操作(由第二应用程序)执行延迟,以便使查询操作执行时相应文档已经写在文件***缓存。以上延迟查询时长可以针对不同的待写入文档灵活设置,但是需要设置为不小于ES中从文档被写入内存缓冲区到被写入文件***缓存之间的默认时长(如前述1秒),这样才能使第二应用程序查询到目标文档。在本步骤中,消息队列服务器首先将目标文档的延迟查询时长与其执行时间信息相加,得到延迟消息的投递时间信息,此后将投递时间信息标记在延迟消息并将标记有投递时间信息的延迟消息存储在本地的第一主题。此后,消息队列服务器周期性地检测第一主题中延迟消息的投递时间信息是否达到。
步骤S103:响应于检测到当前时刻达到第一主题中延迟消息的投递时间信息,将延迟消息存储在本地预设的第二主题,以使延迟消息从第二主题被获取之后、第二应用程序可从ES中查询到目标文档。
在本发明实施例中,第二应用程序可以不作为消息队列消费者,也可以作为消息队列消费者。在前一情况下,消息队列服务器在检测到第一主题中延迟消息的投递时间信息达到之后,将标记有投递时间信息的延迟消息发送到第二主题,该第二主题已经预先被消息队列消费者订阅,因此消息队列消费者能够第一时间从第二主题中获得延迟消息。消息队列消费者从第二主题中获得延迟消息之后,向第二应用程序发送携带有目标文档标识的通知,以使第二应用程序在接收到通知之后即可发起执行指令,从ES中查询到目标文档。在后一情况下,消息队列服务器在检测到第一主题中延迟消息的投递时间信息达到之后,将标记有投递时间信息的延迟消息发送到第二主题,该第二主题已经预先被第二应用程序订阅,因此第二应用程序能够第一时间从第二主题中获得延迟消息。获得延迟消息之后,第二应用程序即可发起执行指令,从ES中查询到目标文档。
图3是本发明实施例中ES操作方法的执行架构示意图,如图3所示,以上消息队列可以是RabbitMQ,消息队列服务器的各种功能可以由其中通用的commitlog和管理服务(ScheduleMessageService)执行。在图3中,首先维持ES的原有数据处理机制不变,第一应用程序在ES的内存缓冲区写入文档之后,向消息队列生产者发送延迟消息,消息队列生产者将延迟消息发送到commitlog,commitlog在判断该消息属于延迟类型消息之后,在标记投递时间信息之后将延迟消息存储到第一主题。管理服务周期性检测第一主题中延迟消息的投递时间信息是否达到,在达到时将第一主题中的延迟消息发送到commitlog,由commitlog将延迟消息存储在消息队列消费者订阅的第二主题,消息队列消费者在第一时间获取到第二主题的延迟消息之后,向第二应用程序发出通知,第二应用程序接收到通知之后即可在ES中发出查询指令。
在本发明实施例的技术方案中,通过设置消息队列执行写入文档后查询指令的延迟,来提高ES的查询准确率。具体地,消息队列服务器在获取到第一应用程序在ES关联的内存缓冲区中写入目标文档后发出的延迟消息之后,根据其中携带的以上写入的执行时间信息以及预设的目标文档的延迟查询时长确定延迟消息的投递时间信息,并将标记有以上投递时间信息的延迟消息存储在本地预设的第一主题;以上延迟查询时长被配置为不小于ES中从文档被写入内存缓冲区到被写入文件***缓存之间的默认时长。此后,当消息队列服务器监测到当前时刻达到第一主题中延迟消息的投递时间信息时,将标记有以上投递时间信息的延迟消息存储在消息队列消费者预先订阅的第二主题,消息队列消费者在获取到第二主题中的延迟消息之后,向第二应用程序发送通知,以使第二应用程序可从ES中查询到目标文档。这样,可以针对每一待写入ES的文档通过消息队列的以上机制将第二应用程序的查询指令延迟一段时间,以便使第二应用程序执行查询时不会遗漏刚才写入ES的文档,从而在不影响ES原有工作流程的基础上提高ES***的查询准确率,并且,以上延迟查询时长可以针对不同待写入文档灵活配置,能够减轻高并发查询场景对ES***带来的压力,提升ES***的查询性能。
需要说明的是,对于前述的各方法实施例,为了便于描述,将其表述为一系列的动作组合,但是本领域技术人员应该知悉,本发明并不受所描述的动作顺序的限制,某些步骤事实上可以采用其它顺序进行或者同时进行。此外,本领域技术人员也应该知悉,说明书中所描述的实施例均属于优选实施例,所涉及的动作和模块并不一定是实现本发明所必须的。
为便于更好的实施本发明实施例的上述方案,下面还提供用于实施上述方案的相关装置。
请参阅图4所示,本发明实施例提供的ES操作装置400设置在预设的消息队列服务器中,可以包括:延迟消息获取单元401、延迟消息处理单元402以及延迟消息发布单元403。
其中,延迟消息获取单元401可以用于:获取预设的第一应用程序在弹性搜索ES关联的内存缓冲区中写入目标文档后发出的延迟消息;其中,所述延迟消息中含有目标文档的标识以及所述写入的执行时间信息;延迟消息处理单元402可以用于:根据预设的、所述目标文档的延迟查询时长以及所述执行时间信息确定所述延迟消息的投递时间信息,并将所述延迟消息存储在本地预设的第一主题;延迟消息发布单元403可以用于:响应于检测到当前时刻达到第一主题中所述延迟消息的所述投递时间信息,将所述延迟消息存储在本地预设的第二主题,以使所述延迟消息从第二主题被获取之后、第二应用程序可从所述ES中查询到所述目标文档。
较佳地,所述写入目标文档后发出的延迟消息是第一应用程序向消息队列生产者发送的,第二主题预先被消息队列消费者订阅;以及,所述延迟消息获取单元401可进一步用于:获取消息队列生产者发送的延迟消息;所述消息队列消费者从第二主题中获得所述延迟消息之后,向第二应用程序发送携带有目标文档标识的通知,以使第二应用程序在接收到所述通知之后可从所述ES中查询到所述目标文档。
此外,在本发明实施例中,所述延迟查询时长不小于所述ES中从文档被写入所述内存缓冲区到被写入所述文件***缓存之间的默认时长;以及,所述延迟消息处理单元402可进一步用于:将所述延迟查询时长与所述执行时间信息相加,得到所述投递时间信息;将所述投递时间信息标记在所述延迟消息,将标记有所述投递时间信息的所述延迟消息存储在第一主题;所述延迟消息发布单元403可进一步用于:将标记有所述投递时间信息的所述延迟消息存储在第二主题。
根据本发明实施例的技术方案,通过设置消息队列执行写入文档后查询指令的延迟,来提高ES的查询准确率。具体地,消息队列服务器在获取到第一应用程序在ES关联的内存缓冲区中写入目标文档后发出的延迟消息之后,根据其中携带的以上写入的执行时间信息以及预设的目标文档的延迟查询时长确定延迟消息的投递时间信息,并将标记有以上投递时间信息的延迟消息存储在本地预设的第一主题;以上延迟查询时长被配置为不小于ES中从文档被写入内存缓冲区到被写入文件***缓存之间的默认时长。此后,当消息队列服务器监测到当前时刻达到第一主题中延迟消息的投递时间信息时,将标记有以上投递时间信息的延迟消息存储在消息队列消费者预先订阅的第二主题,消息队列消费者在获取到第二主题中的延迟消息之后,向第二应用程序发送通知,以使第二应用程序可从ES中查询到目标文档。这样,可以针对每一待写入ES的文档通过消息队列的以上机制将第二应用程序的查询指令延迟一段时间,以便使第二应用程序执行查询时不会遗漏刚才写入ES的文档,从而在不影响ES原有工作流程的基础上提高ES***的查询准确率,并且,以上延迟查询时长可以针对不同待写入文档灵活配置,能够减轻高并发查询场景对ES***带来的压力,提升ES***的查询性能。
图5示出了可以应用本发明实施例的ES操作方法或ES操作装置的示例性***架构500。
如图5所示,***架构500可以包括终端设备501、502、503,网络504和服务器505(此架构仅仅是示例,具体架构中包含的组件可以根据申请具体情况调整)。网络504用以在终端设备501、502、503和服务器505之间提供通信链路的介质。网络504可以包括各种连接类型,例如有线、无线通信链路或者光纤电缆等。
用户可以使用终端设备501、502、503通过网络504与服务器505交互,以接收或发送消息等。终端设备501、502、503上可以安装有各种客户端应用,例如消息队列应用等(仅为示例)。
终端设备501、502、503可以是具有显示屏并且支持网页浏览的各种电子设备,包括但不限于智能手机、平板电脑、膝上型便携计算机和台式计算机等等。
服务器505可以是提供各种服务的服务器,例如对用户利用终端设备501、502、503所操作的消息队列应用提供支持的后台服务器(仅为示例)。后台服务器可以对接收到的延迟请求进行处理,并将处理结果(例如延迟消息被消费之后发出的通知--仅为示例)反馈给终端设备501、502、503。
需要说明的是,本发明实施例所提供的ES操作方法一般由服务器505执行,相应地,ES操作装置一般设置于服务器505中。
应该理解,图5中的终端设备、网络和服务器的数目仅仅是示意性的。根据实现需要,可以具有任意数目的终端设备、网络和服务器。
本发明还提供了一种电子设备。本发明实施例的电子设备包括:一个或多个处理器;存储装置,用于存储一个或多个程序,当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现本发明所提供的ES操作方法。
下面参考图6,其示出了适于用来实现本发明实施例的电子设备的计算机***600的结构示意图。图6示出的电子设备仅仅是一个示例,不应对本发明实施例的功能和使用范围带来任何限制。
如图6所示,计算机***600包括中央处理单元(CPU)601,其可以根据存储在只读存储器(ROM)602中的程序或者从存储部分608加载到随机访问存储器(RAM)603中的程序而执行各种适当的动作和处理。在RAM603中,还存储有计算机***600操作所需的各种程序和数据。CPU601、ROM 602以及RAM 603通过总线604彼此相连。输入/输出(I/O)接口605也连接至总线604。
以下部件连接至I/O接口605:包括键盘、鼠标等的输入部分606;包括诸如阴极射线管(CRT)、液晶显示器(LCD)等以及扬声器等的输出部分607;包括硬盘等的存储部分608;以及包括诸如LAN卡、调制解调器等的网络接口卡的通信部分609。通信部分609经由诸如因特网的网络执行通信处理。驱动器610也根据需要连接至I/O接口605。可拆卸介质611,诸如磁盘、光盘、磁光盘、半导体存储器等等,根据需要安装在驱动器610上,以便从其上读出的计算机程序根据需要被安装入存储部分608。
特别地,根据本发明公开的实施例,上文的主要步骤图描述的过程可以被实现为计算机软件程序。例如,本发明实施例包括一种计算机程序产品,其包括承载在计算机可读介质上的计算机程序,该计算机程序包含用于执行主要步骤图所示的方法的程序代码。在上述实施例中,该计算机程序可以通过通信部分609从网络上被下载和安装,和/或从可拆卸介质611被安装。在该计算机程序被中央处理单元601执行时,执行本发明的***中限定的上述功能。
需要说明的是,本发明所示的计算机可读介质可以是计算机可读信号介质或者计算机可读存储介质或者是上述两者的任意组合。计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的***、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本发明中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行***、装置或者器件使用或者与其结合使用。在本发明中,计算机可读信号介质可以包括在基带中或者作为载波一部分传播的数据信号,其中承载了计算机可读的程序代码。这种传播的数据信号可以采用多种形式,包括但不限于电磁信号、光信号或上述任意合适的组合。计算机可读信号介质还可以是计算机可读存储介质以外的任何计算机可读介质,该计算机可读介质可以发送、传播或者传输用于由指令执行***、装置或者器件使用或者与其结合使用的程序。计算机可读介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
附图中的流程图和框图,图示了按照本发明各种实施例的***、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段、或代码的一部分,上述模块、程序段、或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这根据所涉及的功能而定。也要注意的是,框图或流程图中的每个方框、以及框图或流程图中的方框的组合,可以用执行规定的功能或操作的专用的基于硬件的***来实现,或者可以用专用硬件与计算机指令的组合来实现。
描述于本发明实施例中所涉及到的单元可以通过软件的方式实现,也可以通过硬件的方式来实现。所描述的单元也可以设置在处理器中,例如,可以描述为:一种处理器包括延迟消息获取单元、延迟消息处理单元和延迟消息发布单元。其中,这些单元的名称在某种情况下并不构成对该单元本身的限定,例如,延迟消息获取单元还可以被描述为“向延迟消息处理单元提供延迟消息的单元”。
作为另一方面,本发明还提供了一种计算机可读介质,该计算机可读介质可以是上述实施例中描述的设备中所包含的;也可以是单独存在,而未装配入该设备中的。上述计算机可读介质承载有一个或者多个程序,当上述一个或者多个程序被该设备执行时,使得该设备执行的步骤包括:获取预设的第一应用程序在弹性搜索ES关联的内存缓冲区中写入目标文档后发出的延迟消息;其中,所述延迟消息中含有目标文档的标识以及所述写入的执行时间信息;根据预设的、所述目标文档的延迟查询时长以及所述执行时间信息确定所述延迟消息的投递时间信息,并将所述延迟消息存储在本地预设的第一主题;响应于检测到当前时刻达到第一主题中所述延迟消息的所述投递时间信息,将所述延迟消息存储在本地预设的第二主题,以使所述延迟消息从第二主题被获取之后、第二应用程序可从所述ES中查询到所述目标文档。
在本发明实施例的技术方案中,通过设置消息队列执行写入文档后查询指令的延迟,来提高ES的查询准确率。具体地,消息队列服务器在获取到第一应用程序在ES关联的内存缓冲区中写入目标文档后发出的延迟消息之后,根据其中携带的以上写入的执行时间信息以及预设的目标文档的延迟查询时长确定延迟消息的投递时间信息,并将标记有以上投递时间信息的延迟消息存储在本地预设的第一主题;以上延迟查询时长被配置为不小于ES中从文档被写入内存缓冲区到被写入文件***缓存之间的默认时长。此后,当消息队列服务器监测到当前时刻达到第一主题中延迟消息的投递时间信息时,将标记有以上投递时间信息的延迟消息存储在消息队列消费者预先订阅的第二主题,消息队列消费者在获取到第二主题中的延迟消息之后,向第二应用程序发送通知,以使第二应用程序可从ES中查询到目标文档。这样,可以针对每一待写入ES的文档通过消息队列的以上机制将第二应用程序的查询指令延迟一段时间,以便使第二应用程序执行查询时不会遗漏刚才写入ES的文档,从而在不影响ES原有工作流程的基础上提高ES***的查询准确率,并且,以上延迟查询时长可以针对不同待写入文档灵活配置,能够减轻高并发查询场景对ES***带来的压力,提升ES***的查询性能。
上述具体实施方式,并不构成对本发明保护范围的限制。本领域技术人员应该明白的是,取决于设计要求和其他因素,可以发生各种各样的修改、组合、子组合和替代。任何在本发明的精神和原则之内所作的修改、等同替换和改进等,均应包含在本发明保护范围之内。

Claims (10)

1.一种ES操作方法,其特征在于,由预设的消息队列服务器执行;所述方法包括:
获取预设的第一应用程序在弹性搜索ES关联的内存缓冲区中写入目标文档后发出的延迟消息;其中,所述延迟消息中含有目标文档的标识以及所述写入的执行时间信息;
根据预设的、所述目标文档的延迟查询时长以及所述执行时间信息确定所述延迟消息的投递时间信息,并将所述延迟消息存储在本地预设的第一主题;
响应于检测到当前时刻达到第一主题中所述延迟消息的所述投递时间信息,将所述延迟消息存储在本地预设的第二主题,以使所述延迟消息从第二主题被获取之后、第二应用程序可从所述ES中查询到所述目标文档。
2.根据权利要求1所述的方法,其特征在于,所述写入目标文档后发出的延迟消息是第一应用程序向消息队列生产者发送的;以及,所述获取预设的第一应用程序在弹性搜索ES关联的内存缓冲区中写入目标文档后发出的延迟消息,包括:
获取消息队列生产者发送的延迟消息。
3.根据权利要求1所述的方法,其特征在于,所述方法进一步包括:在所述确定所述延迟消息的投递时间信息之后,将所述投递时间信息标记在所述延迟消息;以及,
所述将所述延迟消息存储在本地预设的第一主题,包括:将标记有所述投递时间信息的所述延迟消息存储在第一主题;
所述将所述延迟消息存储在本地预设的第二主题,包括:将标记有所述投递时间信息的所述延迟消息存储在第二主题。
4.根据权利要求1所述的方法,其特征在于,所述延迟查询时长不小于所述ES中从文档被写入所述内存缓冲区到被写入所述文件***缓存之间的默认时长;以及,所述根据预设的、所述目标文档的延迟查询时长以及所述执行时间信息确定所述延迟消息的投递时间信息,包括:
将所述延迟查询时长与所述执行时间信息相加,得到所述投递时间信息。
5.根据权利要求1所述的方法,其特征在于,第二主题预先被消息队列消费者订阅;以及,所述延迟消息从第二主题被获取之后、第二应用程序可从所述ES中查询到所述目标文档,包括:
所述消息队列消费者从第二主题中获得所述延迟消息之后,向第二应用程序发送携带有目标文档标识的通知,以使第二应用程序在接收到所述通知之后可从所述ES中查询到所述目标文档。
6.一种ES操作装置,其特征在于,设置在预设的消息队列服务器中;所述装置包括:
延迟消息获取单元,用于:获取预设的第一应用程序在弹性搜索ES关联的内存缓冲区中写入目标文档后发出的延迟消息;其中,所述延迟消息中含有目标文档的标识以及所述写入的执行时间信息;
延迟消息处理单元,用于:根据预设的、所述目标文档的延迟查询时长以及所述执行时间信息确定所述延迟消息的投递时间信息,并将所述延迟消息存储在本地预设的第一主题;
延迟消息发布单元,用于:响应于检测到当前时刻达到第一主题中所述延迟消息的所述投递时间信息,将所述延迟消息存储在本地预设的第二主题,以使所述延迟消息从第二主题被获取之后、第二应用程序可从所述ES中查询到所述目标文档。
7.根据权利要求6所述的装置,其特征在于,所述写入目标文档后发出的延迟消息是第一应用程序向消息队列生产者发送的,第二主题预先被消息队列消费者订阅;以及,
所述延迟消息获取单元进一步用于:获取消息队列生产者发送的延迟消息;
所述消息队列消费者从第二主题中获得所述延迟消息之后,向第二应用程序发送携带有目标文档标识的通知,以使第二应用程序在接收到所述通知之后可从所述ES中查询到所述目标文档。
8.根据权利要求6所述的装置,其特征在于,所述延迟查询时长不小于所述ES中从文档被写入所述内存缓冲区到被写入所述文件***缓存之间的默认时长;以及,
所述延迟消息处理单元进一步用于:将所述延迟查询时长与所述执行时间信息相加,得到所述投递时间信息;将所述投递时间信息标记在所述延迟消息,将标记有所述投递时间信息的所述延迟消息存储在第一主题;
所述延迟消息发布单元进一步用于:将标记有所述投递时间信息的所述延迟消息存储在第二主题。
9.一种电子设备,其特征在于,包括:
一个或多个处理器;
存储装置,用于存储一个或多个程序,
当所述一个或多个程序被所述一个或多个处理器执行,使得所述一个或多个处理器实现如权利要求1-5中任一所述的方法。
10.一种计算机可读存储介质,其上存储有计算机程序,其特征在于,所述程序被处理器执行时实现如权利要求1-5中任一所述的方法。
CN202211508988.3A 2022-11-29 2022-11-29 Es操作方法和装置 Pending CN118152340A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202211508988.3A CN118152340A (zh) 2022-11-29 2022-11-29 Es操作方法和装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202211508988.3A CN118152340A (zh) 2022-11-29 2022-11-29 Es操作方法和装置

Publications (1)

Publication Number Publication Date
CN118152340A true CN118152340A (zh) 2024-06-07

Family

ID=91300412

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202211508988.3A Pending CN118152340A (zh) 2022-11-29 2022-11-29 Es操作方法和装置

Country Status (1)

Country Link
CN (1) CN118152340A (zh)

Similar Documents

Publication Publication Date Title
CN105787077B (zh) 数据同步方法和装置
CN111367687A (zh) 进程间数据通信方法和装置
CN111917687A (zh) 一种循环推送提醒消息的方法和装置
CN111478781B (zh) 一种消息广播的方法和装置
CN113312553B (zh) 一种用户标签的确定方法和装置
CN114116247A (zh) 基于Redis的消息处理方法、装置、***、服务器和介质
CN112948138A (zh) 一种处理消息的方法和装置
CN112784139B (zh) 查询方法、装置、电子设备和计算机可读介质
CN115454666A (zh) 消息队列集群间的数据同步方法和装置
CN118152340A (zh) Es操作方法和装置
CN112799863B (zh) 用于输出信息的方法和装置
CN112688982B (zh) 一种用户请求处理方法和装置
CN109087097B (zh) 一种更新链码同一标识的方法和装置
CN113742376A (zh) 一种同步数据的方法、第一服务器以及同步数据的***
CN113761433A (zh) 业务处理方法和装置
CN113572704A (zh) 一种信息处理方法、生产端、消费端和服务器
CN113779018A (zh) 一种数据处理方法和装置
CN113722193A (zh) 检测页面异常的方法和装置
CN112784195A (zh) 一种页面数据发布方法和***
CN113612676B (zh) 社交群组的消息同步方法、装置、设备及存储介质
CN113760965B (zh) 数据查询的方法和装置
CN112181937B (zh) 一种结转数据的方法和装置
CN110858240A (zh) 一种前端模块加载方法和装置
CN114064314A (zh) 业务消息处理方法、***、电子设备和计算机可读介质
CN113726827A (zh) 基于分布式集群的数据包处理方法和装置

Legal Events

Date Code Title Description
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination