CN107133111A - 一种消息处理装置及方法 - Google Patents
一种消息处理装置及方法 Download PDFInfo
- Publication number
- CN107133111A CN107133111A CN201710286833.2A CN201710286833A CN107133111A CN 107133111 A CN107133111 A CN 107133111A CN 201710286833 A CN201710286833 A CN 201710286833A CN 107133111 A CN107133111 A CN 107133111A
- Authority
- CN
- China
- Prior art keywords
- message
- pending
- state index
- index
- pending message
- 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
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements 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/46—Multiprogramming arrangements
- G06F9/54—Interprogram communication
- G06F9/546—Message passing systems or structures, e.g. queues
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/22—Indexing; Data structures therefor; Storage structures
- G06F16/2228—Indexing structures
- G06F16/2246—Trees, e.g. B+trees
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Data Mining & Analysis (AREA)
- Databases & Information Systems (AREA)
- Computational Linguistics (AREA)
- Mobile Radio Communication Systems (AREA)
Abstract
本发明公开了一种消息处理装置及方法,应用于消息队列,所述装置包括:接收模块,用于接收待处理消息;第一判断模块,用于查询索引库,并判断是否存在与所述待处理消息相对应的状态索引;创建模块,用于所述第一判断模块的判断结果为否的情况下,创建目标状态索引,其中,所述目标状态索引为与所述待处理消息相对应的状态索引;更新模块,用于根据所述待处理消息的处理结果,更新所述目标状态索引。本发明还公开了一种消息处理方法,只有在待处理消息通过查询索引库不存在对应的状态索引的情况下才进行创建对应的目标状态索引,从而达到一个待处理消息对应一个状态索引,解决待处理消息丢失的问题。
Description
技术领域
本发明涉及消息处理技术领域,尤其涉及一种消息处理装置及方法。
背景技术
消息是在两台计算机间传送的数据单位。消息可以非常简单,例如只包含文本字符串;也可以更复杂,可能包含嵌入对象。通常,消息可以被发送到队列中。而消息队列是在消息的传输过程中保存消息的容器。消息队列管理器在将消息从它的源中继到它的目标时充当中间人。队列的主要目的是提供路由并保证消息的传递;如果发送消息时接收者不可用,消息队列会保留消息,直到可以成功地传递它。
目前的消息处理系统中,消息生产者发送消息,由消息服务器集群接收并推送给消息消费者进行处理。当消息处理量大或达到消息处理请求高峰时,消息生产者发送大量消息,消息服务器集群收到大量消息后,经过粗略的分配后发送给消息消费者,不能保障消息处理的稳定性,导致消息消费者收到的消息秩序杂乱,处理效率低。而且,当消息处理量大或达到消息处理请求高峰时,出现重复消息的频率较高,甚至会出现消息处理的丢失,而无法及时完成消息的处理。
因此,现有技术中,提供一种解决信息丢失的方案是亟待解决的技术问题。
发明内容
本发明的主要目的在于提出一种消息处理装置及方法,只有在待处理消息通过查询索引库不存在对应的状态索引的情况下才进行创建对应的目标状态索引,从而达到一个待处理消息对应一个状态索引,旨在解决待处理消息丢失的问题。
为实现上述目的,本发明提供了一种请求处理装置,应用于消息队列,所述装置包括:
接收模块,用于接收待处理消息;
第一判断模块,用于查询索引库,并判断是否存在与所述待处理消息相对应的状态索引;
创建模块,用于所述第一判断模块的判断结果为否的情况下,创建目标状态索引,其中,所述目标状态索引为与所述待处理消息相对应的状态索引;
更新模块,用于根据所述待处理消息的处理结果,更新所述目标状态索引。
可选的,所述装置还包括:
过滤模块,用于所述第一判断模块的判断结果为是的情况下,则过滤掉所述待处理消息。
可选的,所述装置还包括:
查询模块,用于根据预设时间,查询所述索引库中的目标状态索引;
第二判断模块,用于判断所述目标状态索引是否为处理完成状态;
重新处理模块,用于在所述第二判断模块的判断结果为否的情况下,重新处理所述目标状态索引对应的所述待处理消息。
可选的,所述更新模块,包括:
判断子模块,用于判断所述待处理消息的处理结果是否为处理完成状态;
更新子模块,用于在所述判断子模块的判断结果为是的情况下,更新所述目标状态索引为完成状态。
可选的,所述第一判断模块,具体用于:
采用二叉树查找方法,查询索引库。
相较于现有技术,本发明所提出的消息处理装置,通过在消息队列中对每一个没有创建状态索引的待处理消息进行创建状态索引,能够及时根据待处理消息的处理结果更新待处理消息对应的目标状态索引。从而实现每一个待处理消息对应一个状态索引,通过追踪状态索引解决了待处理消息丢失的问题。
此外,为实现上述目的,本发明还提出一种消息处理方法,应用于消息队列,所述方法包括:
接收待处理消息;
查询索引库,并判断是否存在与所述待处理消息相对应的状态索引;
如果不存在与所述待处理消息相对应的状态索引,创建目标状态索引,其中,所述目标状态索引为与所述待处理消息相对应的状态索引;
根据所述待处理消息的处理结果,更新所述目标状态索引。
可选的,所述方法还包括:
如果存在与所述待处理消息相对应的状态索引,则过滤掉所述待处理消息。
可选的,所述方法还包括:
根据预设时间,查询所述索引库中的目标状态索引;
判断所述目标状态索引是否为处理完成状态;
如果否,重新处理所述目标状态索引对应的所述待处理消息。
可选的,所述根据所述待处理消息的处理结果,更新所述目标状态索引,包括:
判断所述待处理消息的处理结果是否为处理完成状态;
如果是,更新所述目标状态索引为完成状态。
可选的,所述查询索引库,包括:
采用二叉树查找方法,查询索引库。
相较于现有技术,本发明所提出的消息处理装置,通过在消息队列中对每一个没有创建状态索引的待处理消息进行创建状态索引,能够及时根据待处理消息的处理结果更新待处理消息对应的目标状态索引。从而实现每一个待处理消息对应一个状态索引,通过追踪状态索引解决了待处理消息丢失的问题。
本发明还提供了一种终端,包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的消息处理程序,所述消息处理程序被所述处理器执行时实现如权利要求6至9中任一项所述的消息处理方法的步骤。
相较于现有技术,本发明所提出一种终端,通过在消息队列中对每一个没有创建状态索引的待处理消息进行创建状态索引,能够及时根据待处理消息的处理结果更新待处理消息对应的目标状态索引。从而实现每一个待处理消息对应一个状态索引,通过追踪状态索引解决了待处理消息丢失的问题。
附图说明
图1为实现本发明各个实施例中一可选的移动终端的硬件结构示意图;
图2为如图1所示的移动终端的无线通信系统示意图;
图3为本发明所述的消息处理装置的第一种功能模块示意图;
图4为本发明所述的消息处理装置的第二种功能模块示意图;
图5为本发明所述的消息处理装置的第三种功能模块示意图;
图6为本发明所述的消息处理方法的第一种流程示意图;
图7为本发明所述的消息处理方法的第二种流程示意图;
图8为本发明所述的消息处理方法的第三种流程示意图;
图9为本发明所述的消息处理结果提示图。
附图标记:
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
现在将参考附图描述实现本发明各个实施例的移动终端。在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身并没有特定的意义。因此,"模块"与"部件"可以混合地使用。
移动终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如移动电话、智能电话、笔记本电脑、数字广播接收器、PDA(个人数字助理)、PAD(平板电脑)、PMP(便携式多媒体播放器)、导航装置等等的移动终端以及诸如数字TV、台式计算机等等的固定终端。下面,假设终端是移动终端。然而,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。
图1为实现本发明各个实施例的移动终端的硬件结构示意。
移动终端100可以包括无线通信单元110、输入单元120、用户输入单元130、感测单元140、输出单元150、存储器160、接口单元170、控制器180和电源单元190等等。图1示出了具有各种组件的移动终端,但是应理解的是,并不要求实施所有示出的组件。可以替代地实施更多或更少的组件。将在下面详细描述移动终端的元件。
无线通信单元110通常包括一个或多个组件,其允许移动终端100与无线通信系统或网络之间的无线电通信。例如,无线通信单元可以包括广播接收模块、移动通信模块、无线互联网模块、短程通信模块和位置信息模块中的至少一个。
广播接收模块经由广播信道从外部广播管理服务器接收广播信号和/或广播相关信息。广播信道可以包括卫星信道和/或地面信道。广播管理服务器可以是生成并发送广播信号和/或广播相关信息的服务器或者接收之前生成的广播信号和/或广播相关信息并且将其发送给终端的服务器。广播信号可以包括TV广播信号、无线电广播信号、数据广播信号等等。而且,广播信号可以进一步包括与TV或无线电广播信号组合的广播信号。广播相关信息也可以经由移动通信网络提供,并且在该情况下,广播相关信息可以由移动通信模块来接收。广播信号可以以各种形式存在,例如,其可以以数字多媒体广播(DMB)的电子节目指南(EPG)、数字视频广播手持(DVB-H)的电子服务指南(ESG)等等的形式而存在。广播接收模块可以通过使用各种类型的广播系统接收信号广播。特别地,广播接收模块可以通过使用诸如多媒体广播-地面(DMB-T)、数字多媒体广播-卫星(DMB-S)、数字视频广播-手持(DVB-H),前向链路媒体(MediaFLO@)的数据广播系统、地面数字广播综合服务(ISDB-T)等等的数字广播系统接收数字广播。广播接收模块可以被构造为适合提供广播信号的各种广播系统以及上述数字广播系统。经由广播接收模块接收的广播信号和/或广播相关信息可以存储在存储器160(或者其它类型的存储介质)中。
移动通信模块将无线电信号发送到基站(例如,接入点、节点B等等)、外部终端以及服务器中的至少一个和/或从其接收无线电信号。这样的无线电信号可以包括语音通话信号、视频通话信号、或者根据文本和/或多媒体消息发送和/或接收的各种类型的数据。
无线互联网模块支持移动终端的无线互联网接入。该模块可以内部或外部地耦接到终端。该模块所涉及的无线互联网接入技术可以包括WLAN(无线LAN)(Wi-Fi)、Wibro(无线宽带)、Wimax(全球微波互联接入)、HSDPA(高速下行链路分组接入)等等。
短程通信模块是用于支持短程通信的模块。短程通信技术的一些示例包括蓝牙TM、射频识别(RFID)、红外数据协会(IrDA)、超宽带(UWB)、紫蜂TM等等。
位置信息模块是用于检查或获取移动终端的位置信息的模块。位置信息模块的典型示例是GPS(全球定位系统)。根据当前的技术,GPS模块计算来自三个或更多卫星的距离信息和准确的时间信息并且对于计算的信息应用三角测量法,从而根据经度、纬度和高度准确地计算三维当前位置信息。当前,用于计算位置和时间信息的方法使用三颗卫星并且通过使用另外的一颗卫星校正计算出的位置和时间信息的误差。此外,GPS模块能够通过实时地连续计算当前位置信息来计算速度信息。
输入单元120用于接收音频或视频信号。输入单元120可以包括相机121和麦克风122,相机121对在视频捕获模式或图像捕获模式中由图像捕获装置获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元151上。经相机121处理后的图像帧可以存储在存储器160(或其它存储介质)中或者经由无线通信单元110进行发送,可以根据移动终端的构造提供两个或更多相机121。麦克风122可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由移动通信模块发送到移动通信基站的格式输出。麦克风122可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。
用户输入单元130可以根据用户输入的命令生成键输入数据以控制移动终端的各种操作。用户输入单元130允许用户输入各种类型的信息,并且可以包括键盘、锅仔片、触摸板(例如,检测由于被接触而导致的电阻、压力、电容等等的变化的触敏组件)、滚轮、摇杆等等。特别地,当触摸板以层的形式叠加在显示单元151上时,可以形成触摸屏。
感测单元140检测移动终端100的当前状态,(例如,移动终端100的打开或关闭状态)、移动终端100的位置、用户对于移动终端100的接触(即,触摸输入)的有无、移动终端100的取向、移动终端100的加速或减速移动和方向等等,并且生成用于控制移动终端100的操作的命令或信号。例如,当移动终端100实施为滑动型移动电话时,感测单元140可以感测该滑动型电话是打开还是关闭。另外,感测单元140能够检测电源单元190是否提供电力或者接口单元170是否与外部装置耦接。感测单元140可以包括声纹感测器,用于采集用户的声纹信息。
接口单元170用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口、用于连接具有识别模块的装置的端口、音频输入/输出(I/O)端口、视频I/O端口、耳机端口等等。识别模块可以是存储用于验证用户使用移动终端100的各种信息并且可以包括用户识别模块(UIM)、客户识别模块(SIM)、通用客户识别模块(USIM)等等。另外,具有识别模块的装置(下面称为"识别装置")可以采取智能卡的形式,因此,识别装置可以经由端口或其它连接装置与移动终端100连接。接口单元170可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端和外部装置之间传输数据。
另外,当移动终端100与外部底座连接时,接口单元170可以用作允许通过其将电力从底座提供到移动终端100的路径或者可以用作允许从底座输入的各种命令信号通过其传输到移动终端的路径。从底座输入的各种命令信号或电力可以用作用于识别移动终端是否准确地安装在底座上的信号。输出单元150被构造为以视觉、音频和/或触觉方式提供输出信号(例如,音频信号、视频信号、警报信号、振动信号等等)。输出单元150可以包括显示单元151、音频输出模块152、警报单元153等等。
显示单元151可以显示在移动终端100中处理的信息。例如,当移动终端100处于电话通话模式时,显示单元151可以显示与通话或其它通信(例如,文本消息收发、多媒体文件下载等等)相关的用户界面(UI)或图形用户界面(GUI)。当移动终端100处于视频通话模式或者图像捕获模式时,显示单元151可以显示捕获的图像和/或接收的图像、示出视频或图像以及相关功能的UI或GUI等等。
同时,当显示单元151和触摸板以层的形式彼此叠加以形成触摸屏时,显示单元151可以用作输入装置和输出装置。显示单元151可以包括液晶显示器(LCD)、薄膜晶体管LCD(TFT-LCD)、有机发光二极管(OLED)显示器、柔性显示器、三维(3D)显示器等等中的至少一种。这些显示器中的一些可以被构造为透明状以允许用户从外部观看,这可以称为透明显示器,典型的透明显示器可以例如为TOLED(透明有机发光二极管)显示器等等。根据特定想要的实施方式,移动终端100可以包括两个或更多显示单元(或其它显示装置),例如,移动终端可以包括外部显示单元(未示出)和内部显示单元(未示出)。触摸屏可用于检测触摸输入压力以及触摸输入位置和触摸输入面积。
音频输出模块152可以在移动终端处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将无线通信单元110接收的或者在存储器160中存储的音频数据转换音频信号并且输出为声音。而且,音频输出模块152可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出模块152可以包括扬声器、蜂鸣器等等。
警报单元153可以提供输出以将事件的发生通知给移动终端100。典型的事件可以包括呼叫接收、消息接收、键信号输入、触摸输入等等。除了音频或视频输出之外,警报单元153可以以不同的方式提供输出以通知事件的发生。例如,警报单元153可以以振动的形式提供输出,当接收到呼叫、消息或一些其它进入通信(incomingcommunication)时,警报单元153可以提供触觉输出(即,振动)以将其通知给用户。通过提供这样的触觉输出,即使在用户的移动电话处于用户的口袋中时,用户也能够识别出各种事件的发生。警报单元153也可以经由显示单元151或音频输出模块152提供通知事件的发生的输出。
存储器160可以存储由控制器180执行的处理和控制操作的软件程序等等,或者可以暂时地存储己经输出或将要输出的数据(例如,电话簿、消息、静态图像、视频等等)。而且,存储器160可以存储关于当触摸施加到触摸屏时输出的各种方式的振动和音频信号的数据。
存储器160可以包括至少一种类型的存储介质,所述存储介质包括闪存、硬盘、多媒体卡、卡型存储器(例如,SD或DX存储器等等)、随机访问存储器(RAM)、静态随机访问存储器(SRAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、可编程只读存储器(PROM)、磁性存储器、磁盘、光盘等等。而且,移动终端100可以与通过网络连接执行存储器160的存储功能的网络存储装置协作。
控制器180通常控制移动终端的总体操作。例如,控制器180执行与语音通话、数据通信、视频通话等等相关的控制和处理。另外,控制器180可以包括用于再现(或回放)多媒体数据的多媒体模块181,多媒体模块181可以构造在控制器180内,或者可以构造为与控制器180分离。控制器180可以执行模式识别处理,以将在触摸屏上执行的手写输入或者图片绘制输入识别为字符或图像。
电源单元190在控制器180的控制下接收外部电力或内部电力并且提供操作各元件和组件所需的适当的电力。
这里描述的各种实施方式可以以使用例如计算机软件、硬件或其任何组合的计算机可读介质来实施。对于硬件实施,这里描述的实施方式可以通过使用特定用途集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理装置(DSPD)、可编程逻辑装置(PLD)、现场可编程门阵列(FPGA)、处理器、控制器、微控制器、微处理器、被设计为执行这里描述的功能的电子单元中的至少一种来实施,在一些情况下,这样的实施方式可以在控制器180中实施。对于软件实施,诸如过程或功能的实施方式可以与允许执行至少一种功能或操作的单独的软件模块来实施。软件代码可以由以任何适当的编程语言编写的软件应用程序(或程序)来实施,软件代码可以存储在存储器160中并且由控制器180执行。
至此,己经按照其功能描述了移动终端。下面,结合本发明,所述移动终端为一具有显示功能的显示终端,以下所描述的显示终端即为该移动终端100。本发明能够应用于任何类型的显示终端,并且不限于移动式显示终端。
如图1中所示的移动终端100可以被构造为利用经由帧或分组发送数据的诸如有线和无线通信系统以及基于卫星的通信系统来操作。
现在将参考图2描述其中根据本发明的移动终端能够操作的通信系统。
这样的通信系统可以使用不同的空中接口和/或物理层。例如,由通信系统使用的空中接口包括例如频分多址(FDMA)、时分多址(TDMA)、码分多址(CDMA)和通用移动通信系统(UMTS)(特别地,长期演进(LTE))、全球移动通信系统(GSM)等等。作为非限制性示例,下面的描述涉及CDMA通信系统,但是这样的教导同样适用于其它类型的系统。
参考图2,CDMA无线通信系统可以包括多个移动终端100、多个基站(BS)270、基站控制器(BSC)275和移动交换中心(MSC)280。MSC280被构造为与公共电话交换网络(PSTN)290形成接口。MSC280还被构造为与可以经由回程线路耦接到基站270的BSC275形成接口。回程线路可以根据若干己知的接口中的任一种来构造,所述接口包括例如E1/T1、ATM,IP、PPP、帧中继、HDSL、ADSL或xDSL。将理解的是,如图2中所示的系统可以包括多个BSC2750。
每个BS270可以服务一个或多个分区(或区域),由多向天线或指向特定方向的天线覆盖的每个分区放射状地远离BS270。或者,每个分区可以由用于分集接收的两个或更多天线覆盖。每个BS270可以被构造为支持多个频率分配,并且每个频率分配具有特定频谱(例如,1.25MHz,5MHz等等)。
分区与频率分配的交叉可以被称为CDMA信道。BS270也可以被称为基站收发器子系统(BTS)或者其它等效术语。在这样的情况下,术语"基站"可以用于笼统地表示单个BSC275和至少一个BS270。基站也可以被称为"蜂窝站"。或者,特定BS270的各分区可以被称为多个蜂窝站。
如图2中所示,广播发射器(BT)295将广播信号发送给在系统内操作的移动终端100。如图1中所示的广播接收模块111被设置在移动终端100处以接收由BT295发送的广播信号。在图2中,示出了几个全球定位系统(GPS)卫星300。卫星300帮助定位多个移动终端100中的至少一个。
在图2中,描绘了多个卫星300,但是理解的是,可以利用任何数目的卫星获得有用的定位信息。如图1中所示的GPS模块115通常被构造为与卫星300配合以获得想要的定位信息。替代GPS跟踪技术或者在GPS跟踪技术之外,可以使用可以跟踪移动终端的位置的其它技术。另外,至少一个GPS卫星300可以选择性地或者额外地处理卫星DMB传输。
作为无线通信系统的一个典型操作,BS270接收来自各种移动终端100的反向链路信号。移动终端100通常参与通话、消息收发和其它类型的通信。特定基站270接收的每个反向链路信号被在特定BS270内进行处理。获得的数据被转发给相关的BSC275。BSC提供通话资源分配和包括BS270之间的软切换过程的协调的移动管理功能。BSC275还将接收到的数据路由到MSC280,其提供用于与PSTN290形成接口的额外的路由服务。类似地,PSTN290与MSC280形成接口,MSC与BSC275形成接口,并且BSC275相应地控制BS270以将正向链路信号发送到移动终端100。
基于上述移动终端硬件结构以及通信系统,提出本发明系统各个实施例。
首先,本发明提出一种消息处理装置400。
如图3所示,本发明所述的消息处理装置的功能模块示意图。在本实施例中,所述消息处理装置400可以被分割成一个或多个模块,所述一个或多个模块被存储于所述存储器160中,并由一个或多个控制器(本实施例中的所述控制器180)所执行,以完成本发明。例如,在图3中,所述消息处理装置400可以被分割成接收模块401、第一判断模块402、创建模块403、更新模块404。本发明所称的模块是指一种能够完成特定功能的一系列计算机程序指令段,以下将就上述各功能模块401-404的具体功能进行详细描述。
接收模块401,用于接收待处理消息。
需要说明的是,可以由消息服务器集群接收并推送给消息消费者进行处理。当消息处理量大或达到消息处理请求高峰时,消息生产者发送大量消息,消息服务器集群收到大量消息后,经过粗略的分配后发送给消息消费者。
具体地,所述移动终端100可以作为客户端,用于与服务器进行通信,服务器接收到移动终端100发送的数据消息。示例性的,通过客户端安装的APP,如浏览器,在网页打开时通过某一命令向服务器发送连接请求,服务器接收该请求以后形成一条与该消息对应的待处理消息,并将待处理消息发送至消息队列。
或者,消息队列从预先设定的存储区域中获取待处理数据,将数据通过压栈操作(push)进消息队列,消息队列可以按照先进先出的顺序再对待处理消息做出栈操作(pop)。
示例性的,消息队列由服务器集群C发送过来一条待处理消息A,即服务器A将与待处理消息A对应的数据push到消息队列中,待处理消息A在消息队列中进行排队等待处理。
所述第一判断模块402,用于查询索引库,并判断是否存在与所述待处理消息相对应的状态索引。
可以理解的是,可以在待处理消息A在消息队列中排队直到pop出消息队列时,查询索引库,以便获得索引库中是否存在与待处理消息A对应的状态索引。
需要说明的是,索引库为一个存储所有待处理消息或者已处理消息对应的状态索引的库。具体的,索引库中的索引状态可以采用若干能够重点表达待处理消息的信息与表示状态的组合。例如通过关键字信息将索引状态与待处理消息进行对应,再通过索引状态中有关处理进度部分的信息,从而确定对应的待处理消息的处理进度。如,待处理消息A,对应的关键字信息为A',在索引库中查询A',如果差找不到,则表示待处理消息A不存在对应的状态索引。
具体的,查询待处理消息对应的状态索引可以是在待处理消息pop出消息队列的时候,也可以是进入消息队列以后的任一个时刻,本发明实施例在此不对其进行具体限定。
具体的,可以通过二叉树查找法,查询索引库。二叉树查找法通过二叉查找树(Binary Search Tree)进行查找,二叉查找树(又:二叉搜索树,二叉排序树)或者是一棵空树,或者是具有下列性质的二叉树:若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值;若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值;它的左、右子树也分别为二叉排序树。二叉树查找法主要具有快速查找的优点,能够提高待处理消息索引状态的查询效率。
所述创建模块403,用于所述第一判断模块402的判断结果为否的情况下,创建目标状态索引,其中,所述目标状态索引为与所述待处理消息相对应的状态索引。
本发明实施例中,在第一判断模块402判断出不存在与待处理消息相对应的状态索引的情况下,创建一个与待处理消息对应的目标状态索引。
示例性的,为待处理消息A的创建的目标状态索引为A1。具体的,可以通过待处理消息A的关键字信息A'创建目标状态索引A1,如通过A'表达A1;另外目标索引状态A1中还可以包括目前待处理消息A的状态信息。如待处理消息A为未处理状态、或者处理中状态等等。
所述更新模块404,用于根据所述待处理消息的处理结果,更新所述目标状态索引。
具体的,更新模块可以包括:
判断子模块,用于判断所述待处理消息的处理结果是否为处理完成状态;
更新子模块,用于在所述判断子模块的判断结果为是的情况下,更新所述目标状态索引为完成状态。
可以理解的是,在消息队列pop出待处理消息A以后会对待处理消息A进行处理,如消息处理完成,则将包含“处理完成”的信息或者标记发送至目标状态索引中,在目标索引状态中更新待处理消息A的目前状态。如消息正在处理中,且尚未处理完成,则将包含“正在处理中”的信息或者表姐发送至目标状态索引中。
应用本发明图3所示的实施例,相较于现有技术,通过在消息队列中对每一个没有创建状态索引的待处理消息进行创建状态索引,能够及时根据待处理消息的处理结果更新待处理消息对应的目标状态索引。从而实现每一个待处理消息对应一个状态索引,通过追踪状态索引解决了待处理消息丢失的问题。
参见图4所示,图4为本发明所述的消息处理装置的第二种功能模块示意图,在图3所示实施例的基础上增加:过滤模块405;具体的,
过滤模块405,用于所述第一判断模块402的判断结果为是的情况下,则过滤掉所述待处理消息。
需要说明的是,在的第一判断模块402判断出索引库中存在与待处理消息相对应的状态索引,即该待处理消息曾经被时创建过对应的目标状态索引,直接将待处理消息进行过滤,即不处理该待处理消息。
示例性的,待处理消息A,经过第一判断模块402查询以后,发现在索引库中存在与待处理消息A对应的目标状态索引A1,A1的状态可以是待处理,可以是处理中,也可以是已处理完成;不管是出于那一种更状态都采用直接过滤掉待处理消息A,即直接放弃对待处理消息A的处理。
应用本发明图4所示的实施例,能够避免待处理消息的重复处理,直接在索引库中进行查询到对应的状态索引以后,就直接过滤掉该待处理消息,采用本发明实施例提供的技术方案达到了待处理消息的去重目的,以提高待处理消息的处理效率。
参见图5,图5为本发明所述的消息处理装置的第三种功能模块示意图,在图3所示实施例的基础上增加:查询模块501、第二判断模块502、重新处理模块503;其中,
查询模块501,用于根据预设时间,查询所述索引库中的目标状态索引。
需要说明的是,消息队列中pop出来的待处理消息会进行处理,处理的结果通过状态进行反馈,而处理的状态信息从对应的目标状态索引中能够获得。所以可以根据预设的时间,从索引库中查询待处理消息对应的目标状态索引,以获得待处理消息对应的状态。
示例性的,预设时间为10min,在达到预设时间之后,通过查询索引库得知待处理消息A的目标状态索引A1表示待处理消息A仍处于处理中。
第二判断模块502,用于判断所述目标状态索引是否为处理完成状态。
示例性的,由查询模块501可以得到,待处理消息A的目标状态索引为处理中的状态,而并不是完成的状态,因此第二判断模块的判断结果为否。
重新处理模块503,用于在所述第二判断模块的判断结果为否的情况下,重新处理所述目标状态索引对应的所述待处理消息
可以理解的是,经过预设的查询时间,获得待处理消息A仍是处理中的状态,表明目前待处理消息A的处理速度较为滞后,甚至可能出现消息队列中的所有消息处理出现问题。
可以理解的是,待处理消息A经过第二判断模块判断后的结果为否,那么将待处理消息A重新进行处理。可以减少甚至避免待处理消息目前发生处理故障而导致处理较慢的问题。
应用本发明图5所示的实施例,如果在预设时间内待处理消息仍然没有处理完成,则表明目标的消息处理系统的处理能力下降,无法及时完成消息的处理;通过重新处理待处理消息的手段来提高待处理消息的处理效率。
进一步地,本发明还提供了一种消息处理方法,应用于消息队列,如图6所示,是本发明所述的消息处理方法的第一种流程示意图。在本实施例中,所述消息处理方法可以分为以下步骤:
S601,接收待处理消息。
S602,查询索引库,并判断是否存在与所述待处理消息相对应的状态索引;如果否,执行S603。
S603,创建目标状态索引,其中,所述目标状态索引为与所述待处理消息相对应的状态索引。
S604,根据所述待处理消息的处理结果,更新所述目标状态索引。
具体的,所述根据所述待处理消息的处理结果,更新所述目标状态索引,包括:
判断所述待处理消息的处理结果是否为处理完成状态;
如果是,更新所述目标状态索引为完成状态。
具体的,所述第一判断模块,具体用于:
采用二叉树查找方法,查询索引库。
需要说明的是,可以由消息服务器集群接收并推送给消息消费者进行处理。当消息处理量大或达到消息处理请求高峰时,消息生产者发送大量消息,消息服务器集群收到大量消息后,经过粗略的分配后发送给消息消费者。
具体地,所述移动终端100可以作为客户端,用于与服务器进行通信,服务器接收到移动终端100发送的数据消息。示例性的,通过客户端安装的APP,如浏览器,在网页打开时通过某一命令向服务器发送连接请求,服务器接收该请求以后形成一条与该消息对应的待处理消息,并将待处理消息发送至消息队列。
或者,消息队列从预先设定的存储区域中获取待处理数据,将数据通过压栈操作(push)进消息队列,消息队列可以按照先进先出的顺序再对待处理消息做出栈操作(pop)。
示例性的,消息队列由服务器集群C发送过来一条待处理消息A,即服务器A将与待处理消息A对应的数据push到消息队列中,待处理消息A在消息队列中进行排队等待处理。
可以理解的是,可以在待处理消息A在消息队列中排队直到pop出消息队列时,查询索引库,以便获得索引库中是否存在与待处理消息A对应的状态索引。
需要说明的是,索引库为一个存储所有待处理消息或者已处理消息对应的状态索引的库。具体的,索引库中的索引状态可以采用若干能够重点表达待处理消息的信息与表示状态的组合。例如通过关键字信息将索引状态与待处理消息进行对应,再通过索引状态中有关处理进度部分的信息,从而确定对应的待处理消息的处理进度。如,待处理消息A,对应的关键字信息为A',在索引库中查询A',如果差找不到,则表示待处理消息A不存在对应的状态索引。
具体的,查询待处理消息对应的状态索引可以是在待处理消息pop出消息队列的时候,也可以是进入消息队列以后的任一个时刻,本发明实施例在此不对其进行具体限定。
具体的,可以通过二叉树查找法,查询索引库。二叉树查找法通过二叉查找树(Binary Search Tree)进行查找,二叉查找树(又:二叉搜索树,二叉排序树)或者是一棵空树,或者是具有下列性质的二叉树:若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值;若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值;它的左、右子树也分别为二叉排序树。二叉树查找法主要具有快速查找的优点,能够提高待处理消息索引状态的查询效率。
本发明实施例中,在S602判断出不存在与待处理消息相对应的状态索引的情况下,创建一个与待处理消息对应的目标状态索引。
示例性的,为待处理消息A的创建的目标状态索引为A1。具体的,可以通过待处理消息A的关键字信息A'创建目标状态索引A1,如通过A'表达A1;另外目标索引状态A1中还可以包括目前待处理消息A的状态信息。如待处理消息A为未处理状态、或者处理中状态等等。
可以理解的是,在消息队列pop出待处理消息A以后会对待处理消息A进行处理,如消息处理完成,则将包含“处理完成”的信息或者标记发送至目标状态索引中,在目标索引状态中更新待处理消息A的目前状态。如消息正在处理中,且尚未处理完成,则将包含“正在处理中”的信息或者表姐发送至目标状态索引中。
应用本发明图6所示的实施例,相较于现有技术,通过在消息队列中对每一个没有创建状态索引的待处理消息进行创建状态索引,能够及时根据待处理消息的处理结果更新待处理消息对应的目标状态索引。从而实现每一个待处理消息对应一个状态索引,通过追踪状态索引解决了待处理消息丢失的问题。。
进一步地,如图7所示,是本发明所述的消息处理方法的第二种流程示意图。在本实施例中,在图6所示实施例的基础上,在S602的判断结果为是的情况下,增加S701。
S701,如果存在与所述待处理消息相对应的状态索引,则过滤掉所述待处理消息。
可以理解的是,该步骤的目的,是要保证待处理消息与状态索引达到一一对应的目的,不可以一个待处理消息对应不止一个状态索引,也不可以不止一个待处理消息对应一个状态索引,避免在后续的状态判断过程中产生混乱。
应用本发明图7所示的实施例,能够避免待处理消息的重复处理,直接在索引库中进行查询到对应的状态索引以后,就直接过滤掉该待处理消息,采用本发明实施例提供的技术方案达到了待处理消息的去重目的,以提高待处理消息的处理效率。
进一步地,如图8所示,是本发明所述的消息处理方法的第三种流程示意图。在本实施例中,在图6所示实施例的基础上,增加S801、S802、S803;其中,
S801,根据预设时间,查询所述索引库中的目标状态索引。
S802,判断所述目标状态索引是否为处理完成状态,如果否,执行S803。
S803,重新处理所述目标状态索引对应的所述待处理消息。
需要说明的是,消息队列中pop出来的待处理消息会进行处理,处理的结果通过状态进行反馈,而处理的状态信息从对应的目标状态索引中能够获得。所以可以根据预设的时间,从索引库中查询待处理消息对应的目标状态索引,以获得待处理消息对应的状态。
示例性的,预设时间为10min,在达到预设时间之后,通过查询索引库得知待处理消息A的目标状态索引A1表示待处理消息A仍处于处理中。
示例性的,由通过查询待处理消息对应的状态索引可以得到,待处理消息A的目标状态索引为处理中的状态,而并不是完成的状态,因此第二判断模块的判断结果为否。
可以理解的是,经过预设的查询时间,获得待处理消息A仍是处理中的状态,表明目前待处理消息A的处理速度较为滞后,甚至可能出现消息队列中的所有消息处理出现问题。
可以理解的是,待处理消息A经过第二判断模块判断后的结果为否,那么将待处理消息A重新进行处理。可以减少甚至避免待处理消息目前发生处理故障而导致处理较慢的问题。
应用本发明图8所示的实施例,如果在预设时间内待处理消息仍然没有处理完成,则表明目标的消息处理系统的处理能力下降,无法及时完成消息的处理;通过重新处理待处理消息的手段来提高待处理消息的处理效率。
本发明实施例还提供了一种终端,包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的消息处理程序,所述消息处理程序被所述处理器执行时实现如权利要求6至9中任一项所述的消息处理方法的步骤。
参见图9,图9为本发明所述的消息处理结果提示图,在预设时间10分钟内,待处理消息A仍然处理失败,为了保证消息是否继续处理,询问管理员,或者依据管理员设定的规则进行是或者否处理。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,空调器,或者网络设备,机器人等)执行本发明各个实施例所述的方法。
以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本发明的专利保护范围内。
Claims (10)
1.一种消息处理装置,应用于消息队列,其特征在于,所述装置包括:
接收模块,用于接收待处理消息;
第一判断模块,用于查询索引库,并判断是否存在与所述待处理消息相对应的状态索引;
创建模块,用于所述第一判断模块的判断结果为否的情况下,创建目标状态索引,其中,所述目标状态索引为与所述待处理消息相对应的状态索引;
更新模块,用于根据所述待处理消息的处理结果,更新所述目标状态索引。
2.根据权利要求1所述的消息处理装置,其特征在于,所述装置还包括:
过滤模块,用于所述第一判断模块的判断结果为是的情况下,则过滤掉所述待处理消息。
3.根据权利要求1或2所述的消息处理装置,其特征在于,所述装置还包括:
查询模块,用于根据预设时间,查询所述索引库中的目标状态索引;
第二判断模块,用于判断所述目标状态索引是否为处理完成状态;
重新处理模块,用于在所述第二判断模块的判断结果为否的情况下,重新处理所述目标状态索引对应的所述待处理消息。
4.根据权利要求1所述的消息处理装置,其特征在于,所述更新模块,包括:
判断子模块,用于判断所述待处理消息的处理结果是否为处理完成状态;
更新子模块,用于在所述判断子模块的判断结果为是的情况下,更新所述目标状态索引为完成状态。
5.根据权利要求1所述的消息处理装置,其特征在于,所述第一判断模块,具体用于:
采用二叉树查找方法,查询索引库。
6.一种消息处理方法,应用于消息队列,其特征在于,所述方法包括:
接收待处理消息;
查询索引库,并判断是否存在与所述待处理消息相对应的状态索引;
如果不存在与所述待处理消息相对应的状态索引,创建目标状态索引,其中,所述目标状态索引为与所述待处理消息相对应的状态索引;
根据所述待处理消息的处理结果,更新所述目标状态索引。
7.根据权利要求6所述的消息处理方法,其特征在于,所述方法还包括:
如果存在与所述待处理消息相对应的状态索引,则过滤掉所述待处理消息。
8.根据权利要求6或7所述的消息处理方法,其特征在于,所述方法还包括:
根据预设时间,查询所述索引库中的目标状态索引;
判断所述目标状态索引是否为处理完成状态;
如果否,重新处理所述目标状态索引对应的所述待处理消息。
9.根据权利要求6所述的消息处理方法,其特征在于,所述根据所述待处理消息的处理结果,更新所述目标状态索引,包括:
判断所述待处理消息的处理结果是否为处理完成状态;
如果是,更新所述目标状态索引为完成状态。
10.一种终端,其特征在于,包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的消息处理程序,所述消息处理程序被所述处理器执行时实现如权利要求6至9中任一项所述的消息处理方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710286833.2A CN107133111A (zh) | 2017-04-27 | 2017-04-27 | 一种消息处理装置及方法 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710286833.2A CN107133111A (zh) | 2017-04-27 | 2017-04-27 | 一种消息处理装置及方法 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN107133111A true CN107133111A (zh) | 2017-09-05 |
Family
ID=59715425
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710286833.2A Pending CN107133111A (zh) | 2017-04-27 | 2017-04-27 | 一种消息处理装置及方法 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN107133111A (zh) |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108762944A (zh) * | 2018-04-20 | 2018-11-06 | 北京奇艺世纪科技有限公司 | 一种业务系统的处理方法、装置、设备及介质 |
CN108762953A (zh) * | 2018-05-25 | 2018-11-06 | 连云港杰瑞电子有限公司 | 一种消息队列实现方法 |
CN110321232A (zh) * | 2018-03-30 | 2019-10-11 | 阿里巴巴集团控股有限公司 | 消息的处理方法、装置及电子设备 |
CN110895490A (zh) * | 2019-11-29 | 2020-03-20 | 深圳乐信软件技术有限公司 | 一种数据批量处理系统、方法、设备和存储介质 |
CN113641515A (zh) * | 2021-08-02 | 2021-11-12 | 北京达佳互联信息技术有限公司 | 一种消息处理方法、装置、系统、电子设备和存储介质 |
CN114491137A (zh) * | 2022-02-15 | 2022-05-13 | 平安科技(深圳)有限公司 | 数据存储方法、相关设备及介质 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104102552A (zh) * | 2013-04-15 | 2014-10-15 | 深圳中兴网信科技有限公司 | 一种消息处理方法及装置 |
CN105740083A (zh) * | 2016-01-28 | 2016-07-06 | 努比亚技术有限公司 | 消息处理方法、装置及系统 |
CN105871966A (zh) * | 2015-09-22 | 2016-08-17 | 乐视网信息技术(北京)股份有限公司 | 消息分发的方法、装置及系统 |
-
2017
- 2017-04-27 CN CN201710286833.2A patent/CN107133111A/zh active Pending
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104102552A (zh) * | 2013-04-15 | 2014-10-15 | 深圳中兴网信科技有限公司 | 一种消息处理方法及装置 |
CN105871966A (zh) * | 2015-09-22 | 2016-08-17 | 乐视网信息技术(北京)股份有限公司 | 消息分发的方法、装置及系统 |
CN105740083A (zh) * | 2016-01-28 | 2016-07-06 | 努比亚技术有限公司 | 消息处理方法、装置及系统 |
Cited By (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110321232A (zh) * | 2018-03-30 | 2019-10-11 | 阿里巴巴集团控股有限公司 | 消息的处理方法、装置及电子设备 |
CN110321232B (zh) * | 2018-03-30 | 2024-01-09 | 阿里巴巴集团控股有限公司 | 消息的处理方法、装置及电子设备 |
CN108762944A (zh) * | 2018-04-20 | 2018-11-06 | 北京奇艺世纪科技有限公司 | 一种业务系统的处理方法、装置、设备及介质 |
CN108762944B (zh) * | 2018-04-20 | 2021-02-12 | 北京奇艺世纪科技有限公司 | 一种业务系统的处理方法、装置、设备及介质 |
CN108762953A (zh) * | 2018-05-25 | 2018-11-06 | 连云港杰瑞电子有限公司 | 一种消息队列实现方法 |
CN110895490A (zh) * | 2019-11-29 | 2020-03-20 | 深圳乐信软件技术有限公司 | 一种数据批量处理系统、方法、设备和存储介质 |
CN113641515A (zh) * | 2021-08-02 | 2021-11-12 | 北京达佳互联信息技术有限公司 | 一种消息处理方法、装置、系统、电子设备和存储介质 |
CN114491137A (zh) * | 2022-02-15 | 2022-05-13 | 平安科技(深圳)有限公司 | 数据存储方法、相关设备及介质 |
CN114491137B (zh) * | 2022-02-15 | 2024-03-26 | 平安科技(深圳)有限公司 | 数据存储方法、相关设备及介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107133111A (zh) | 一种消息处理装置及方法 | |
CN106302385B (zh) | 一种消息分发装置及方法 | |
CN105282245B (zh) | 跨服务器消息推送系统及方法 | |
CN105159533A (zh) | 一种移动终端及其验证码自动输入方法 | |
CN106941443A (zh) | 一种群历史记录查看终端和方法 | |
CN105262819B (zh) | 一种移动终端及其实现推送的方法 | |
CN105718071A (zh) | 输入法中推荐联想词汇的终端及方法 | |
CN104735255A (zh) | 分屏显示方法和系统 | |
CN104881219B (zh) | 一种移动终端及其边框辅助输入方法和装置 | |
CN105897995B (zh) | 一种添加联系人信息的方法和装置 | |
CN106155694A (zh) | 一种应用与分身应用的显示方法和装置 | |
CN105099875A (zh) | 多用户协作编辑与发布图片信息的方法和装置 | |
CN105262821A (zh) | 接口管理装置和方法 | |
CN107132931A (zh) | 一种搜索方法及服务器 | |
CN106803860A (zh) | 一种终端应用的存储处理方法和装置 | |
CN106254617B (zh) | 一种移动终端及控制方法 | |
CN104679890A (zh) | 图片推送方法及装置 | |
CN105263195A (zh) | 数据传输装置及方法 | |
CN106909681A (zh) | 一种信息处理方法及其装置 | |
CN106446096A (zh) | 一种文件分享方法、装置及终端 | |
CN105099701A (zh) | 一种终端及终端鉴权的方法 | |
CN104780278B (zh) | 基于通信数据的路线生成方法及装置 | |
CN104980576A (zh) | 移动终端自动提取号码的方法及装置 | |
CN104967749A (zh) | 一种处理图文信息的装置和方法 | |
CN106332028A (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 | ||
RJ01 | Rejection of invention patent application after publication | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20170905 |