CN107222534B - 一种集群定时任务同步方法、系统和设备 - Google Patents
一种集群定时任务同步方法、系统和设备 Download PDFInfo
- Publication number
- CN107222534B CN107222534B CN201710379208.2A CN201710379208A CN107222534B CN 107222534 B CN107222534 B CN 107222534B CN 201710379208 A CN201710379208 A CN 201710379208A CN 107222534 B CN107222534 B CN 107222534B
- Authority
- CN
- China
- Prior art keywords
- task
- target
- timing task
- subscriber node
- target timing
- 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.)
- Active
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/60—Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
- H04L67/62—Establishing a time schedule for servicing the requests
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Mobile Radio Communication Systems (AREA)
Abstract
本发明公开了一种集群定时任务同步方法,应用于集群中的目标订阅者节点,所述目标订阅者节点包含至少一个订阅者节点,所述方法包括:接收目标定时任务的任务通知;按照预设规则,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,其中,所述目标定时任务信息为任意一个订阅者节点的任务接收队列所接收的与所述目标定时任务相对应的任务信息;根据所读取的目标定时任务信息开启定时任务。本发明还公开了一种集群定时任务同步设备以及一种计算机可读存储介质,解决了在多个订阅者节点中实现定时任务同步处理的问题。
Description
技术领域
本发明涉及集群技术领域,尤其涉及一种集群定时任务同步方法、系统和设备。
背景技术
随着互联网技术的广泛应用与快速发展,集群技术以其高性能、高可用、可扩展的特点获得了越来越广泛的应用与关注。集群通过多台节点机(服务器)协同起来执行任务并作为单一的系统向用户提供服务。定时任务能够在指定时间执行指定的任务,在用用程序中获得了广泛的应用,例如Linux系统中的crontab命令,用于周期性的执行指定任务;Java的util包中的Timer定时器,一种简单易用的定时任务;Spring中的Quartz,可以让你的程序在指定时间执行,也可以按照某一个频度执行。
然而,上述定时任务在集群环境下并不能很好的应用:crontab命令并不便于应用程序调用;Timer定时器过于简单并不能执行较复杂的定时策略;Quartz兼具了crontab命令丰富的定时策略以及Timer的易用性,但其配置通常写在xml文件中不能更改并不便于动态的配置定时任务。
因此,现有的定时任务在集群环境下没有解决任务如何在多个节点间的任务如何同步的问题。
发明内容
本发明的主要目的在于提出一种集群定时任务同步方法、系统和设备,旨在解决在多个订阅者节点中实现定时任务同步处理的问题。
为实现上述目的,本发明提出一种集群定时任务同步方法,应用于集群中的目标订阅者节点,所述目标订阅者节点包含至少一个订阅者节点,所述方法包括:
接收目标定时任务的任务通知;
按照预设规则,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,其中,所述目标定时任务信息为任意一个订阅者节点的任务接收队列所接收的与所述目标定时任务相对应的任务信息;
根据所读取的目标定时任务信息开启定时任务。
可选的,所述按照预设规则,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,包括:
按照预设周期,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,以使所述任务接收队列在所述目标定时任务信息读取进行清除;
或,
按照先入先出的规则,依次读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,以使所述任务接收队列在所述目标定时任务信息读取进行清除。
可选的,所述目标定时任务信息至少包括:任务标识、任务定时策略、执行任务时所要调用的类、执行任务时所要调用的参数和过程。
可选的,在所述目标订阅者节点中的每一个订阅者节点均有特定标识的情况下,
所述按照预设规则,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,包括:
根据所述订阅者节点的所具有的特定标识,查找与所述特定标识相对应的任务接收队列;
读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息。
相较于现有技术,本发明提供的一种集群定时任务同步方法,通过目标订阅者节点接收目标定时任务以及读取与目标订阅者节点相对应的任务接收队列中的目标定时任务信息,从而根据所读取的目标定时任务信息开启定时任务。从而能够实现在目标订阅者节点中所有的订阅者节点之间实现同步开启定时任务,从而解决了现有技术中多个订阅者节点之间任务不同步的问题。
此外,为实现上述目的,本发明还提出一种集群定时任务同步系统,包括:任务发布设备、目标订阅者节点、目标数据库;
所述任务发布设备,用于发布目标定时任务的任务通知至所述目标订阅者节点,以及发布与所述目标定时任务相对应的目标定时任务信息至所述目标数据库中的目标任务接收队列,其中,所述目标订阅者节点分别与所述目标任务接收队列具有对应标识;
目标数据库,用于采用所述目标任务接收队列接收与所述目标定时任务通知相对应的目标定时任务信息;
所述目标订阅者节点,用于接收所述目标定时任务通知,并通过对应从所述目标任务接收队列中获取与所述目标定时任务相对应的目标定时任务信息,并开启定时任务。
相较于现有技术,本发明提供的一种集群定时任务同步系统,通过目标订阅者节点接收目标定时任务以及读取与目标订阅者节点相对应的任务接收队列中的目标定时任务信息,从而根据所读取的目标定时任务信息开启定时任务。从而能够实现在目标订阅者节点中所有的订阅者节点之间实现同步开启定时任务,从而解决了现有技术中多个订阅者节点之间任务不同步的问题。
为实现上述目的,本发明还提出一种集群定时任务同步设备,应用于集群中的目标订阅者节点,所述目标订阅者节点包含至少一个订阅者节点,所述集群定时任务同步设备包括:存储器、处理器及通信总线;
所述通信总线用于实现处理器和存储器之间的连接通信;
所述处理器用于执行集群定时任务同步程序,以实现以下步骤:
接收目标定时任务的任务通知;
按照预设规则,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,其中,所述目标定时任务信息为任意一个订阅者节点的任务接收队列所接收的与所述目标定时任务相对应的任务信息;
根据所读取的目标定时任务信息开启定时任务。
可选的,所述处理器还用于执行集群定时任务同步程序,以实现以下步骤:
在所述哈希地图结构表中记录并标记所述第二目标资按照预设周期,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,以使所述任务接收队列在所述目标定时任务信息读取进行清除;
或,
按照先入先出的规则,依次读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,以使所述任务接收队列在所述目标定时任务信息读取进行清除。
可选的,所述处理器还用于执行集群定时任务同步程序,以实现以下步骤:
在所述目标订阅者节点中的每一个订阅者节点均有特定标识的情况下,根据所述订阅者节点的所具有的特定标识,查找与所述特定标识相对应的任务接收队列;
读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息。
可选的,所述处理器还用于执行集群定时任务同步程序,以实现以下步骤:
所述目标定时任务信息至少包括:任务标识、任务定时策略、执行任务时所要调用的类、执行任务时所要调用的参数和过程。
相较于现有技术,本发明提供的一种集群定时任务同步设备,通过目标订阅者节点接收目标定时任务以及读取与目标订阅者节点相对应的任务接收队列中的目标定时任务信息,从而根据所读取的目标定时任务信息开启定时任务。从而能够实现在目标订阅者节点中所有的订阅者节点之间实现同步开启定时任务,从而解决了现有技术中多个订阅者节点之间任务不同步的问题。
本发明还提供一种计算机可读存储介质,所述计算机可读存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现如下步骤:
接收目标定时任务的任务通知;
按照预设规则,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,其中,所述目标定时任务信息为任意一个订阅者节点的任务接收队列所接收的与所述目标定时任务相对应的任务信息;
根据所读取的目标定时任务信息开启定时任务。
可选的,所述一个或者多个程序可被一个或者多个处理器执行,以实现如下步骤:
按照预设周期,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,以使所述任务接收队列在所述目标定时任务信息读取进行清除;
或,
按照先入先出的规则,依次读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,以使所述任务接收队列在所述目标定时任务信息读取进行清除。
可选的,所述一个或者多个程序可被一个或者多个处理器执行,以实现如下步骤:
所述目标定时任务信息至少包括:任务标识、任务定时策略、执行任务时所要调用的类、执行任务时所要调用的参数和过程。
可选的,所述一个或者多个程序可被一个或者多个处理器执行,以实现如下步骤:
在所述目标订阅者节点中的每一个订阅者节点均有特定标识的情况下,根据所述订阅者节点的所具有的特定标识,查找与所述特定标识相对应的任务接收队列;
读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息。
相较于现有技术,本发明提供的一种计算机可读存储介质,通过目标订阅者节点接收目标定时任务以及读取与目标订阅者节点相对应的任务接收队列中的目标定时任务信息,从而根据所读取的目标定时任务信息开启定时任务。从而能够实现在目标订阅者节点中所有的订阅者节点之间实现同步开启定时任务,从而解决了现有技术中多个订阅者节点之间任务不同步的问题。
附图说明
图1为实现本发明各个实施例的一个可选的移动终端的硬件结构示意图;
图2为如图1所示的移动终端的无线通信系统示意图;
图3为本发明所述的集群定时任务同步方法的流程示意图;
图4为本发明所述的集群定时任务同步系统的模块示意图;
图5为本发明所述的集群定时任务同步系统的实施例示意图;
图6为本发明所述的集群定时任务同步方法的实施例示意图;
图7为本发明所述的集群定时任务同步设备模块示意图;
图8为本发明所述的计算机可读存储介质模块示意图。
附图标记:
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。
终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如手机、平板电脑、笔记本电脑、掌上电脑、个人数字助理(Personal Digital Assistant,PDA)、便捷式媒体播放器(Portable Media Player,PMP)、导航装置、可穿戴设备、智能手环、计步器等移动终端,以及诸如数字TV、台式计算机等固定终端。
后续描述中将以移动终端为例进行说明,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。
请参阅图1,其为实现本发明各个实施例的一种移动终端的硬件结构示意图,该移动终端100可以包括:RF(Radio Frequency,射频)单元101、WiFi模块102、音频输出单元103、A/V(音频/视频)输入单元104、传感器105、显示单元106、用户输入单元107、接口单元108、存储器109、处理器110、以及电源111等部件。本领域技术人员可以理解,图1中示出的移动终端结构并不构成对移动终端的限定,移动终端可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
下面结合图1对移动终端的各个部件进行具体的介绍:
射频单元101可用于收发信息或通话过程中,信号的接收和发送,具体的,将基站的下行信息接收后,给处理器110处理;另外,将上行的数据发送给基站。通常,射频单元101包括但不限于天线、至少一个放大器、收发信机、耦合器、低噪声放大器、双工器等。此外,射频单元101还可以通过无线通信与网络和其他设备通信。上述无线通信可以使用任一通信标准或协议,包括但不限于GSM(Global System of Mobile communication,全球移动通讯系统)、GPRS(General Packet Radio Service,通用分组无线服务)、CDMA2000(CodeDivision Multiple Access 2000,码分多址2000)、WCDMA(Wideband Code DivisionMultiple Access,宽带码分多址)、TD-SCDMA(Time Division-Synchronous CodeDivision Multiple Access,时分同步码分多址)、FDD-LTE(Frequency DivisionDuplexing-Long Term Evolution,频分双工长期演进)和TDD-LTE(Time DivisionDuplexing-Long Term Evolution,分时双工长期演进)等。
WiFi属于短距离无线传输技术,移动终端通过WiFi模块102可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图1示出了WiFi模块102,但是可以理解的是,其并不属于移动终端的必须构成,完全可以根据需要在不改变发明的本质的范围内而省略。
音频输出单元103可以在移动终端100处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将射频单元101或WiFi模块102接收的或者在存储器109中存储的音频数据转换成音频信号并且输出为声音。而且,音频输出单元103还可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出单元103可以包括扬声器、蜂鸣器等等。
A/V输入单元104用于接收音频或视频信号。A/V输入单元104可以包括图形处理器(Graphics Processing Unit,GPU)1041和麦克风1042,图形处理器1041对在视频捕获模式或图像捕获模式中由图像捕获装置(如摄像头)获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元106上。经图形处理器1041处理后的图像帧可以存储在存储器109(或其它存储介质)中或者经由射频单元101或WiFi模块102进行发送。麦克风1042可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风1042接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由射频单元101发送到移动通信基站的格式输出。麦克风1042可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。
移动终端100还包括至少一种传感器105,比如光传感器、运动传感器以及其他传感器。具体地,光传感器包括环境光传感器及接近传感器,其中,环境光传感器可根据环境光线的明暗来调节显示面板1061的亮度,接近传感器可在移动终端100移动到耳边时,关闭显示面板1061和/或背光。作为运动传感器的一种,加速计传感器可检测各个方向上(一般为三轴)加速度的大小,静止时可检测出重力的大小及方向,可用于识别手机姿态的应用(比如横竖屏切换、相关游戏、磁力计姿态校准)、振动识别相关功能(比如计步器、敲击)等;至于手机还可配置的指纹传感器、压力传感器、虹膜传感器、分子传感器、陀螺仪、气压计、湿度计、温度计、红外线传感器等其他传感器,在此不再赘述。
显示单元106用于显示由用户输入的信息或提供给用户的信息。显示单元106可包括显示面板1061,可以采用液晶显示器(Liquid Crystal Display,LCD)、有机发光二极管(Organic Light-Emitting Diode,OLED)等形式来配置显示面板1061。
用户输入单元107可用于接收输入的数字或字符信息,以及产生与移动终端的用户设置以及功能控制有关的键信号输入。具体地,用户输入单元107可包括触控面板1071以及其他输入设备1072。触控面板1071,也称为触摸屏,可收集用户在其上或附近的触摸操作(比如用户使用手指、触笔等任何适合的物体或附件在触控面板1071上或在触控面板1071附近的操作),并根据预先设定的程式驱动相应的连接装置。触控面板1071可包括触摸检测装置和触摸控制器两个部分。其中,触摸检测装置检测用户的触摸方位,并检测触摸操作带来的信号,将信号传送给触摸控制器;触摸控制器从触摸检测装置上接收触摸信息,并将它转换成触点坐标,再送给处理器110,并能接收处理器110发来的命令并加以执行。此外,可以采用电阻式、电容式、红外线以及表面声波等多种类型实现触控面板1071。除了触控面板1071,用户输入单元107还可以包括其他输入设备1072。具体地,其他输入设备1072可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆等中的一种或多种,具体此处不做限定。
进一步地,触控面板1071可覆盖显示面板1061,当触控面板1071检测到在其上或附近的触摸操作后,传送给处理器110以确定触摸事件的类型,随后处理器110根据触摸事件的类型在显示面板1061上提供相应的视觉输出。虽然在图1中,触控面板1071与显示面板1061是作为两个独立的部件来实现移动终端的输入和输出功能,但是在某些实施例中,可以将触控面板1071与显示面板1061集成而实现移动终端的输入和输出功能,具体此处不做限定。
接口单元108用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口、用于连接具有识别模块的装置的端口、音频输入/输出(I/O)端口、视频I/O端口、耳机端口等等。接口单元108可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端100和外部装置之间传输数据。
存储器109可用于存储软件程序以及各种数据。存储器109可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据手机的使用所创建的数据(比如音频数据、电话本等)等。此外,存储器109可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
处理器110是移动终端的控制中心,利用各种接口和线路连接整个移动终端的各个部分,通过运行或执行存储在存储器109内的软件程序和/或模块,以及调用存储在存储器109内的数据,执行移动终端的各种功能和处理数据,从而对移动终端进行整体监控。处理器110可包括一个或多个处理单元;优选的,处理器110可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器110中。
移动终端100还可以包括给各个部件供电的电源111(比如电池),优选的,电源111可以通过电源管理系统与处理器110逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。
尽管图1未示出,移动终端100还可以包括蓝牙模块等,在此不再赘述。
为了便于理解本发明实施例,下面对本发明的移动终端所基于的通信网络系统进行描述。
请参阅图2,图2为本发明实施例提供的一种通信网络系统架构图,该通信网络系统为通用移动通信技术的LTE系统,该LTE系统包括依次通讯连接的UE(User Equipment,用户设备)201,E-UTRAN(Evolved UMTS Terrestrial Radio Access Network,演进式UMTS陆地无线接入网)202,EPC(Evolved Packet Core,演进式分组核心网)203和运营商的IP业务204。
具体地,UE201可以是上述终端100,此处不再赘述。
E-UTRAN202包括eNodeB2021和其它eNodeB2022等。其中,eNodeB2021可以通过回程(backhaul)(例如X2接口)与其它eNodeB2022连接,eNodeB2021连接到EPC203,eNodeB2021可以提供UE201到EPC203的接入。
EPC203可以包括MME(Mobility Management Entity,移动性管理实体)2031,HSS(Home Subscriber Server,归属用户服务器)2032,其它MME2033,SGW(Serving Gate Way,服务网关)2034,PGW(PDN Gate Way,分组数据网络网关)2035和PCRF(Policy andCharging Rules Function,政策和资费功能实体)2036等。其中,MME2031是处理UE201和EPC203之间信令的控制节点,提供承载和连接管理。HSS2032用于提供一些寄存器来管理诸如归属位置寄存器(图中未示)之类的功能,并且保存有一些有关服务特征、数据速率等用户专用的信息。所有用户数据都可以通过SGW2034进行发送,PGW2035可以提供UE 201的IP地址分配以及其它功能,PCRF2036是业务数据流和IP承载资源的策略与计费控制策略决策点,它为策略与计费执行功能单元(图中未示)选择及提供可用的策略和计费控制决策。
IP业务204可以包括因特网、内联网、IMS(IP Multimedia Subsystem,IP多媒体子系统)或其它IP业务等。
虽然上述以LTE系统为例进行了介绍,但本领域技术人员应当知晓,本发明不仅仅适用于LTE系统,也可以适用于其他无线通信系统,例如GSM、CDMA2000、WCDMA、TD-SCDMA以及未来新的网络系统等,此处不做限定。
基于上述移动终端硬件结构以及通信网络系统,提出本发明方法各个实施例。
基于上述移动终端硬件结构以及通信系统,提出本发明系统各个实施例。
首先,本发明提出一种集群定时任务同步方法。
如图3所示,在本实施例中,应用于集群中的目标订阅者节点,所述目标订阅者节点包含至少一个订阅者节点,所述集群定时任务同步方法可以分为以下步骤:步骤S310为接收步骤:接收目标定时任务的任务通知;步骤S320为读取步骤:按照预设规则,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,其中,所述目标定时任务信息为任意一个订阅者节点的任务接收队列所接收的与所述目标定时任务相对应的任务信息;步骤
S330为开启步骤:根据所读取的目标定时任务信息开启定时任务。上述这些步骤根据不同的需求调整顺序,或者省略某些步骤。或者还可以根据需求补充其他的步骤。
S310,接收目标定时任务的任务通知。
需要说明的是,集群是通过多个节点(服务器)协同起来执行任务并作为单一的系统向用户提供服务,每一个服务器可以称为一个节点。对于本分发明实施例中,将用于接收并处理任务节点称为订阅者节点。
本发明实施例中,将一个用来接收同一定时任务通知的或者多个订阅者节点称为目标订阅者节点。具体的,任务通知可以由集群定时任务同步系统中的任务发布设备进行发布,任务发布设备可以为任务发布中心中用于发布任务相关信息的设备。
具体的,任务通知是用于通知用于执行任务的节点:有任务需要该节点处理,以便节点能够及时获得待处理的任务的信息能够及时对任务进行处理。任务通知的形式可以包括任务名称、处理时间等等,也可以是包含任务的标定标识;任务通知只要能和具体的任务相对应起来即可,本发明实施例不对其形式进行具体限定。
示4例性的,目标订阅者节点中的订阅者节点A,接收到任务通知为任务A的通知,任务通知的形式可以为:任务A,处理时间20160504170510,处理时间表示处理该任务的截止时间为2016年5月4日17时05分10秒。本发明实施例中的任务通知仅仅是示例性的。
S320,按照预设规则,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,其中,所述目标定时任务信息为任意一个订阅者节点的任务接收队列所接收的与所述目标定时任务相对应的任务信息。
需要说明的是,定时任务能够在指定时间执行指定的任务,在用用程序中获得了广泛的应用。目标订阅者节点在接收到任务通知以后,需要去获取与该任务相关的任务信息,用于进行具体任务的执行。
可以理解的是,任务发布设备可以将与该目标定时任务相关的任务信息放置于任务接收队列中;在目标订阅者节点中的任一订阅者节点接收到任务通知以后去与自己相对应的任务接收队列中读取对应的任务信息。
示例性的,目标订阅者节点中的订阅者节点a,订阅者节点a对应的任务接收队列为a1,订阅者节点a接收到任务通知以后会去任务接收队列a1中读取与任务A对应的任务信息。
需要说明的是,任务信息为处理目标定时任务所必不可少的信息,本发明实施例中所述目标定时任务信息可以至少包括:任务标识、任务定时策略、执行任务时所要调用的类、执行任务时所要调用的参数和过程。
具体的,任务标识即任务ID,用于标识任务;示例性的,目标定时任务A的任务ID为A001。任务定时策略,即为用于控制任务的定时策略,通过cron表达式进行表达,cron表达式主要是用在Quartz(Quartz是一个完全由java编写的开源作业调度框架)框架中,最主要的功能就是调度器(完成定时任务),可以与javaEE或者javaSE应用程序相结合也可以单独使用,能借助关系数据库和JDBC作业存储支持集群,负载均衡。
需要说明的是,一个cron表达式有至少6个(也可能是7个)由空格分隔的时间元素。从左至右,这些元素的定义如下:1.秒(0–59),2.分钟(0–59),3.小时(0–23),4.月份中的日期(1–31),5.月份(1–12或JAN–DEC),6.星期中的日期(1–7或SUN–SAT),7.年份(1970–2099)。具体的,每一个元素都可以显式地规定一个值(如6),一个区间(如9-12),一个列表(如9,11,13)或一个通配符(如*)。“月份中的日期”和“星期中的日期”,这两个元素是互斥的,因此应该通过设置一个问号(?)来表明你不想设置的那个字段。示例性的,0 0,15,30,45*1-10*?表示:每月前10天每隔15分钟。
执行任务时所要调用的类即为定时任务执行时所要调用的类,类是具备某些共同特征的实体的集合,它是一种抽象的概念。示例性的,执行目标定时任务A需要掉用的类为:person1、person2。
另外,执行任务时所要调用的参数和过程;为执行方法名时定时任务执行时所要调用的具体方法名;方法参数列表中包含执行方法所需参数。示例性的,可以通过反射机制调用某个类的过程,具体的可以采用如下函数进行过程的调用:
public Object invoke(Object obj,Object...args)
这个方法过程对带有指定参数的指定对象调用由此Method对象表示的底层方法。个别参数被自动解包,以便与基本形参相匹配,基本参数和引用参数都随需服从方法调用转换。然后,返回使用参数args在obj上指派该对象所表示方法的结果。
上述调用类的方法中包含的具体参数如下:
obj表示从中调用底层方法的对象;rgs用于方法调用的参数。
具体的,任务发布设备在发送任务接收队列至目标订阅者节点的同时将任务信息发送至任务接收队列,在目标订阅者节点接收到任务信息以后,按照预先设定的规则从任务接收队列中获取任务信息,当任务接收队列为云端的任务接收队列,那么目标订阅者节点分别从云端任务接收队列中读取任务信息。
本发明实施例中,目标订阅者节点可以按照预设周期,去读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,以使所述任务接收队列在所述目标定时任务信息读取进行清除;防止由于网络问题目标订阅者节点未接收到任务通知。另外,目标订阅者节点启动时可以到云端任务队列中读取任务,防止由于节点暂时失效未接收到任务通知,从而未执行发布的任务。
另外,目标订阅者节点还可以按照先入先出的规则,依次读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,以使所述任务接收队列在所述目标定时任务信息读取进行清除。以保证先进入任务接收队列中的任务信息可以先进行处理。
S330,根据所读取的目标定时任务信息开启定时任务。
需要说明的是,目标订阅者节点读取到目标定时任务相关的任务信息以后,可以根据任务信息开启定时任务,即执行定时任务。
可以理解的是,任务信息中至少可以包括任务的标识、定时策略、调用的类、参数、调用类的方法及参数等等,目标订阅节点可以先去根据任务标识确定需要执行的任务,获取该任务定时的策略,示例性的,为任务的执行时间上的执行策略,然后根据该任务确认需要调用的类,确定以后进行类的调用与调用参数的获取。
应用本发明图3所示的实施例,通过目标订阅者节点接收目标定时任务以及读取与目标订阅者节点相对应的任务接收队列中的目标定时任务信息,从而根据所读取的目标定时任务信息开启定时任务。从而能够实现在目标订阅者节点中所有的订阅者节点之间实现同步开启定时任务,解决了现有技术中多个订阅者节点之间任务不同步的问题,实现了各节点定时任务的同步。
另外,本发明实施例还提供一种集群定时任务同步系统400,参见图4,包括:任务发布设备410、目标订阅者节点420、目标数据库430;
所述任务发布设备410,用于发布目标定时任务的任务通知至所述目标订阅者节点,以及发布与所述目标定时任务相对应的目标定时任务信息至所述目标数据库中的目标任务接收队列,其中,所述目标订阅者节点420分别与所述目标任务接收队列具有对应标识;
所述目标订阅者节点420,用于接收所述目标定时任务通知,并通过对应从所述目标任务接收队列中获取与所述目标定时任务相对应的目标定时任务信息,并开启定时任务;
目标数据库430,用于采用所述目标任务接收队列接收与所述目标定时任务通知相对应的目标定时任务信息。
具体的,任务发布设备410用于向指定的目标订阅者节点集合发布定时任务;目标订阅者节点420,由包含多个节点构成,用于执行定时任务;目标数据库430,用于存储定时任务同步所需的数据。
具体的,可以将订阅相同信息的订阅者节点作为一个频道,并将频道信息存储在目标数据库430中,一个频道设置一个标识或者一个设定值,任务发布设备410根据标识或者设定值频道中的订阅者节点发送任务通知并将任务信息放入对应接收者的云端任务队列。其中,任务通知告知订阅者有新的任务。其中,云端任务队列为对应订阅者未消费的任务队列,可以为任务队列设定一个标识;任务订阅者节点也可以设置一个与其对应的任务队列对应的任务接收队列相同的标识,在订阅者节点接收到任务通知后到,到与其自身相同的标识任务接收队列中读取任务,并将读取过的任务清除出任务队列。其中,读取策略为每次读取队列中的所有任务。
如图5所示,任务发布设备410发送目标定时任务的任务通知至频道1中的订阅者节点,具体为订阅者节点1和订阅者节点2,还将该目标定时任务的目标定时任务信息发送至频道1中所有目标订阅者节点对应的云端任务队列中,即云端任务队列1和云端任务队列2;订阅者节点和订阅者节点2可以分别从云端任务队列1和云端任务队列2中获取目标定时任务信息,以便开启目标定时任务。
本发明实施例中,目标数据库430用于存储云端任务队列、频道等信息,避免了传统发布订阅机制的消息易失性。
参见图6,图6为本发明实施例提供的集群定时任务同步方法的一个实施例。
S610,将目标订阅者节点放入订阅者列表中;
S620,向订阅者列表中的每一个订阅者节点发送任务通知;
S630,按照先入先出的规则,依次读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,以使所述任务接收队列在所述目标定时任务信息读取进行清除;
S640根据目标定时任务信息,所有目标订阅者节点同时开启定时任务。
参见图6,图6为一种集群定时任务同步设备,应用于集群中的目标订阅者节点,所述目标订阅者节点包含至少一个订阅者节点,所述集群定时任务同步设备包括:存储器710、处理器720及通信总线730;
所述通信总线730用于实现处理器120和存储器710之间的连接通信;
所述处理器720用于集群定时任务同步程序,以实现以下步骤:
接收目标定时任务的任务通知;
按照预设规则,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,其中,所述目标定时任务信息为任意一个订阅者节点的任务接收队列所接收的与所述目标定时任务相对应的任务信息;
根据所读取的目标定时任务信息开启定时任务。
进一步地,所述处理器720用于集群定时任务同步程序,以实现以下步骤:
按照预设周期,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,以使所述任务接收队列在所述目标定时任务信息读取进行清除;
或,
按照先入先出的规则,依次读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,以使所述任务接收队列在所述目标定时任务信息读取进行清除。
进一步地,所述处理器720用于集群定时任务同步程序,以实现以下步骤:
所述目标定时任务信息至少包括:任务标识、任务定时策略、执行任务时所要调用的类、执行任务时所要调用的参数和过程。
进一步地,所述处理器720用于集群定时任务同步程序,以实现以下步骤:
根据所述订阅者节点的所具有的特定标识,查找与所述特定标识相对应的任务接收队列;
读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息。
应用本发明图7所示的实施例,通过目标订阅者节点接收目标定时任务以及读取与目标订阅者节点相对应的任务接收队列中的目标定时任务信息,从而根据所读取的目标定时任务信息开启定时任务。从而能够实现在目标订阅者节点中所有的订阅者节点之间实现同步开启定时任务,从而解决了现有技术中多个订阅者节点之间任务不同步的问题。
进一步地,本发明还提供了一种计算机可读存储介质,参见图8,所述计算机可读存储介质存储有一个或者多个程序810,所述一个或者多个程序810可被一个或者多个处理器820执行,以实现以下步骤:
接收目标定时任务的任务通知;
按照预设规则,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,其中,所述目标定时任务信息为任意一个订阅者节点的任务接收队列所接收的与所述目标定时任务相对应的任务信息;
根据所读取的目标定时任务信息开启定时任务。。
进一步地,所述一个或者多个程序810被所述一个或者多个处理器820执行,以实现以下步骤:
按照预设周期,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,以使所述任务接收队列在所述目标定时任务信息读取进行清除;
或,
按照先入先出的规则,依次读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,以使所述任务接收队列在所述目标定时任务信息读取进行清除。
进一步地,所述一个或者多个程序810被所述一个或者多个处理器820执行,以实现以下步骤
所述目标定时任务信息至少包括:任务标识、任务定时策略、执行任务时所要调用的类、执行任务时所要调用的参数和过程。。
进一步地,所述一个或者多个程序810还被所述一个或者多个处理器820执行,以实现以下步骤:
在所述目标订阅者节点中的每一个订阅者节点均有特定标识的情况下,根据所述订阅者节点的所具有的特定标识,查找与所述特定标识相对应的任务接收队列;
读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息。。
应用本发明图8所示的实施例,通过目标订阅者节点接收目标定时任务以及读取与目标订阅者节点相对应的任务接收队列中的目标定时任务信息,从而根据所读取的目标定时任务信息开启定时任务。从而能够实现在目标订阅者节点中所有的订阅者节点之间实现同步开启定时任务,从而解决了现有技术中多个订阅者节点之间任务不同步的问题。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。
以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本发明的专利保护范围内。
Claims (5)
1.一种集群定时任务同步方法,其特征在于,应用于集群中的目标订阅者节点,所述目标订阅者节点包含至少一个订阅者节点,所述方法包括:
订阅者节点设置一个与其对应的任务队列对应的任务接收队列相同的标识;
接收目标定时任务的任务通知;
按照预设规则,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,其中,所述目标定时任务信息为任意一个订阅者节点的任务接收队列所接收的与所述目标定时任务相对应的任务信息;
根据所读取的目标定时任务信息开启定时任务;
其中,所述按照预设规则,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,包括:
按照预设周期,在订阅者节点接收到任务通知后,到与其自身相同的标识的任务接收队列中读取任务,并将读取过的任务清除出任务队列,读取策略为每次读取队列中的所有任务;
或,
按照先入先出的规则,依次读取与订阅者节点自身相同的标识的任务接收队列中与所述目标定时任务相对应的目标定时任务信息,并将读取过的任务清除出任务队列,读取策略为每次读取队列中的所有任务;
其中,在所述目标订阅者节点中的每一个订阅者节点均有特定标识的情况下,
所述按照预设规则,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,包括:
根据所述订阅者节点的所具有的特定标识,查找与所述特定标识相对应的任务接收队列;
读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息。
2.根据权利要求1所述的集群定时任务同步方法,其特征在于,所述目标定时任务信息至少包括:任务标识、任务定时策略、执行任务时所要调用的类、或执行任务时所要调用的参数和过程。
3.一种集群定时任务同步设备,其特征在于,应用于集群中的目标订阅者节点,所述目标订阅者节点包含至少一个订阅者节点,所述集群定时任务同步设备包括:存储器、处理器及通信总线;
所述通信总线用于实现处理器和存储器之间的连接通信;
所述处理器用于执行集群定时任务同步程序,以实现以下步骤:
订阅者节点设置一个与其对应的任务队列对应的任务接收队列相同的标识;
接收目标定时任务的任务通知;
按照预设规则,读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息,其中,所述目标定时任务信息为任意一个订阅者节点的任务接收队列所接收的与所述目标定时任务相对应的任务信息;
根据所读取的目标定时任务信息开启定时任务;
其中,所述处理器还用于执行集群定时任务同步程序,以实现以下步骤:
按照预设周期,在订阅者节点接收到任务通知后,到与其自身相同的标识的任务接收队列中读取任务,并将读取过的任务清除出任务队列,读取策略为每次读取队列中的所有任务;
或,
按照先入先出的规则,依次读取与订阅者节点自身相同的标识的任务接收队列中与所述目标定时任务相对应的目标定时任务信息,并将读取过的任务清除出任务队列,读取策略为每次读取队列中的所有任务;
其中,所述处理器还用于执行集群定时任务同步程序,以实现以下步骤:
在所述目标订阅者节点中的每一个订阅者节点均有特定标识的情况下,根据所述订阅者节点的所具有的特定标识,查找与所述特定标识相对应的任务接收队列;
读取任务接收队列中与所述目标定时任务相对应的目标定时任务信息。
4.根据权利要求3所述的集群定时任务同步设备,其特征在于,所述处理器还用于执行集群定时任务同步程序,以实现以下步骤:
所述目标定时任务信息至少包括:任务标识、任务定时策略、执行任务时所要调用的类、或执行任务时所要调用的参数和过程。
5.一种计算机可读存储介质,应用于移动终端,其特征在于,所述计算机可读存储介质存储有一个或者多个程序,以使一个或者多个处理器执行如权利要求1-2任一项所述的集群定时任务同步方法步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710379208.2A CN107222534B (zh) | 2017-05-25 | 2017-05-25 | 一种集群定时任务同步方法、系统和设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710379208.2A CN107222534B (zh) | 2017-05-25 | 2017-05-25 | 一种集群定时任务同步方法、系统和设备 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN107222534A CN107222534A (zh) | 2017-09-29 |
CN107222534B true CN107222534B (zh) | 2020-11-17 |
Family
ID=59944475
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710379208.2A Active CN107222534B (zh) | 2017-05-25 | 2017-05-25 | 一种集群定时任务同步方法、系统和设备 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN107222534B (zh) |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111832857B (zh) * | 2019-04-17 | 2024-08-13 | 盒马(中国)有限公司 | 任务下发处理方法、装置及电子设备 |
CN112835693A (zh) * | 2021-01-14 | 2021-05-25 | 北京金山云网络技术有限公司 | 任务的定时方法、装置及电子设备 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN103581307A (zh) * | 2013-10-17 | 2014-02-12 | 北京邮电大学 | 一种基于集群的发布/订阅系统及其可靠性保障方法 |
CN104166590A (zh) * | 2013-05-20 | 2014-11-26 | 阿里巴巴集团控股有限公司 | 一种实现任务调度的方法及系统 |
CN104702426A (zh) * | 2013-12-05 | 2015-06-10 | 广东优迈信息通信股份有限公司 | 一种定时调度服务系统的配置方法及装置 |
-
2017
- 2017-05-25 CN CN201710379208.2A patent/CN107222534B/zh active Active
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN104166590A (zh) * | 2013-05-20 | 2014-11-26 | 阿里巴巴集团控股有限公司 | 一种实现任务调度的方法及系统 |
CN103581307A (zh) * | 2013-10-17 | 2014-02-12 | 北京邮电大学 | 一种基于集群的发布/订阅系统及其可靠性保障方法 |
CN104702426A (zh) * | 2013-12-05 | 2015-06-10 | 广东优迈信息通信股份有限公司 | 一种定时调度服务系统的配置方法及装置 |
Also Published As
Publication number | Publication date |
---|---|
CN107222534A (zh) | 2017-09-29 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109587747B (zh) | Sim卡切换控制方法、终端及计算机存储介质 | |
CN107967322B (zh) | 文件分类显示方法、移动终端及计算机可读存储介质 | |
CN107688607A (zh) | 一种数据库访问的方法及移动终端、计算机可读存储介质 | |
CN107402813B (zh) | 一种资源分配的方法及移动终端、计算机可读存储介质 | |
CN107220132B (zh) | 一种文件创建信息的监听方法、设备及存储介质 | |
CN108241752B (zh) | 照片显示方法、移动终端及计算机可读存储介质 | |
CN107862217B (zh) | 一种位置信息获取方法、移动终端以及计算机存储介质 | |
CN108011937B (zh) | 消息推送方法、服务器、智能终端及计算机可读存储介质 | |
CN112822538A (zh) | 投屏显示方法、投屏方法、投屏设备、终端及存储介质 | |
CN111190559A (zh) | 一种投屏控制同步方法、移动终端及计算机可读存储介质 | |
CN109286970B (zh) | 可穿戴设备功耗优化方法及装置、设备及可读存储介质 | |
CN108900779B (zh) | 初始自动曝光收敛方法、移动终端及计算机可读存储介质 | |
CN110020386B (zh) | 应用页面分享方法、移动终端及计算机可读存储介质 | |
CN108769126B (zh) | 应用推荐方法、移动终端及计算机可读存储介质 | |
CN108306856B (zh) | 一种接口合并方法、客户端、服务器及计算机可读存储介质 | |
CN107682541B (zh) | 屏幕投影的音频控制方法、移动终端及存储介质 | |
CN112597115A (zh) | 容器镜像的压缩方法、装置、终端设备及介质 | |
CN111935849A (zh) | 信息处理方法、设备及存储介质 | |
CN109725819B (zh) | 界面显示方法、装置、双屏双系统终端及可读存储介质 | |
CN107222534B (zh) | 一种集群定时任务同步方法、系统和设备 | |
CN111158617A (zh) | 一种投屏内容同步方法、移动终端及计算机可读存储介质 | |
CN108063863B (zh) | 一种信息浏览方法、终端、服务器和计算机可读存储介质 | |
CN107688497B (zh) | 一种内存调控方法、设备及计算机可读存储介质 | |
CN112612372A (zh) | 一种触控事件调控方法、设备及计算机可读存储介质 | |
CN112395106A (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 | ||
TA01 | Transfer of patent application right |
Effective date of registration: 20201029 Address after: Room 306, building 1, Jingxiu family, Huangjing Town, Taicang City, Suzhou City, Jiangsu Province Applicant after: Taicang Haobo Technical Service Co., Ltd Address before: 518057 Guangdong Province, Shenzhen high tech Zone of Nanshan District City, No. 9018 North Central Avenue's innovation building A, 6-8 layer, 10-11 layer, B layer, C District 6-10 District 6 floor Applicant before: NUBIA TECHNOLOGY Co.,Ltd. |
|
TA01 | Transfer of patent application right | ||
GR01 | Patent grant | ||
GR01 | Patent grant |