CN106549796A - 一种固件空间下载的资源控制方法及主节点 - Google Patents
一种固件空间下载的资源控制方法及主节点 Download PDFInfo
- Publication number
- CN106549796A CN106549796A CN201610857189.5A CN201610857189A CN106549796A CN 106549796 A CN106549796 A CN 106549796A CN 201610857189 A CN201610857189 A CN 201610857189A CN 106549796 A CN106549796 A CN 106549796A
- Authority
- CN
- China
- Prior art keywords
- node
- queue
- resource
- global
- message queue
- 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
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/06—Management of faults, events, alarms or notifications
- H04L41/0654—Management of faults, events, alarms or notifications using network fault recovery
- H04L41/0663—Performing the actions predefined by failover planning, e.g. switching to standby network elements
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/08—Configuration management of networks or network elements
- H04L41/0803—Configuration setting
- H04L41/0813—Configuration setting characterised by the conditions triggering a change of settings
- H04L41/082—Configuration setting characterised by the conditions triggering a change of settings the condition being updates or upgrades of network functionality
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L43/00—Arrangements for monitoring or testing data switching networks
- H04L43/10—Active monitoring, e.g. heartbeat, ping or trace-route
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/10—Flow control; Congestion control
- H04L47/12—Avoiding congestion; Recovering from congestion
- H04L47/125—Avoiding congestion; Recovering from congestion by balancing the load, e.g. traffic engineering
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L47/00—Traffic control in data switching networks
- H04L47/50—Queue scheduling
- H04L47/62—Queue scheduling characterised by scheduling criteria
- H04L47/622—Queue service order
- H04L47/6235—Variable service order
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Health & Medical Sciences (AREA)
- Cardiology (AREA)
- General Health & Medical Sciences (AREA)
- Computer And Data Communications (AREA)
Abstract
本发明公开了一种固件空间下载的资源控制方法及主节点。在一个中间件***中通过选取一个主节点,该主节点可以接收资源更新请求,主节点根据该资源更新请求,对全局资源列表进行更新处理,根据相应的分配原则将需要分配的消息队列分配到对应的节点,为需要分配消息队列的节点分配相应的消息队列,无需重启便可完成资源的重新配置。可以解决现有中间件***各节点中间件之间相互独立,对节点或消息队列的配置只能固定配置,导致新增节点时无对应消息队列可分配,删除节点时,该删除节点所负责的消息队列没有其他节点帮忙处理,无法根据需要增删节点,要改变资源配置就只能通过重启这一技术问题。
Description
技术领域
本发明涉及网络通信技术领域,更具体地说,涉及一种固件空间下载的资源控制方法及主节点。
背景技术
中间件是一类在操作***、网络和数据库之上,应用软件下层的软件。总的作用是为处于自己上层的应用软件提供运行与开发的环境。例如FOTA(Firmware Over-The-Air,移动终端的空中下载软件升级)-MOM(Message-Oriented Middleware,面向消息的中间件)是用于异步延迟存储,将FOTA在协议交互过程中对数据库的同步读写操作,转化为异步延迟处理,提高FOTA服务器的交互并发性能,并解耦依赖,如图1所示的FOTA-MOM中间件***,有2个节点中间件,redis集群中有多个redis队列,每个节点负责部分redis队列。但是当前中间件***中的各节点中间件之间是相互独立的,导致中间件***中节点中间件以及各节点中间件上承载的消息队列的配置都是固定的,需要对节点中间件或者消息队列配置进行更新时,就需要重启各节点中间件进行重新配置。例如FOTA-MOM***就存在上述问题,在FOTA-MOM***中新增或删除节点中间件时,节点中间件无法获得***内新增或删除节点中间件信息,导致新增节点中间件时无对应消息队列可分配,删除节点中间件时,被删除的节点中间件所负责的消息队列没有其他节点中间件帮忙处理,无法灵活的根据需要更新节点中间件,同样,在FOTA-MOM***中增加消息队列时也不能及时动态的将新增的队列分配到匹配的节点中间件上执行,只能通过重启FOTA-MOM***进行重新配置。
发明内容
本发明要解决的技术问题在于:现有中间件***各节点中间件之间相互独立,对节点中间件或消息队列的配置只能固定配置,要更新资源配置就只能通过重启。针对该技术问题,提供一种基于固件空间下载的资源控制方法及主节点。
为解决上述技术问题,本发明提供一种固件空间下载的资源控制方法,所述方法包括:
主节点接收资源更新请求,所述资源更新请求包括请求更新节点的节点更新请求和请求更新队列的队列更新请求中的至少一种;所述主节点为中间件***中的一个节点中间件,所述中间件***中的其他节点中间件为普通节点;
所述主节点根据全局资源列表对所述资源更新请求所请求更新的资源进行更新处理;所述全局资源列表包括:包含所述各普通节点信息的全局节点表和包含所述中间件***当前承载的消息队列的全局队列表。
进一步地,本发明提供了一种固件空间下载的资源控制方法,所述方法包括:
所述资源更新请求包括节点更新请求时,所述节点更新请求包括增加节点和删除节点中的至少一种;
所述主节点根据所述全局资源列表完成节点更新包括:
所述节点更新请求包括增加节点时,在所述全局节点表中增加新增的普通节点;
所述节点更新请求包括删除节点时,在所述全局节点表中删除对应的普通节点。
进一步地,本发明提供了一种固件空间下载的资源控制方法,所述方法包括:
所述全局节点表中包含各普通节点的节点地址以及承载的消息队列;
所述主节点在所述全局节点表中增加新增的普通节点包括:在所述全局节点表中增加该普通节点地址以及承载的消息队列;
所述主节点在所述全局节点表中删除对应的普通节点包括:在所述全局节点表中删除该普通节点地址以及承载的消息队列,回收并重新分配该普通节点所承载的消息队列。
进一步地,本发明提供了一种固件空间下载的资源控制方法,所述方法包括:
所述主节点在所述全局节点表中增加普通节点后,在增加的普通节点承载的消息队列为空时,从所述全局队列表中择对应的消息队列分配给该普通节点。
进一步地,本发明提供了一种固件空间下载的资源控制方法,所述方法包括:
所述资源更新请求包括队列更新请求时,所述队列更新请求包括增加队列和删除队列中的至少一种;
所述主节点根据所述全局资源列表完成队列更新包括:
所述队列更新请求包括增加队列时,在所述全局队列表中增加新增的消息队列;
所述队列更新请求包括删除队列时,在所述全局队列表中删除对应的消息队列。
进一步地,本发明提供了一种固件空间下载的资源控制方法,所述方法包括:
所述全局队列表中包含各消息队列的队列标识和分配状态;
所述主节点在所述全局节点表中增加新增的消息队列包括:在所述全局节点表中增加该消息队列标识以及对应的分配状态;
所述主节点在所述全局节点表中删除对应的消息队列包括:在所述全局队列表中删除该消息队列对应的队列标识和分配状态,并根据该分配状态通知当前承载该消息队列的节点停止处理该消息队列。
进一步地,本发明提供了一种固件空间下载的资源控制方法,所述方法包括:
所述主节点在所述全局队列表中增加消息队列后,在该消息队列的分配状态为未分配时,根据所述全局节点表中各普通节点当前的承载状态,将新增的所述消息队列分配到所述全局节点表中相匹配的普通节点上。
进一步地,本发明提供了一种固件空间下载的资源控制方法,所述方法包括:
所述主节点监测所述各普通节点的运行状态;
所述主节点在监测到某一普通节点故障时,在所述全局节点表中删除该普通节点,回收并重新分配该普通节点承载的消息队列。
进一步地,本发明提供了一种固件空间下载的资源控制方法,所述方法包括:
所述主节点根据全局资源列表对所述资源更新请求所请求更新的资源进行更新处理包括:
将在预设时间段内接收到的资源更新请求进行分类合并存储;
在所述预设时间段到达时,根据所述全局资源列表对该预设时间段内分类合并存储的资源更新请求所请求更新的资源进行更新处理。
进一步地,本发明提供了一种固件空间下载的资源控制方法,所述方法包括:
监测到所述主节点故障时,根据主节点选择规则从所述全局节点表中的各普通点中选择出一个作为新的主节点,并删除所述故障的主节点,以及回收并重新分配该故障的主节点所承载的消息队列。
进一步地,本发明提供了一种固件空间下载的资源控制方法,所述方法还包括:
所述资源更新请求为第三方通过所述主节点提供的第三方通信接口发给所述主节点,或由普通节点直接发给所述主节点。
进一步地,本发明提供了一种固件空间下载的主节点,所述主节点为中间件***中的一个节点中间件,所述中间件***中的其他节点中间件为普通节点;所述主节点包括:
请求处理模块,用于接收资源更新请求,所述资源更新请求包括请求更新节点的节点更新请求和请求更新队列的队列更新请求中的至少一种;
资源更新模块,用于全局资源列表对所述资源更新请求所请求更新的资源进行更新处理;所述全局资源列表包括:包含所述各普通节点信息的全局节点表和包含所述中间件***当前承载的消息队列的全局队列表。
进一步地,本发明还提供了一种固件空间下载的主节点,其特征在于,所述主节点还包括:
监测模块,用于监测所述各普通节点的运行状态,并在监测到某一普通节点故障时,通知所述资源更新模块;
所述资源更新模块还用于在所述全局节点表中删除所述故障的普通节点,回收并重新分配该故障的普通节点承载的消息队列。
有益效果
本发明提供一种基于固件空间下载的资源控制方法及主节点,将中间件***中的一个节点中间件作为主节点,其他的节点中间件作为普通节点;主节点可以维护包含全局节点表和全局队列表的全局资源列表。主节点可以接收资源更新请求,该资源更新请求包含节点更新请求和队列更新请求的至少一种,根据全局资源列表对该资源更新请求所请求更新的资源进行更新处理,包括增加或者删除相应的节点和/或消息队列。本发明通过在中间件***中设置可以维护***内全局资源列表的主节点,通过主节点基于维护的全局资源列表实现对节点和/或消息队列等资源的动态更新,克服了现有中间件***中各节点中间件相互独立,无法动态更新资源配置,只能通过重启的方式实现资源更新的问题。
附图说明
下面将结合附图及实施例对本发明作进一步说明,附图中:
图1为一种FOTA-MOM中间件***结构示意图;
图2实现本发明各个实施例一个可选的移动终端的硬件结构示意图;
图3为实现本发明各个实施例一个可选的服务器的结构示意图;
图4为本发明第一实施例提供的主节点处理资源更新请求的流程示意图;
图5为本发明第二实施例提供的当资源更新请求包括节点更新请求时的流程示意图;
图6为本发明第三实施例提供的当资源更新请求包括队列更新请求时的流程示意图;
图7为本发明第四实施例提供的心跳检测的流程示意图;
图8位本发明第四实施例提供的心跳反馈流程示意图;
图9为本发明第四实施例提供的心跳反馈超时的流程示意图;
图10为本发明第四实施例提供的节点调整流程示意图;
图11为本发明第四实施例提供的主节点故障处理的流程示意图;
图12为本发明第五实施例提供的固件空间下载的主节点结构示意图;
图13本发明第六实施例提供的固件空间下载的主节点结构示意图。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
现在将参考附图描述实现本发明各个实施例的移动终端。在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身并没有特定的意义。因此,"模块"与"部件"可以混合地使用。
移动终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如移动电话、智能电话、笔记本电脑、数字广播接收器、PDA(个人数字助理)、PAD(平板电脑)、PMP(便携式多媒体播放器)、导航装置等等的移动终端以及诸如数字TV、台式计算机等等的固定终端。下面,假设终端是移动终端,然而,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。
图2为实现本发明各个实施例一个可选的移动终端的硬件结构示意图。
移动终端100可以包括无线通信单元110、A/V(音频/视频)输入单元120、用户输入单元130、感测单元140、输出单元150、存储器160、接口单元170、控制器180和电源单元190等等。图2示出了具有各种组件的移动终端,但是应理解的是,并不要求实施所有示出的组件。可以替代地实施更多或更少的组件。将在下面详细描述移动终端的元件。
无线通信单元110通常包括一个或多个组件,其允许移动终端100与无线通信***或网络之间的无线电通信。例如,无线通信单元可以包括广播接收模块、移动通信模块、无线互联网模块、短程通信模块和位置信息模块中的至少一个。
A/V输入单元120用于接收音频或视频信号。A/V输入单元120可以包括相机和麦克风,相机对在视频捕获模式或图像捕获模式中由图像捕获装置获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示模块上。经相机处理后的图像帧可以存储在存储器160(或其它存储介质)中或者经由无线通信单元110进行发送,可以根据移动终端的构造提供两个或更多相机。麦克风可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由移动通信模块发送到移动通信基站的格式输出。麦克风可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。
用户输入单元130可以根据用户输入的命令生成键输入数据以控制移动终端的各种操作。用户输入单元130允许用户输入各种类型的信息,并且可以包括键盘、锅仔片、触摸板(例如,检测由于被接触而导致的电阻、压力、电容等等的变化的触敏组件)、滚轮、摇杆等等。特别地,当触摸板以层的形式叠加在显示模块上时,可以形成触摸屏。
感测单元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可以包括显示模块、音频输出模块、警报模块等等。
存储器160可以存储由控制器180执行的处理和控制操作的软件程序等等,或者可以暂时地存储己经输出或将要输出的数据(例如,电话簿、消息、静态图像、视频等等)。而且,存储器160可以存储关于当触摸施加到触摸屏时输出的各种方式的振动和音频信号的数据。
存储器160可以包括至少一种类型的存储介质,所述存储介质包括闪存、硬盘、多媒体卡、卡型存储器(例如,SD或DX存储器等等)、随机访问存储器(RAM)、静态随机访问存储器(SRAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、可编程只读存储器(PROM)、磁性存储器、磁盘、光盘等等。而且,移动终端100可以与通过网络连接执行存储器160的存储功能的网络存储装置协作。
控制器180通常控制移动终端的总体操作。例如,控制器180执行与语音通话、数据通信、视频通话等等相关的控制和处理。另外,控制器180可以包括用于再现(或回放)多媒体数据的多媒体模块1810,多媒体模块可以构造在控制器180内,或者可以构造为与控制器180分离。控制器180可以执行模式识别处理,以将在触摸屏上执行的手写输入或者图片绘制输入识别为字符或图像。
电源单元190在控制器180的控制下接收外部电力或内部电力并且提供操作各元件和组件所需的适当的电力。
这里描述的各种实施方式可以以使用例如计算机软件、硬件或其任何组合的计算机可读介质来实施。对于硬件实施,这里描述的实施方式可以通过使用特定用途集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理装置(DSPD)、可编程逻辑装置(PLD)、现场可编程门阵列(FPGA)、处理器、控制器、微控制器、微处理器、被设计为执行这里描述的功能的电子单元中的至少一种来实施,在一些情况下,这样的实施方式可以在控制器180中实施。对于软件实施,诸如过程或功能的实施方式可以与允许执行至少一种功能或操作的单独的软件模块来实施。软件代码可以由以任何适当的编程语言编写的软件应用程序(或程序)来实施,软件代码可以存储在存储器中并且由控制器180执行。
如图3所示,为实现本发明各个实施例一个可选的服务器的结构示意图,该服务器至少包括:输入输出(IO)总线21、处理器22、存储器23、内存24和通信装置25。其中,
输入输出(IO)总线21分别与自身所属的服务器的其它部件(处理器22、存储器23、内存24和通信装置25)连接,并且为其它部件提供传送线路。
处理器22通常控制自身所属的服务器的总体操作。例如,处理器22执行计算和确认等操作。其中,处理器22可以是中央处理器(CPU)。
存储器23存储处理器可读、处理器可执行的软件代码,其包含用于控制处理器22执行本文描述的功能的指令(即软件执行功能)。
其中,本发明提供的主节点的请求处理模块、资源更新模块、检测模块等的功能的软件代码可存储在存储器23中,并由处理器22执行或编译后执行。
内存24,一般采用半导体存储单元,包括随机存储器(RAM),只读存储器(ROM),以及高速缓存(CACHE),RAM是其中最重要的存储器。内存24是计算机中重要的部件之一,它是与CPU22进行沟通的桥梁,计算机中所有程序的运行都是在内存中进行的,其作用是用于暂时存放CPU22中的运算数据,以及与硬盘等外部存储器交换的数据,只要计算机在运行中,CPU22就会把需要运算的数据调到内存中进行运算,当运算完成后CPU22再将结果传送出来。
通信装置25,通常包括一个或多个组件,其允许自身所属的服务器与无线通信***或网络之间的无线电通信。
以下通过具体实施例进行详细说明。
第一实施例
本实施例为解决当前节点中间件资源配置固定,不能进行动态扩容,只能进行重启才能完成节点与消息队列的重新分配问题,提供一种固件空间下载的资源控制方法,参照图4所示,包括:
S301:主节点接收资源更新请求。
本实施例中的资源更新请求包括请求更新节点的节点更新请求和请求更新队列的队列更新请求中的至少一种,具体包含哪些更新请求可以根据实际应用场景和具体需求灵活设定。本实施例中的主节点为中间件***中的一个节点中间件,中间件***中的其他节点中间件为普通节点。当应当理解的是,本实施例中的主节点可以动态更新,也可以设置为一个固定的节点中间件。
S302:主节点根据全局资源列表对资源更新请求所请求更新的资源进行更新处理。
本实施例中的全局资源列表包括:包含各普通节点信息的全局节点表和包含中间件***当前承载的消息队列的全局队列表。主节点可以动态的对该全局资源列表进行维护,以实现对中间件***中的节点和消息队列等资源配置的动态更新。
本实施例中的,资源更新请求可以由第三方直接向主节点发送,也可以由中间***中的其他普通节点直接向主节点发送。
资源更新请求由第三方发送时,主节点可提供一第三方接口,第三方通过该第三方接口向主节点发送资源更新请求,本实施例中的资源包括但不限于节点和消息队列。
本实施例中的资源更新请求包括节点更新请求时,该节点更新请求可以包含新增节点和/或删除节点,本实施例中的资源更新请求包括队列更新请求时,该队列更新请求可以包含新增队列和/或删除队列。
本实施例中的节点更新请求中包含需要添加和/或删除的节点信息。节点信息包含节点地址以及该节点负责的消息队列,本实施例中的节点地址包括但不限于节点IP和节点接口。例如,一种节点信息表示方式为:
[节点IP,节点Port,负责的消息队列名列表]
应当说明的是,当新增节点时,可以在该新增节点信息表中携带该节点启动后需要分配的消息队列,即此时负责的消息队列名列表中包含该新增节点启动后需要分配的消息队列,当然也可能为空。当删除节点时,该负责的消息队列名列表中包含该删除节点负责的所有消息队列,主节点对该节点进行删除后,会对消息队列进行回收分配处理。
队列更新请求中包含需要添加和/或删除的队列信息,队列信息中包括但不限于队列标识以及对应的分配状态,还可包括队列的处理类别。本实施例中队列标识可以用消息队列名表征。队列信息的一种表示可以为:
[消息队列名,处理类别名,is_used(是否已被分配处理的分配状态)]
本实施例中对于节点和队列的增加和删除在***中可以定义对应的命令码和字符串进行表征,例如表1所示:
表1
基于上述列表,本实施例中的节点信息列表:对于NODE_ADD和NODE_DEL为ip:port形式的字符串队列对于REDIS_ADD和REDIS_DEL为redis队列名队列。
当资源更新请求为第三方接口向主节点发送的时,本实施例中可以在***中定义主节点向第三方反馈的编码的含义,参见表2所示:
表2
错误码 | 含义 |
0x01 | 成功 |
0x02 | 失败 |
0x03 | json解析失败 |
0x04 | 该节点不是主节点 |
0x05 | 该节点不是普通节点 |
应当理解的是,主节点实质上也是一个普通节点,主节点也是在普通节点中选取的,但主节点具有维护全局资源列表和更新全局资源列表的功能。在一个中间件***中,除了一个主节点外,其余节点为普通节点。本实施例中的节点具体可由工作站、网络传真机、网络打印机、档案服务器、通信终端等构成。应当理解的是,本实施例中的消息队列包括但不限于redis队列。
主节点接收到资源更新请求,该节点更新请求可以包含新增节点和/或删除节点时,对相应资源进行更新处理包括但不限于:在全局节点表中删除对应的普通节点和/或在全局节点表中增加新增的普通节点,并还可进一步为增加的普通节点分配消息队列;当资源更新请求包括队列更新请求时,对相应资源进行更新处理包括但不限于在全局队列表中删除对应的消息队列和/或在全局队列表中增加新增的消息队列,并根据相应的分配原则将需要分配的消息队列分配到对应的节点。
主节点在全局节点表中增加新增的普通节点包括:在全局节点表中增加该普通节点地址以及承载的消息队列。节点地址包括但不限于节点IP、节点接口。应当说明的是,初始时新增的普通节点承载的消息队列可能为空,第三方也可能直接为该普通节点分配了对应的消息队列。
主节点在全局节点表中删除对应的普通节点包括:在全局节点表中删除该普通节点地址以及承载的消息队列,回收并重新分配该普通节点所承载的消息队列。
主节点在全局队列表中增加新增的消息队列包括:在全局队列表中增加该消息队列标识以及对应的分配状态。应当说明的是,分配状态可以包括“已分配”和“未分配”两种状态,当消息队列分配状态为“未分配”时,主节点将其分配到相应的普通节点。
主节点在全局队列表中删除对应的消息队列包括:在全局队列表中删除该消息队列对应的队列标识和分配状态,并根据该分配状态通知当前承载该消息队列的节点停止处理该消息队列。
其中,全局节点表包含当前中间件***的所有普通节点信息,普通节点信息包括但不限于所有普通节点的节点IP、节点接口、所负责的消息队列列表;当主节点对普通节点运行状态有监测时,还可包括最近一次的监测状态,例如通过心跳监测时,包括最后收到hearbeat反馈时间。
全局节点表中某一节点信息的一种表示方式如下:
[节点IP,节点Port,负责的消息队列名列表,最近一次监测状态]
全局队列表包含当前中间件***承载的消息队列信息,消息队列信息包括但不限于消息队列名称,处理类别名,is used(是否已被分配处理),全局队列表包括但不限于以下方式表示:
[消息队列名,处理类别名,is_used(是否已被分配处理)]
应当说明的是,全局资源列表包括但不限于存储在主节点本地中或者其他适合的地方,适合的地方包括但不限于服务器数据库中,而且当全局资源列表需要进行更新时主节点可以随时调用。
相应的分配原则包括但不限于平均分配原则、随机分配原则以及负载平衡分配原则。被分配的消息队列可以是分配状态为“未分配”的队列,也可以是分配状态为“已分配”的队列,也即分配时,包括但不限于从当前分配状态为“未分配”的消息队列中选;也可以是从“已分配”的消息队列中调整。具体的,需要分配的消息队列可以是当前分配状态为未分配的消息队列,也可以是某一普通节点当前所承载的消息队列较多的该普通节点。需要分配消息队列的普通节点可以是当前承载的消息队列为空的普通节点,也可以是当前承载的消息队列较少的普通节点。
应当理解的是,普通节点与其所负责的消息队列的处理类别应该相匹配。
应当说明的是,在步骤S301之前,还可进行主节点的选取过程。选择的主体可以是通过后台管理设备(例如服务器)进行选择,也可以是由全局节点表中的各普通节点自推荐选择。选择的原则可以是根据各普通节点的健康程度进行选择,选择最健康的节点作为主节点。健康程度可以通过各节点当前负荷情况(包括但不限于承载消息队列情况)、通信环境、自身处理能力等决定。
本实施例通过在一个中间件***中通过选取一个主节点,该主节点提供一种供第三方发送资源更新请求的接口来接收该资源更新请求,该资源更新请求中包括节点更新请求和/或队列更新请求,节点更新请求包括新增节点和/或删除节点,队列更新请求包括新增队列和/或删除队列。主节点根据全局资源列表对资源更新请求所请求更新的资源进行更新处理。全局资源列表中包括:包含各普通节点信息的全局节点表和包含中间件***当前承载的消息队列的全局队列表。基于上述实施例,可以解决现有中间件***各节点中间件之间相互独立,对节点或消息队列的配置只能固定配置,导致新增节点时无对应消息队列可分配,删除节点时,该删除节点所负责的消息队列没有其他节点帮忙处理,无法根据需要灵活增删节点,要更新资源配置就只能通过重启这一技术问题。
第二实施例
基于第一实施例可知,本发明中的资源更新请求可包括节点更新请求、队列更行请求、以及节点更新请求和队列更行请求这三种情形,为了更好的理解,本实施例结合图5,对资源更新请求包括节点更新请求的情况进行示例说明。此时的资源更新过程参见图5所示,包括:
S401:主节点接收资源更新请求,且资源更新请求包括节点更新请求;
S402:主节点根据全局资源列表对所述资源更新请求所请求更新的节点资源进行更新处理。
本实施例中的节点更新请求中包含需要添加和/或删除的普通节点的节点信息。应当理解的时,节点信息中应当包含需要添加和/或删除的普通节点的节点IP、节点接口等。
本实施例中,当节点更新请求中包含新增节点时,第三方可以在该新增节点信息中携带该节点启动后需要分配的消息队列名,此时负责的消息队列名中包含该新增节点启动后需要分配的消息队列,主节点接收识别并进行相应更新处理。应当理解的是,第三方也可能在节点添加请求中不携带需要分配到该节点的消息队列名,也即新增普通节点承载的消息队列为空,主节点可以在后续过程中为其从分配状态为未分配中选择相匹配的消息队列或从其他普通节点上移除一些相匹配的消息队列分配到该普通节点上。
本实施例中,当节点更新请求中包含删除节点时,主节点收到该节点更新请求后,在全局节点表中删除对应的普通节点地址以及承载的消息队列,回收并重新分配该普通节点所承载的消息队列。对于被回收重新分配出去的消息队列,主节点可在全局队列表中更新该消息队列当前被承载的节点信息,也可以不更新,而在全局节点列表中更新新分配到该消息队列的普通节点所承载的消息信息。而对于被回收单重新分配未分配出去的消息队列,则需要在全局队列列表中将该消息队列的分配状态修改为未分配状态,以留待后续将其重新分配出去。
应当理解的是,本实施例中的一个节点更新请求中可以包含对一个节点进行更新,例如可以包含同时增加一个或多个节点,也可以包含同时删除一个或多个节点。本实施例中的节点更新请求可以由第三方通过第三方接口向主节点发起,也可以由需要自启动完成自动添加的普通节点或需要自关闭完成退出的普通节点直接向主节点发起。
本实施例中主节点可以接收第三方通过主节点本身提供的接口向其发送的资源更新请求或接收需要更新的节点直接向其发送的资源更新请求,基于维护的全局资源列表完成节点以及相应队列的更新。可以很好的解决中间件***在新增节点时无对应消息队列可分配,删除节点时,该删除节点所负责的消息队列没有其他节点帮忙处理,只能通过重启更新资源配置的技术问题。且应当理解的是,本实施例中的中间件***可以为FOTA-MOM中间件***,当然也可以为其他类型的中间件***。
第三实施例
基于第一实施例可知,本发明中的资源更新请求可包括节点更新请求、队列更行请求、以及节点更新请求和队列更行请求这三种情形,为了更好的理解,本实施例结合图6,对资源更新请求包括队列更新请求的情况进行示例说明。此时的资源更新过程参见图6所示,包括:
S501:主节点接收资源更新请求,资源更新请求包括队列更新请求;
S502:主节点根据全局资源列表对资源更新请求所请求更新的队列资源进行更新处理。
根据上述分析可知,本实施例中的队列更新请求中也可能包含需要添加和/或删除的队列信息,此时的队列信息中包括但不限于用于唯一标识各消息队列的消息队列名。
应当理解的是,主节点对队列更新处理包括:
当队列更新请求中包含删除队列时,则在全局队列表中删除对应的消息队列,具体包括在全局队列表中删除该消息队列对应的队列标识和分配状态,并根据该分配状态通知当前承载该消息队列的节点停止处理该消息队列。
当队列更新请求中包含增加队列时,主节点在全局队列表中增加新增的消息队列包括:在全局队列表中增加该消息队列的标识以及对应的分配状态。消息队列标识包括但不限于消息队列名。
本实施例中主节点可以接收第三方通过主节点本身提供的接口向其发送的资源更新请求或接收需要更新的节点直接向其发送的队列更新请求,基于维护的全局资源列表完成相应队列的更新。可以很好的解决中间件***在新增队列时所新增的队列不能被及时分配到对应节点上,以及也不能对各节点所承载的队列进行动态调整的问题。
第四实施例
在上述各实施例从基础上,本实施例中的主节点还可以动态的监测各普通节点运行状态,对于故障的普通节点做出相应的资源更新处理。例如:主节点在监测到某一普通节点故障时,可以在全局节点表中删除该普通节点,回收并重新分配该普通节点承载的消息队列。本实施例中的监测机制可以是采用心跳检测或者BFD(Bidirectional ForwardingDetection,双向转发检测)检测。本实施例以心跳检测为例进行说明。
参照图7和图8,图7为本施例提供的心跳检测的流程示意图,图8为本施例提供的心跳反馈流程示意图。
本实施例中,主节点以心跳机制检测各普通节点的运行状态参见图7所示,包括:
S601:主节点遍历全局节点表;
S602:主节点判断是否存在普通节点,如存在,转至S603;如不存在,转至S606;
S603:主节点向普通节点发送心跳检测包;
S604:主节点判断当前时间与普通节点最后一次反馈心跳检测响应包的时间差是否大于设定值,当时间差大于设定值时,转至S605,当时间差不大于设定值时,转至S606;该设定值可以设置为心跳检测周期的N倍,N大于等于1,具体值可以根据具体的应用场景灵活选择;
S605:表明该普通节点故障,删除该普通节点,回收该普通节点承载的消息队列;
S606:等待预设时长后返回S601。预设时长可以根据实际情况设定,实际情况可以是根据主节点处理频率、网络通信质量等。例如设定为15秒。
应当理解的是,根据全局节点包中包含各普通节点最后一次反馈心跳检测响应包的时间计算与当前时间的时间差,并判断时间差是否大于设定值,例如设定值为1min。
本实施例中,主节点向普通节点发送心跳检测包,可以根据全局节点表中的普通节点的节点地址向普通节点发送。
图7为主节点发送心跳检测的过程,在发送心跳检测包后,普通节点的处理反馈过程可以参照图8,包括:
S701:普通节点接收主节点发送的心跳检测包;
S702:普通节点判断发送心跳检测包的节点是否为主节点,当心跳检测包是主节点发送的时,转至S703,当心跳检测包不是由主节点发送的时,转至S704;
S703:更新收到心跳检测包的时间,并向主节点反馈心跳检测响应包;
S704:向发送心跳检测包的节点反馈发送错误提示。
应当理解的是,普通节点在收到主节点发送的心跳检测包后,对其进行解析处理。心跳检测包可以通过包括但不限于json字符格式发送。
参照图9,图9为本实施例提供的心跳超时反馈的流程示意图,包括:
S801:普通节点计算当前时间与与最后一次收到主节点的心跳检测包的时间差(例如40秒),当判断时间差大于40秒时,转至S802;当时间差不大于40秒时,转至S804;
S802:遍历其所有承载的消息队列线程,并设置退出标志;
S803:等待所有队列线程的结束;
S804:等待定时时间(15秒)。
本实施例中,普通节点判断当前时间与最后一次收到主节点的心跳检测包的时间差大于设定时间时,可以将自身承载的消息队列全部退出,以避免因自身故障导致消息队列得不到及时的处理。
应当理解的是,此处遍历是指调用当前节点的节点信息表,遍历该节点信息表中包含当前节点所承载的所有消息队列信息。
本实施例中,为了提升处理效率,主节点可以预设一个时间段,对该时间段内接收到的资源更新请求进行分类合并存储,然后在该预设时间段到达时,根据全局资源列表对该预设时间段内分类合并存储的资源更新请求所请求更新的资源进行批量更新处理。例如,假设在该预设时间段内接收到4个关于节点更新的请求包括删除普通节点请求1,增加普通节点请求2,删除普通节点请求3,增加普通节点请求4,此时可以将删除普通节点请求1和删除普通节点请求3合并存储,将增加普通节点2请求和增加普通节点请求4合并存储。又例如在该预设时间段内接收到4个关于队列更新的请求包括删除队列请求1,增加队列请求2,删除队列请求3,增加队列请求4,此时可以将删除队列请求1和删除队列请求3合并存储,将增加队列请求2和增加队列请求4合并存储。且本实施例中,对于不同类型的请求还可分别设置对应的任务调度队列进行存储,执行时可以依序对各请求进行处理。
本实施例中的预设时间可以根据***要求处理的实时性、主节点处理频率、处理能力、通信环境等因素另附设定,例如设定为10秒。
下面以节点更新的请求为示例进行说明,对本实施例中的分时段分类集中处理过程进行示例说明。
参照图10,图10为本发明第四实施例提供的节点调整流程示意图,包括:
S901:主节点判断调度命令对列是否为空;当调度命令对列为空时,直接转至S907,等待定时时间,例如10秒,当调度命令队列不为空时,转至S902;应当理解的是,当前处理调度命令定时与发送心跳检测包定时可以采用相同或不同的定时线程处理。
本实施例中以调度命令队列中包含接收到的删除主节点请求和增加节点请求,下面以删除直接点请求为一个删除命令,一个增加节点请求为一个增加命令为示例进行说明。
S902:主节点依次取出调度命令对列中的所有命令进行合并处理;
应当理解的是,合并可以通过但不限于以下原则:将所有命令中删除命令队列整理合并到一起,将所有命令中新增命令队列整理合并到一起,最终形成一个删除命令队列和/或一个新增命令队列。
删除命令队列包括但不限于需要删除节点的节点信息、需要回收的消息队列信息。包括但不限于通过以下方式表示:
[删除命令队列:队列项[“普通节点IP;Port”;“需要回收的消息队列名”]]
新增命令队列包括但不限于需要新增节点的的节点信息、需要添加的消息队列信息。可以通过以下方式表示:
[新增命令队列:队列项[“普通节点IP;Port”;“需要添加的消息队列名”]]
S903:主节点调用相应的线程执行删除命令队列中的各队列项;包含对删除命令队列对应的节点进行删除,并回收需要回收的消息队列。具体包括删除全局节点表中相应节点信息,并回收该被删除节点所承载的消息队列。需要回收的消息队列包括但不限于被删除节点所承载的消息队列。
主节点将所有需要回收的消息队列分配到相应的普通节点,包括主节点调用相应的普通节点对消息队列进行回收,主节点在普通节点的节点信息表中添加当前回收的消息队列信息,消息队列信息包括但不限于消息队列名、处理类别名。且主节点在全局节点表中更新消息队列的队列信息。
S904:判断删除命令队列中是否还存在待执行的队列项,当不存在队列项时,转至S905,当存在队列项时,转至S903;
S905:主节点调用相应的线程执行新增命令队列中的各队列项。
执行新增命令时,在全局节点表中新增相应普通节点的普通节点地址以及承载的消息队列。
S906:判断新增命令队列中是否还存在待执行的队列项,如是,转至S905;否则,转至S907。
S907:等待定时时间,返回S901。
本实施例中,当主节点故障之后,还可从中间件***的其他节点中选择一个作为新的主节点,由新的主节点接替原来的主节点进行全局资源表的维护以及***内资源的更新。该过程参见图11所示,包括:
S1001:主节点发生故障;
S1002:从全局节点表中选取一个普通节点为新的主节点。
主节点也是普通节点,所以主节点在中间件***中也有可能存在故障问题。可能是由于断电或者其他紧急情况导致的故障。中间件***可以通过但不限于以下情况判断主节点发生故障:
当第三方发送资源更新请求时主节点未进行反馈时;
当普通节点发送自启动请求时主节点未进行反馈;
当心跳检测包定时超过设定时间(例如15秒)所有普通节点均未收到心跳检测包。
从全局节点表中选取一个普通节点作为主节点,选择的主体可以是通过后台管理设备(例如服务器)进行选择,也可以是由全局节点表中的各普通节点自推荐选择。选择的原则可以是根据各普通节点的健康程度进行选择,选择最健康的节点作为主节点。健康程度可以通过各节点当前负荷情况(包括但不限于承载队列情况)、通信环境、自身处理能力等决定。
新的主节点删除发生故障的主节点并回收该发生故障的主节点的调度命令队列,调用全局资源列表重新进行节点调整。
应当理解的是,新的主节点调用全局资源列表重新进行节点调整,包括但不限于主节点提供返回全局资源列表的接口。
本实施例中,主节点定时给普通节点发送心跳检测包,可以对普通节点和消息队列进行维护处理。主节点在短时间内接收的所有命令添加到调度命令队列中,并对调度命令队列中的所有命令合并调整,实现了节点调整的高效性。普通节点可以向主节点发送自启动请求,不需要第三方干预,可以实现快速添加。中间件***能够判断主节点是否发生故障,并对发生故障的主节点进行相应处理,实现中间件***的自我维护处理。
第五实施例
图12为本发明第五实施例提供的固件空间下载的主节点结构示意图,本实施例中的主节点包括:
请求处理模块1101:用于接收资源更新请求,资源更新请求包括请求更新节点的节点更新请求和请求更新队列的队列更新请求中的至少一种;
资源更新模块1102:用于全局资源列表对资源更新请求所请求更新的资源进行更新处理;全局资源列表包括:包含各普通节点信息的全局节点表和包含中间件***当前承载的消息队列的全局队列表。
本实施例中,请求处理模块1101用于接收资源更新请求,与资源更新模块1102相连,在接收到资源更新请求后,资源更新模块1102对全局资源列表对资源更新请求所请求更新的资源进行更新处理。
应当理解的是,请求处理模块1101可以接收由第三方下发的资源更新请求,请求处理模块1101与第三方之间可以建立相应的连接机制,包括但不限于网络协议、空中接口。请求处理模块1101中可以包括但不限于接收单元,用于完成对资源更新请求的接收。
应当理解的是,请求处理模块1101中包括但不限于通知单元,用于在接收到资源更新请求后,通知资源更新模块1102。应当理解的是,资源更新请求包括请求更新节点的节点更新请求和请求更新队列的队列更新请求中的至少一种,节点更新请求可以是新增节点和/或删除节点,队列更新请求可以是新增队列和/或删除队列。
本实施例中,资源更新模块1102对全局资源列表对资源更新请求所请求更新的资源进行更新处理。资源更新模块1102包括但不限于调用单元和处理单元,调用单元用于获取全局资源列表,处理单元用于更新处理。
应当理解的是,全局资源列表中包含全局节点表和全局队列表。
全局节点表中包含各普通节点信息,普通节点信息包括但不限于所有普通节点的节点IP、节点接口、所负责的消息队列列表、最后收到heartbeat反馈时间,包括但不限于以下方式表示:
[节点IP,节点Port,处理类别,负责的消息队列名列表,最后收到heartbeat反馈时间]
全局队列表中包含中间件***当前承载的消息队列信息,消息队列信息包括但不限于消息队列名称,类型,is used(是否已被分配处理),包括但不限于以下方式表示:
[redis队列名,类型,is_used(是否已被分配处理)]
资源更新模块1102根据资源更新请求,对全局资源列表进行相应更新处理。包括:
当新增节点时,在全局节点表中增加该普通节点地址以及承载的消息队列,节点地址包括但不限于该节点IP、Port。;
当删除节点时,在全局节点表中删除该普通节点地址以及承载的消息队列,回收并重新分配该普通节点所承载的消息队列;
当增加消息队列时,在全局节点表中增加该消息队列标识以及对应的分配状态。消息队列标识包括但不限于消息队列名、消息队列类型;
当删除消息队列时,在全局队列表中删除该消息队列对应的队列标识和分配状态,并根据该分配状态通知当前承载该消息队列的节点停止处理该消息队列;
并根据相应的分配原则将需要分配的消息队列分配到对应的节点,为需要分配消息队列的节点分配相应的消息队列。在此之前,资源更新模块1102应获取相应的分配原则、判断需要分配的消息队列和需要分配消息队列的节点。
相应的分配原则包括但不限于平均分配原则、根据节点处理能力分配原则。分配包括但不限于从当前分配分配状态为“未分配”的消息队列中选;也可以是从“已分配”的消息队列中调整。
资源更新模块1102判断需要分配的消息队列,包括但不限于当前分配状态为“未分配”的消息队列,某一普通节点当前所承载的消息队列太多导致超过普通节点负载标准的部分消息队列。
资源更新模块1102判断需要分配消息队列的节点,包括但不限于当前承载的消息队列为空的节点、当前承载的消息队列较少的节点。
本实施例中的节点可以通过图2所示的终端或图3所示的服务器实现。本实施例中主节点的上述各模块的功能可以通过终端中的控制器或服务器中的处理器实现,各模块可以构造于控制器或处理内。
本实施例中,主节点中的请求处理模块可以接收第三方或节点发送的资源更新请求,资源更新模块可以根据维护的全局资源列表对资源更新请求所请求更新的资源进行更新处理。解决了现有中间件***中各节点之间相互独立,配置信息固定,新增和/或删除节点、新增和/或删除消息队列时只能进行重启才能进行资源重新配置的技术问题。
第六实施例
在上述各实施例从基础上,本实施例中的主节点还包括监测模块1203,监测模块1203用于动态的监测各普通节点运行状态,对于故障的普通节点通知资源更新模块1202做出相应的资源更新处理。例如:监测模块1203在监测到某一普通节点故障时,资源更新模块1202可以在全局节点表中删除该普通节点,回收并重新分配该普通节点承载的消息队列。本实施例中监测模块1203采用的监测机制可以是采用心跳检测或者BFD(BidirectionalForwarding Detection,双向转发检测)检测。本实施例以心跳检测为例进行说明。监测模块1203执行监测的过程如下:
监测模块1203遍历全局节点表;
监测模块1203判断是否存在普通节点,如不存在,等待预设时长后重新判断。如存在,普通节点发送心跳检测包,判断当前时间与普通节点最后一次反馈心跳检测响应包的时间差是否大于设定值,当时间差大于设定值时,表明该普通节点故障,资源更新模块1202删除该普通节点,回收该普通节点承载的消息队列。当时间差不大于设定值时,等待预设时长后重新判断。
本实施例中,监测模块1203向普通节点发送心跳检测包,可以根据全局节点表中的普通节点的节点地址向普通节点发送。
本实施例中,为了提升处理效率,主节点的资源更新模块1202可以预设一个时间段,对该时间段内接收到的资源更新请求进行分类合并存储,然后在该预设时间段到达时,根据全局资源列表对该预设时间段内分类合并存储的资源更新请求所请求更新的资源进行批量更新处理。例如,假设在该预设时间段内接收到4个关于节点更新的请求包括删除普通节点请求1,增加普通节点请求2,删除普通节点请求3,增加普通节点请求4,此时可以将删除普通节点请求1和删除普通节点请求3合并存储,将增加普通节点2请求和增加普通节点请求4合并存储。又例如在该预设时间段内接收到4个关于队列更新的请求包括删除队列请求1,增加队列请求2,删除队列请求3,增加队列请求4,此时可以将删除队列请求1和删除队列请求3合并存储,将增加队列请求2和增加队列请求4合并存储。且本实施例中,对于不同类型的请求还可分别设置对应的任务调度队列进行存储,执行时可以依序对各请求进行处理。
本实施例中的预设时间可以根据***要求处理的实时性、主节点处理频率、处理能力、通信环境等因素另附设定,例如设定为10秒。
下面以节点更新的请求为示例进行说明,对资源更新模块1202进行分时段分类集中处理过程,以调度命令队列中包含接收到的删除主节点请求和增加节点请求,下面以删除直接点请求为一个删除命令,一个增加节点请求为一个增加命令为示例进行说明。此时的执行过程如下:
资源更新模块1202判断调度命令对列是否为空;当调度命令对列为空时,等待定时时间(例如20秒)后重新判断。当调度命令队列不为空时,资源更新模块1202依次取出调度命令对列中的所有命令进行合并处理。资源更新模块120先调用相应的线程执行删除命令队列中的各队列项;包含对删除命令队列对应的节点进行删除,并回收需要回收的消息队列。具体包括删除全局节点表中相应节点信息,并回收该被删除节点所承载的消息队列。需要回收的消息队列包括但不限于被删除节点所承载的消息队列。在删除命令队列中不存在待执行的队列项时,调用相应的线程执行新增命令队列中的各队列项。
应当理解的是,本实施例中的主节点也是普通节点,因此本实施例中的中间件***中的各节点中间件都可能成为主节点,所以在主节点在中间件***中也有可能存在故障问题时,可以从全局节点表中选取一个普通节点作为主节点,选择的主体可以是通过后台管理设备(例如服务器)进行选择,也可以是由全局节点表中的各普通节点自推荐选择。选择的原则可以是根据各普通节点的健康程度进行选择,选择最健康的节点作为主节点。健康程度可以通过各节点当前负荷情况(包括但不限于承载队列情况)、通信环境、自身处理能力等决定。新的主节点删除发生故障的主节点并回收该发生故障的主节点的调度命令队列,调用全局资源列表重新进行节点调整。
本实施例中,主节点可以定时给普通节点发送心跳检测包,可以动态的对普通节点和消息队列进行动态维护处理。主节点在短时间内接收的所有命令添加到调度命令队列中,并对调度命令队列中的所有命令合并调整,实现了节点调整的高效性。普通节点可以向主节点发送自启动请求,不需要第三方干预,可以实现快速添加。中间件***能够判断主节点是否发生故障,并对发生故障的主节点进行相应处理,实现中间件***的自我维护处理。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例的方法。
上面结合附图对本发明的实施例进行了描述,但是本发明并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本发明的启示下,在不脱离本发明宗旨和权利要求所保护的范围情况下,还可做出很多形式,这些均属于本发明的保护之内。
Claims (10)
1.一种固件空间下载的资源控制方法,其特征在于,包括:
主节点接收资源更新请求,所述资源更新请求包括请求更新节点的节点更新请求和请求更新队列的队列更新请求中的至少一种;所述主节点为中间件***中的一个节点中间件,所述中间件***中的其他节点中间件为普通节点;
所述主节点根据全局资源列表对所述资源更新请求所请求更新的资源进行更新处理;所述全局资源列表包括:包含所述各普通节点信息的全局节点表和包含所述中间件***当前承载的消息队列的全局队列表。
2.如权利要求1所述的固件空间下载的资源控制方法,其特征在于,所述资源更新请求包括节点更新请求时,所述节点更新请求包括增加节点和删除节点中的至少一种;所述全局节点表中包含各普通节点的节点地址以及承载的消息队列
所述主节点根据所述全局资源列表完成节点更新包括:
所述节点更新请求包括增加节点时,在所述全局节点表中增加该普通节点地址以及承载的消息队列;
所述节点更新请求包括删除节点时,在所述全局节点表中删除该普通节点地址以及承载的消息队列,回收并重新分配该普通节点所承载的消息队列。
3.如权利要求2所述的固件空间下载的资源控制方法,其特征在于,所述方法还包括:所述主节点在所述全局节点表中增加普通节点后,在增加的普通节点承载的消息队列为空时,从所述全局队列表中择对应的消息队列分配给该普通节点。
4.如权利要求1所述的固件空间下载的资源控制方法,其特征在于,所述资源更新请求包括队列更新请求时,所述队列更新请求包括增加队列和删除队列中的至少一种;所述全局队列表中包含各消息队列的队列标识和分配状态;
所述主节点根据所述全局资源列表完成队列更新包括:
所述队列更新请求包括增加队列时,在所述全局节点表中增加该消息队列标识以及对应的分配状态;
所述队列更新请求包括删除队列时,在所述全局队列表中删除该消息队列对应的队列标识和分配状态,并根据该分配状态通知当前承载该消息队列的节点停止处理该消息队列。
5.如权利要求4所述的固件空间下载的资源控制方法,其特征在于,所述方法还包括:所述主节点在所述全局队列表中增加消息队列后,在该消息队列的分配状态为未分配时,根据所述全局节点表中各普通节点当前的承载状态,将新增的所述消息队列分配到所述全局节点表中相匹配的普通节点上。
6.如权利要求1-5任一项所述的固件空间下载的资源控制方法,其特征在于,所述方法还包括:
所述主节点监测所述各普通节点的运行状态;
所述主节点在监测到某一普通节点故障时,在所述全局节点表中删除该普通节点,回收并重新分配该普通节点承载的消息队列。
7.如权利要求1-5任一项所述的固件空间下载的资源控制方法,其特征在于,所述主节点根据全局资源列表对所述资源更新请求所请求更新的资源进行更新处理包括:
将在预设时间段内接收到的资源更新请求进行分类合并存储;
在所述预设时间段到达时,根据所述全局资源列表对该预设时间段内分类合并存储的资源更新请求所请求更新的资源进行更新处理。
8.如权利要求1-5任一项所述的固件空间下载的资源控制方法,其特征在于,所述方法还包括:
监测到所述主节点故障时,根据主节点选择规则从所述全局节点表中的各普通点中选择出一个作为新的主节点,并删除所述故障的主节点,以及回收并重新分配该故障的主节点所承载的消息队列。以及回收并重新分配该故障的主节点所承载的消息队列。
9.一种固件空间下载的主节点,其特征在于,所述主节点为中间件***中的一个节点中间件,所述中间件***中的其他节点中间件为普通节点;所述主节点包括:
请求处理模块,用于接收资源更新请求,所述资源更新请求包括请求更新节点的节点更新请求和请求更新队列的队列更新请求中的至少一种;
资源更新模块,用于全局资源列表对所述资源更新请求所请求更新的资源进行更新处理;所述全局资源列表包括:包含所述各普通节点信息的全局节点表和包含所述中间件***当前承载的消息队列的全局队列表。
10.如权利要求9所述的固件空间下载的主节点,其特征在于,所述主节点还包括:
监测模块,用于监测所述各普通节点的运行状态,并在监测到某一普通节点故障时,通知所述资源更新模块;
所述资源更新模块还用于在所述全局节点表中删除所述故障的普通节点,回收并重新分配该故障的普通节点承载的消息队列。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610857189.5A CN106549796A (zh) | 2016-09-27 | 2016-09-27 | 一种固件空间下载的资源控制方法及主节点 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201610857189.5A CN106549796A (zh) | 2016-09-27 | 2016-09-27 | 一种固件空间下载的资源控制方法及主节点 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN106549796A true CN106549796A (zh) | 2017-03-29 |
Family
ID=58368190
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201610857189.5A Pending CN106549796A (zh) | 2016-09-27 | 2016-09-27 | 一种固件空间下载的资源控制方法及主节点 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN106549796A (zh) |
Cited By (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108683612A (zh) * | 2018-05-22 | 2018-10-19 | 阿里巴巴集团控股有限公司 | 一种消息获取方法和装置 |
CN109582335A (zh) * | 2018-12-03 | 2019-04-05 | 郑州云海信息技术有限公司 | 一种无中断存储集群节点在线升级方法、装置及设备 |
CN109766057A (zh) * | 2019-01-07 | 2019-05-17 | 成都中电熊猫显示科技有限公司 | 固件数据处理方法及*** |
CN110909057A (zh) * | 2019-11-22 | 2020-03-24 | 哈尔滨工程大学 | 一种数值水池虚拟试验数据中间件的工作方法 |
CN111124630A (zh) * | 2019-11-29 | 2020-05-08 | 中盈优创资讯科技有限公司 | Spark Streaming程序的运行***及方法 |
CN111818112A (zh) * | 2019-04-11 | 2020-10-23 | ***通信集团四川有限公司 | 一种基于Kafka***的发送消息的方法和装置 |
CN115550361A (zh) * | 2022-09-20 | 2022-12-30 | 三未信安科技股份有限公司 | 一种基于消息队列的集群实现方法 |
CN115550280A (zh) * | 2022-11-24 | 2022-12-30 | 云账户技术(天津)有限公司 | 多级消息队列实现方法、***、电子设备和可读存储介质 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102521044A (zh) * | 2011-12-30 | 2012-06-27 | 北京拓明科技有限公司 | 一种基于消息中间件的分布式任务调度方法及*** |
CN103092698A (zh) * | 2012-12-24 | 2013-05-08 | 中国科学院深圳先进技术研究院 | 云计算应用自动部署***及方法 |
CN104283948A (zh) * | 2014-09-26 | 2015-01-14 | 东软集团股份有限公司 | 服务器集群***及其负载均衡实现方法 |
US20150362619A1 (en) * | 2011-10-11 | 2015-12-17 | Saudi Arabian Oil Company | High performance and grid computing with fault tolerant data distributors quality of service |
-
2016
- 2016-09-27 CN CN201610857189.5A patent/CN106549796A/zh active Pending
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20150362619A1 (en) * | 2011-10-11 | 2015-12-17 | Saudi Arabian Oil Company | High performance and grid computing with fault tolerant data distributors quality of service |
CN102521044A (zh) * | 2011-12-30 | 2012-06-27 | 北京拓明科技有限公司 | 一种基于消息中间件的分布式任务调度方法及*** |
CN103092698A (zh) * | 2012-12-24 | 2013-05-08 | 中国科学院深圳先进技术研究院 | 云计算应用自动部署***及方法 |
CN104283948A (zh) * | 2014-09-26 | 2015-01-14 | 东软集团股份有限公司 | 服务器集群***及其负载均衡实现方法 |
Cited By (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN108683612A (zh) * | 2018-05-22 | 2018-10-19 | 阿里巴巴集团控股有限公司 | 一种消息获取方法和装置 |
CN108683612B (zh) * | 2018-05-22 | 2022-01-18 | 创新先进技术有限公司 | 一种消息获取方法和装置 |
CN109582335A (zh) * | 2018-12-03 | 2019-04-05 | 郑州云海信息技术有限公司 | 一种无中断存储集群节点在线升级方法、装置及设备 |
CN109582335B (zh) * | 2018-12-03 | 2022-02-18 | 郑州云海信息技术有限公司 | 一种无中断存储集群节点在线升级方法、装置及设备 |
CN109766057A (zh) * | 2019-01-07 | 2019-05-17 | 成都中电熊猫显示科技有限公司 | 固件数据处理方法及*** |
CN111818112A (zh) * | 2019-04-11 | 2020-10-23 | ***通信集团四川有限公司 | 一种基于Kafka***的发送消息的方法和装置 |
CN110909057A (zh) * | 2019-11-22 | 2020-03-24 | 哈尔滨工程大学 | 一种数值水池虚拟试验数据中间件的工作方法 |
CN110909057B (zh) * | 2019-11-22 | 2023-06-16 | 哈尔滨工程大学 | 一种数值水池虚拟试验数据中间件***及其工作方法 |
CN111124630A (zh) * | 2019-11-29 | 2020-05-08 | 中盈优创资讯科技有限公司 | Spark Streaming程序的运行***及方法 |
CN111124630B (zh) * | 2019-11-29 | 2024-03-12 | 中盈优创资讯科技有限公司 | Spark Streaming程序的运行***及方法 |
CN115550361A (zh) * | 2022-09-20 | 2022-12-30 | 三未信安科技股份有限公司 | 一种基于消息队列的集群实现方法 |
CN115550280A (zh) * | 2022-11-24 | 2022-12-30 | 云账户技术(天津)有限公司 | 多级消息队列实现方法、***、电子设备和可读存储介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN106549796A (zh) | 一种固件空间下载的资源控制方法及主节点 | |
CN108712501B (zh) | 信息的发送方法、装置、计算设备以及存储介质 | |
US20130173540A1 (en) | Gathering transaction data associated with locally stored data files | |
CN111800462A (zh) | 微服务实例处理方法、装置、计算机设备及存储介质 | |
CN108337127B (zh) | 应用性能监控方法、***、终端及计算机可读存储介质 | |
CN105144102A (zh) | 自适应数据同步 | |
US20190286212A1 (en) | Sensor processing method of mobile terminal, storage medium, and electronic device | |
CN110096258A (zh) | 一种基于Terraform的OpenStack基础设施架构管理的方法 | |
CN114090207A (zh) | 一种异步任务执行的方法 | |
CN112231144A (zh) | 一种数据处理方法、装置及电子设备 | |
CN113014608A (zh) | 一种流量分发控制方法、装置、电子设备及存储介质 | |
CN113609107A (zh) | 数据库管理方法、装置、电子设备及存储介质 | |
CN112347067A (zh) | 一种日志信息管控方法、设备及计算机可读存储介质 | |
CN107423036A (zh) | 一种应用设备及应用设备之应用中心***管理方法 | |
CN114647531B (zh) | 故障解决方法、故障解决***、电子设备及存储介质 | |
CN115658745A (zh) | 数据处理方法、装置、计算机设备和计算机可读存储介质 | |
CN114817419A (zh) | 基于Kafka的媒资数据存储方法、装置、电子设备及存储介质 | |
CN114546671A (zh) | 一种数据处理方法、装置及电子设备 | |
CN113890753A (zh) | 数字身份管理方法、装置、***、计算机设备和存储介质 | |
CN106569901A (zh) | 终端及访问命令的处理方法 | |
CN114625522A (zh) | 对象处理方法、装置、存储介质及计算机设备 | |
CN107291322A (zh) | 一种信息处理方法及终端 | |
CN111813574A (zh) | 图片压缩方法、装置、存储介质和电子设备 | |
CN112463514A (zh) | 分布式缓存集群的监测方法和装置 | |
CN114785722B (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 |
Application publication date: 20170329 |
|
RJ01 | Rejection of invention patent application after publication |