CN111857804B - 离线任务的处理方法、装置、电子设备及存储介质 - Google Patents
离线任务的处理方法、装置、电子设备及存储介质 Download PDFInfo
- Publication number
- CN111857804B CN111857804B CN202010711615.0A CN202010711615A CN111857804B CN 111857804 B CN111857804 B CN 111857804B CN 202010711615 A CN202010711615 A CN 202010711615A CN 111857804 B CN111857804 B CN 111857804B
- Authority
- CN
- China
- Prior art keywords
- task
- offline
- offline task
- callable
- configuration
- 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
- 238000003672 processing method Methods 0.000 title abstract description 5
- 238000000034 method Methods 0.000 claims abstract description 42
- 238000013468 resource allocation Methods 0.000 claims description 41
- 238000012545 processing Methods 0.000 claims description 35
- 238000012360 testing method Methods 0.000 claims description 3
- 238000011161 development Methods 0.000 abstract description 14
- 238000012423 maintenance Methods 0.000 abstract description 9
- 230000008569 process Effects 0.000 abstract description 4
- 230000000694 effects Effects 0.000 description 12
- 238000004891 communication Methods 0.000 description 10
- 230000006870 function Effects 0.000 description 10
- 238000010586 diagram Methods 0.000 description 7
- 238000004590 computer program Methods 0.000 description 6
- 230000005540 biological transmission Effects 0.000 description 5
- 230000008859 change Effects 0.000 description 4
- 230000003287 optical effect Effects 0.000 description 4
- 230000005236 sound signal Effects 0.000 description 4
- 238000005516 engineering process Methods 0.000 description 3
- 230000003993 interaction Effects 0.000 description 3
- 238000007726 management method Methods 0.000 description 3
- 238000012986 modification Methods 0.000 description 3
- 230000004048 modification Effects 0.000 description 3
- 230000001133 acceleration Effects 0.000 description 2
- 230000006978 adaptation Effects 0.000 description 2
- 230000001419 dependent effect Effects 0.000 description 2
- 230000008676 import Effects 0.000 description 2
- 230000009471 action Effects 0.000 description 1
- 238000003491 array Methods 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 239000000284 extract Substances 0.000 description 1
- 238000003384 imaging method Methods 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 230000000737 periodic effect Effects 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
- 238000012795 verification Methods 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/70—Software maintenance or management
- G06F8/71—Version control; Configuration management
Landscapes
- Engineering & Computer Science (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Stored Programmes (AREA)
Abstract
本公开关于一种离线任务的处理方法、装置、电子设备及存储介质。该方法包括:获取目标业务,目标业务包括对应的任务需求和配置参数;根据任务需求,从预设的离线任务集中获取与任务需求对应的至少一个离线任务;离线任务的类型包括可调用离线任务和可配置离线任务,可调用离线任务为预先配置完成的离线任务,可配置离线任务为需要进行配置的离线任务;根据配置参数,对至少一个离线任务进行配置,生成离线任务消息;通过离线任务对应的应用程序接口发送离线任务消息。从而在获取到目标任务后,从预设的离线任务集中获取对应的离线任务,并对离线任务进行配置,得到离线任务消息,发送该离线任务消息,整个过程自动实现,降低开发和维护的成本。
Description
技术领域
本公开涉及计算机技术领域,尤其涉及一种离线任务的处理方法、装置、电子设备及存储介质。
背景技术
目前,在互联网应用的服务端,通常需要通过离线运行的服务来执行一些定时或者周期性的离线任务。比如,定期向账户推送触达消息、周期性的生成账户报告、以及在运营活动结束后向参与该运营活动的账户发送奖励、私信等。
传统技术中,针对每个运营活动业务,技术人员需要将该运营活动业务的业务数据导入到数据中心。然后,技术人员需要为该运营活动业务单独开发一个离线任务,以通过离线任务从数据中心中获取业务数据处理业务数据并调用相应的通用接口层向参与该运营活动的账户发送奖励、私信等。
然而,基于传统技术,技术人员需要针对不同的运营活动业务单独开发一个离线任务,从而导致业务的可扩展性交底,开发和维护的成本较高。
发明内容
本公开提供一种离线任务的处理方法、装置、电子设备及存储介质,以至少解决相关技术中开发和维护的成本较高的问题。本公开的技术方案如下:
根据本公开实施例的第一方面,提供一种离线任务的处理方法,所述方法包括:
获取目标业务,所述目标业务包括对应的任务需求和配置参数;
根据所述任务需求,从预设的离线任务集中获取与所述任务需求对应的至少一个离线任务;其中,所述离线任务的类型包括可调用离线任务和可配置离线任务,所述可调用离线任务为预先配置完成的离线任务,所述可配置离线任务为需要进行配置的离线任务;
根据所述配置参数,对所述至少一个离线任务进行配置,生成离线任务消息;
通过所述离线任务对应的应用程序接口发送所述离线任务消息。
在一示例性实施例中,所述可调用离线任务的确定方式包括:
获取预设需求;
按照预设需求配置任务,得到所述可调用离线任务;
为所述可调用离线任务设置对应的根节点,按照所述根节点设置所述可调用离线任务。
在一示例性实施例中,所述为所述可调用离线任务设置对应的根节点,按照所述根节点设置所述可调用离线任务,包括:
若需上线新的可调用离线任务,则对所述可配置离线任务进行配置,并对应增加新的根节点,按照所述新的根节点设置配置后的可配置离线任务,得到新的可调用离线任务;
若需下线所述可调用离线任务,则下线对应的根节点,以下线所述可调用离线任务。
在一示例性实施例中,所述目标业务对应的任务需求存储于配置中心,所述目标业务对应的配置参数存储于Hive集群。
在一示例性实施例中,所述可调用离线任务至少包括私信任务、第一资源分配任务、第二资源分配任务,所述私信任务对应的应用程序接口为私信服务接口,第一资源分配任务对应的应用程序接口为第一资源分配服务接口,第二资源分配任务对应的应用程序接口为第二资源分配服务接口。
在一示例性实施例中,所述配置参数中包括执行所述至少一个离线任务的任务标识、所述至少一个离线任务的执行顺序和所述至少一个离线任务对应的任务配置参数;
所述根据所述配置参数,对所述至少一个离线任务进行配置,生成离线任务消息,包括:
按照所述任务配置参数,对相应的离线任务进行配置,得到对应的离线任务数据流;其中,所述离线任务数据流包括预设的Hive数据和所述离线任务的前置任务的配置结果;
按照所述执行顺序和每一离线任务对应的任务标识,调用所述离线任务和对应的离线任务数据流,并生成所述离线任务消息。
在一示例性实施例中,所述执行顺序对应的首个离线任务为Hive读取任务,所述Hive读取任务用于生成初始离线任务数据流。
根据本公开实施例的第二方面,提供一种离线任务的处理装置,所述装置包括:
目标业务获取单元,被配置为执行获取目标业务,所述目标业务包括对应的任务需求和配置参数;
离线任务确定单元,被配置为执行根据所述任务需求,从预设的离线任务集中获取与所述任务需求对应的至少一个离线任务;其中,所述离线任务的类型包括可调用离线任务和可配置离线任务,所述可调用离线任务为预先配置完成的离线任务,所述可配置离线任务为需要进行配置的离线任务;
离线任务配置单元,被配置为执行根据所述配置参数,对所述至少一个离线任务进行配置,生成离线任务消息;
离线任务发送单元,被配置为执行通过所述离线任务对应的应用程序接口发送所述离线任务消息。
在一示例性实施例中,所述离线任务确定单元还被配置为执行:
获取预设需求;
按照预设需求配置任务,得到所述可调用离线任务;
为所述可调用离线任务设置对应的根节点,按照所述根节点设置所述可调用离线任务。
在一示例性实施例中,所述离线任务确定单元还被配置为执行:
若需上线新的可调用离线任务,则对所述可配置离线任务进行配置,并对应增加新的根节点,按照所述新的根节点设置配置后的可配置离线任务,得到新的可调用离线任务;
若需下线所述可调用离线任务,则下线对应的根节点,以下线所述可调用离线任务。
在一示例性实施例中,所述目标业务获取单元还被配置为执行将目标业务对应的任务需求存储于配置中心,所述目标业务对应的配置参数存储于Hive集群。
在一示例性实施例中,所述离线任务确定单元还被配置为执行存储所述可调用离线任务,所述可调用离线任务至少包括私信任务、第一资源分配任务、第二资源分配任务,所述私信任务对应的应用程序接口为私信服务接口,第一资源分配任务对应的应用程序接口为第一资源分配服务接口,第二资源分配任务对应的应用程序接口为第二资源分配服务接口。
在一示例性实施例中,所述配置参数中包括执行所述至少一个离线任务的任务标识、所述至少一个离线任务的执行顺序和所述至少一个离线任务对应的任务配置参数;
所述离线任务配置单元还被配置为执行:
按照所述任务配置参数,对相应的离线任务进行配置,得到对应的离线任务数据流;其中,所述离线任务数据流包括预设的Hive数据和所述离线任务的前置任务的配置结果;
按照所述执行顺序和每一离线任务对应的任务标识,调用所述离线任务和对应的离线任务数据流,并生成所述离线任务消息。
在一示例性实施例中,所述离线任务配置单元还被配置为执行存储所述执行顺序,所述执行顺序对应的首个离线任务为Hive读取任务,所述Hive读取任务用于生成初始离线任务数据流。
根据本公开实施例的第三方面,提供一种电子机设备,包括:
处理器;
用于存储所述处理器可执行指令的存储器;
其中,所述处理器被配置为执行所述指令,以实现第一方面中任一项所述的离线任务的处理方法。
根据本公开实施例的第四方面,提供了一种存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得所述电子设备能够执行第一方面中任一项所述的离线任务的处理方法。
根据本公开实施例的第五方面,提供一种计算机程序产品,所述程序产品包括计算机程序,所述计算机程序存储在可读存储介质中,设备的至少一个处理器从所述可读存储介质读取并执行所述计算机程序,使得设备执行第一方面的任一项实施例中所述的离线任务的处理方法。
本公开的实施例提供的技术方案至少带来以下有益效果:
获取目标业务,目标业务包括对应的任务需求和配置参数;根据任务需求,从预设的离线任务集中获取与任务需求对应的至少一个离线任务;其中,离线任务的类型包括可调用离线任务和可配置离线任务,可调用离线任务为预先配置完成的离线任务,可配置离线任务为需要进行配置的离线任务;根据配置参数,对至少一个离线任务进行配置,生成离线任务消息;通过离线任务对应的应用程序接口发送离线任务消息。从而能够在获取到目标任务后,从预设的离线任务集中获取对应的离线任务,并对离线任务进行配置,进而得到离线任务消息,并通过对应的应用程序接口发送该离线任务消息,整个过程自动实现,且可配置离线任务能同时提高业务的可扩展性,降低开发和维护的成本。
应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理,并不构成对本公开的不当限定。
图1是根据一示例性实施例示出的一种离线任务的处理方法的应用环境图;
图2是根据一示例性实施例示出的一种离线任务的处理方法的流程图;
图3是根据一示例性实施例示出的可调用离线任务的确定方式的流程图;
图4是根据一示例性实施例示出的步骤S300的一种可实施方式的流程图;
图5是根据一具体示例性实施例示出的一种离线任务的处理方法的示意图;
图6是根据一示例性实施例示出的一种离线任务处理装置的框图;
图7是根据一示例性实施例示出的一种用于离线任务的处理的电子设备的框图。
具体实施方式
为了使本领域普通人员更好地理解本公开的技术方案,下面将结合附图,对本公开实施例中的技术方案进行清楚、完整地描述。
需要说明的是,本公开的说明书和权利要求书及上述附图中的术语“第一”、“第二”等是用于区别类似的对象,而不必用于描述特定的顺序或先后次序。应该理解这样使用的数据在适当情况下可以互换,以便这里描述的本公开的实施例能够以除了在这里图示或描述的那些以外的顺序实施。以下示例性实施例中所描述的实施方式并不代表与本公开相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本公开的一些方面相一致的装置和方法的例子。
本公开所提供的离线任务的处理方法,可以应用于如图1所示的应用环境中。如图1所示,该应用环境中包括数据中心、配置中心和离线任务系统。其中,离线任务系统中的数据获取模块从配置中心获取目标业务,并通过控制模块从数据中心的离线任务集中获取与任务需求对应的至少一个离线任务,在得到至少一个离线任务后,通过配置中心对至少一个离线任务进行配置,生成离线任务消息,最后,通过离线任务对应的应用程序接口发送离线任务消息。
图2是根据一示例性实施例示出的一种离线任务的处理方法的流程图,如图2所示,该方法的处理过程包括如下步骤。
在步骤S100中,获取目标业务,目标业务包括对应的任务需求和配置参数。
在步骤S200中,根据任务需求,从预设的离线任务集中获取与任务需求对应的至少一个离线任务;其中,离线任务的类型包括可调用离线任务和可配置离线任务,可调用离线任务为预先配置完成的离线任务,可配置离线任务为需要进行配置的离线任务。
在步骤S300中,根据配置参数,对至少一个离线任务进行配置,生成离线任务消息。
在步骤S400中,通过离线任务对应的应用程序接口发送离线任务消息。
其中,任务需求是指完成一项业务的具体需求。配置参数是指是指至少一个离线任务的任务链执行任务时需要的参数,例如任务类型、任务顺序、务执行频率等。预设的离线任务集是指根据预设需求提前开发完成的可实现一定功能的离线任务的集合。应用程序接口,简称API(Application Programming Interface),是软件系统不同组成部分衔接的约定,在本实施例中,应用程序接口用于发送离线任务消息。
可选地,目标业务对应的任务需求存储于配置中心,目标业务对应的配置参数存储于Hive集群。
其中,配置中心是指可以满足各个业务的动态配置中心化管理的需求,实现配置修改实时推送、权限校验、类型检查、修改历史、配置回滚、Open API等业务功能。可选地,配置中心可以选择Kconf配置中心,该Kconf配置中心是一种自研发的配置中心,技术人员可以将各个业务的离线任务预先存储至Kconf配置中心。Hive集群是指一种基于Hadoop构建的数据仓库,在运营活动结束后,可以将需要处理的离线任务数据(比如用户信息、私信内容、奖励数额、超链接等)导入到Hive表中。相应的,可以将Hive表的元数据(即离线任务数据的元数据)存储至Kconf配置中心。
具体地,当离线任务系统需要执行获取到的目标业务时,离线任务系统中的控制模块从配置中心获取目标业务对应的任务需求和配置参数。在获取到目标业务后,控制模块可以基于任务需求,从预设的离线任务集中调用对应的一个或多个能够实现一定需求的离线任务。并根据配置参数,对至少一个离线任务进行配置,得到至少一个离线任务构成的完整任务链,并最终生成目标业务对应的离线任务消息,并通过对应的应用程序接口发送离线任务消息,其中应用程序接口可以为RPC类型的通用接口服务。
在一示例性实施例中,目标业务为包含私信模式的资源分配业务,此时,需要私信任务和资源分配任务,首先从离线任务集中获取私信任务和资源分配任务对应的离线任务,并对需要配置的离线任务进行配置,并根据配置参数对离线任务进行配置,得到私信任务与资源分配任务之间的完整任务链,以实现私信和资源分配的目标业务,生成向终端发送的离线任务消息,最后通过应用程序接口将离线任务消息发送至对应的终端。
上述离线任务的处理方法,通过获取目标业务,目标业务包括对应的任务需求和配置参数;根据任务需求,从预设的离线任务集中获取与任务需求对应的至少一个离线任务;其中,离线任务的类型包括可调用离线任务和可配置离线任务,可调用离线任务为预先配置完成的离线任务,可配置离线任务为需要进行配置的离线任务;根据配置参数,对至少一个离线任务进行配置,生成离线任务消息;通过离线任务对应的应用程序接口发送离线任务消息。从而能够在获取到目标任务后,从预设的离线任务集中获取对应的离线任务,并对离线任务进行配置,进而得到离线任务消息,并通过对应的应用程序接口发送该离线任务消息,且可配置离线任务能同时提高业务的可扩展性,降低开发和维护的成本。
图3是根据一示例性实施例示出的可调用离线任务的确定方式的流程图,具体包括以下步骤:
在步骤S210中,获取预设需求。
在步骤S220中,按照预设需求配置任务,得到可调用离线任务。
在步骤S230中,为可调用离线任务设置对应的根节点,按照根节点设置可调用离线任务。
其中,预设需求是指为实现一个项目或者特定功能的需求。
具体地,根据预设需求,进行代码的编写、调试、测试,得到能够满足预设需求的可调用离线任务,该可调用离线任务的参数和内部结构已固定,可视作为一个封装好的模块化任务,可直接调用以实现相对应的功能。在得到可调用离线任务后,按照设置的节点设置该可调用离线任务。
可选地,可配置离线任务为一个开放的任务模块,该任务模块仅能实现一定的常用功能,例如可以实现数据的接收与传输,但是内部结构可配置,可以在使用过程中根据具体需求进行配置以实现需要的功能。可配置离线任务也设置有对应的根节点,供调用该可配置离线任务使用。
可选地,可调用离线任务至少包括私信任务、第一资源分配任务、第二资源分配任务,私信任务对应的应用程序接口为私信服务接口,第一资源分配任务对应的应用程序接口为第一资源分配服务接口,第二资源分配任务对应的应用程序接口为第二资源分配服务接口。
具体地,每一对应的可调用离线任务对应特定的服务接口,用以实现数据的单线传输,避免数据混传造成的数据丢失、传错等风险。
上述示例性实施例中,获取预设需求;按照预设需求配置任务,得到可调用离线任务;为可调用离线任务设置对应的根节点,按照根节点设置可调用离线任务。其中,生成预设需求的可调用离线任务,可以为后续根据具体目标业务的任务需求调用可配置离线任务提供基础,在存在对应的可调用离线任务时,可以直接调用该可调用离线任务,以实现相应需求,无需重复开发,能够降低开发和维护的成本,其中,可配置离线任务还能保证任务系统的可扩展性。
在一示例性实施例中,为步骤S230的一种可实施方式包括:
若需上线新的可调用离线任务,则对可配置离线任务进行配置,并对应增加新的根节点,按照新的根节点设置配置后的可配置离线任务,得到新的可调用离线任务;若需下线可调用离线任务,则下线对应的根节点,以下线可调用离线任务。
具体地,随着业务需求的不断变化,任务需求也在不断的变化,因此,预设的离线任务集中的离线任务需要不断地更新(新增离线任务或删除旧的离线任务)。若需上线新的可调用离线任务,则对可配置离线任务进行配置,并新增对应的根节点,按照对应的根节点设置该离线任务,以扩充离线任务集。而当需要下线旧的可调用离线任务时,则下线对应的根节点(屏蔽对应的根节点),以下线可调用离线任务。
上述示例性实施例中,若需上线新的可调用离线任务,则对可配置离线任务进行配置,并对应增加新的根节点,按照新的根节点设置配置后的可配置离线任务,得到新的可调用离线任务;若需下线可调用离线任务,则下线对应的根节点,以下线可调用离线任务。从而能够通过设置根节点的方法,快速上线或者下线对应的可调用离线任务,实现对离线任务集的动态扩展,以满足不断变化的任务需求,降低开发和维护的成本。
图4是根据一示例性实施例示出的步骤S300的一种可实施方式的流程图,具体包括以下步骤:
在步骤S310中,按照任务配置参数,对相应的离线任务进行配置,得到对应的离线任务数据流;其中,离线任务数据流包括预设的Hive数据和离线任务的前置任务的配置结果。
在步骤S320中,按照执行顺序和每一离线任务对应的任务标识,调用离线任务和对应的离线任务数据流,并生成离线任务消息。
其中,配置参数中包括执行至少一个离线任务的任务标识、至少一个离线任务的执行顺序和至少一个离线任务对应的任务配置参数。
其中,针对每个离线任务,该离线任务的离线任务配置中包含公共配置和任务配置两部分。其中,公共配置部分包括执行该离线任务的任务标识、该离线任务的执行顺序;任务配置部分包括该离线任务对应的离线任务数据流。
具体地,按照任务配置参数,对相应的离线任务进行配置,得到对应的离线任务数据流,离线任务数据流包括预设的Hive数据和离线任务的前置任务的配置结果。在获取到预设的Hive数据和前置任务的配置结果后,在对应的离线任务中对预设的Hive数据和前置任务的配置结果进行处理,并按照一定的顺序传输离线任务数据流,使得离线任务数据流能够按照一定的流向进行传输和处理,并最终生成离线任务消息。例如,离线任务为私信任务,私信任务可以根据私信模板、占位符等信息,将该离线任务对应的离线任务数据流(用户信息、私信内容等)构建为私信消息。又如,离线任务为代金券任务,代金券任务可以根据代金券模板和该离线任务对应的离线任务数据流(代金券类型、有效期、用户信息、金额等)创建代金券消息。
可选地,执行顺序对应的首个离线任务为Hive读取任务,Hive读取任务用于生成初始离线任务数据流。
可选地,对相应的离线任务进行配置的过程中,还包含各离线任务之间的依赖关系的配置。其中,依赖关系用于表示相邻两个离线任务中前一个离线任务的执行结果是否影响后一个离线任务。具体地,针对每个离线任务,如果当前的离线任务与其前置离线任务和后续离线任务的依赖关系为非依赖关系,说明该离线任务的执行结果不受前置离线任务的影响或该离线任务的执行结果不影像后置离线任务,则执行该离线任务,无需对前置离线任务和后置离线任务的离线任务数据流进行处理。如果当前的离线任务与其前置离线任务和后续离线任务的依赖关系为依赖,说明该离线任务的执行结果受前置离线任务的影响或该离线任务的执行结果影像后置离线任务,则执行该离线任务时,需要对前置离线任务和后置离线任务的离线任务数据流进行处理。
上述示例性实施例中,按照任务配置参数,对相应的离线任务进行配置,得到对应的离线任务数据流;其中,离线任务数据流包括预设的Hive数据和离线任务的前置任务的配置结果;按照执行顺序和每一离线任务对应的任务标识,调用离线任务和对应的离线任务数据流,并生成离线任务消息。从而能够使得获取到的无序的离线任务形成能实现一定功能任务链,实现目标业务对应的任务内容,得到相应的离线消息,为发送离线消息提供数据基础,避免单独开发相应业务的开发成本。
在一个具体的实施例中,如图5所示,为根据一示例性实施例示出的一种离线任务的处理方法的示意图,以下以发送私信为例进行说明:
其中,Kconf配置中心:Kconf平台是自研发的配置中心系统。我们将,可以将各个业务的任务链配置放到Kconf平台上。Hive集群:存放活动相关数据,活动结束后,需要将发送的内容导入hive表,包括发送的用户信息,私信的内容,奖励数额以及超链接等等。Hive表的元数据信息也会被存入到Kconf的任务配置中。pipeline系统:一个离线后台服务,内部包含多个基础模块。其中协调者模块会读取Kconf配置,根据各业务需求的任务链,按顺序依次执行对应的基础模块,完成业务需求,每一个任务链对应一个基础模块,各基础模块之间完全解耦,通过数据流交互,基础模块内部会读取本模块下的配置,从数据流中取出本模块所需的数据,然后调用下游RPC接口层完成特定的功能。
具体地,将业务逻辑中各种通用的逻辑抽象为模块,将模块中可变的部分抽象为模块的配置。其中,协调者模块负责读取任务链配置,将Hive读取模块导入的一批数据逐条发送给任务链中的其他基础模块处理。,不执行业务逻辑。Hive读取模块分批次将hive表数据导入内存,生成业务数据流,具有失败重试功能。私信模块根据配置的私信模板,占位符等信息,将数据流构建为私信消息,调用私信接口发送私信。代金券模块根据配置的代金券类型,有效期等信息,从数据流中提取用户及金额等数据,调用代金券发送接口发送给用户。每一个活动需求都由pipeline系统处理并提供各自的配置,其内置的私信基础模块可以支持不同活动的需求。每一个需求对应一个根节点,根节点下是其任务链配置,任务链包括了各个基础模块,如快币发送模块、私信发送模块。如果需求临时增加了代金券发送逻辑,只需要在任务链中添加对应的基础模块配置。如果要下线某一个需求,只需要下线对应的配置节点即可。任务链中的每一个模块的配置又分为公共配置和各个任务自身的配置。公共配置是指任务链执行任务时需要的参数,比如任务类型,任务顺序,任务执行频率等等。
上述模块化的处理具有如下特点:高内聚:每一个模块都负责某项特定的功能,与其他模块无直接关联,模块与模块之间通过单向数据流交互。可重复:每一个模块可以支持多个需求,只需要开发一遍。各个业务需求只需要在配置节点上新增对应的模块配置即可。不同业务在使用相同的模块时,肯定会有各自定制的需求,就拿发送私信模块来说,不同活动私信内容样式频率等等都是不同的,我们将模块中可能发生变化的点抽象出来,作为模块本身的配置。这样的可配置化设计使得一种模块可以支持同类业务场景的不同需求。可扩展:模块是横向可扩展的,如果现有模块无法满足某中业务场景,只需要编写新的模块即可,不需要改动已有模块的实现。模块与模块之间通过一个context的数据结构进行交互,context中既包含了读入的每一条hive表数据,也包含了该条数据被前置模块处理的结果。任务链的起始模块必须是Hive读取模块,该模块负责导入数据,生成原始数据流。协调者模块负责将生成的数据流按照配置顺序依次发送到任务链中的各个基础模块,基础模块读取自身配置消费数据流。每一个基础模块在处理完一条数据时会将处理结果添加到context中,以供后置任务判断是否处理该条数据。任务链的各模块的顺序以及是依赖前置任务均是可配置的。
上述示例性实施例中,通过将核心的发送逻辑做整理并抽象成基础的任务模块,再把一些业务相关的可变因素转换为模块配置,能够解决重复开发的问题。不同的业务需求只需要将所需的基础模块配置为任务链即可,无需进行代码层面的开发,可以降低开发和维护的成本。此外,将基础模块整合到一个服务中,新增需求只需要添加配置,不需要单独部署服务,活动的下线也只需要下线对应的配置即可,能够降低了运维成本,提升了开发效率。
应该理解的是,虽然图2-5的流程图中的各个步骤按照箭头的指示依次显示,但是这些步骤并不是必然按照箭头指示的顺序依次执行。除非本文中有明确的说明,这些步骤的执行并没有严格的顺序限制,这些步骤可以以其它的顺序执行。而且,图2-5中的至少一部分步骤可以包括多个步骤或者多个阶段,这些步骤或者阶段并不必然是在同一时刻执行完成,而是可以在不同的时刻执行,这些步骤或者阶段的执行顺序也不必然是依次进行,而是可以与其它步骤或者其它步骤中的步骤或者阶段的至少一部分轮流或者交替地执行。
图6是根据一示例性实施例示出的一种离线任务的处理装置框图。参照图6,离线任务的处理装置包括目标业务获取单元601、离线任务确定单元602、离线任务配置单元603和离线任务发送单元604:
目标业务获取单元601,被配置为执行获取目标业务,目标业务包括对应的任务需求和配置参数;
离线任务确定单元602,被配置为执行根据任务需求,从预设的离线任务集中获取与任务需求对应的至少一个离线任务;其中,离线任务的类型包括可调用离线任务和可配置离线任务,可调用离线任务为预先配置完成的离线任务,可配置离线任务为需要进行配置的离线任务;
离线任务配置单元603,被配置为执行根据配置参数,对至少一个离线任务进行配置,生成离线任务消息;
离线任务发送单元604,被配置为执行通过离线任务对应的应用程序接口发送离线任务消息。
在一示例性实施例中,离线任务确定单元602还被配置为执行:获取预设需求;
按照预设需求配置任务,得到可调用离线任务;为可调用离线任务设置对应的根节点,按照根节点设置可调用离线任务。
在一示例性实施例中,离线任务确定单元602还被配置为执行:若需上线新的可调用离线任务,则对可配置离线任务进行配置,并对应增加新的根节点,按照新的根节点设置配置后的可配置离线任务,得到新的可调用离线任务;若需下线可调用离线任务,则下线对应的根节点,以下线可调用离线任务。
在一示例性实施例中,目标业务获取单元601还被配置为执行将目标业务对应的任务需求存储于配置中心,目标业务对应的配置参数存储于Hive集群。
在一示例性实施例中,离线任务确定单元602还被配置为执行存储可调用离线任务,可调用离线任务至少包括私信任务、第一资源分配任务、第二资源分配任务,私信任务对应的应用程序接口为私信服务接口,第一资源分配任务对应的应用程序接口为第一资源分配服务接口,第二资源分配任务对应的应用程序接口为第二资源分配服务接口。
在一示例性实施例中,配置参数中包括执行至少一个离线任务的任务标识、至少一个离线任务的执行顺序和至少一个离线任务对应的任务配置参数;离线任务配置单元603还被配置为执行:按照任务配置参数,对相应的离线任务进行配置,得到对应的离线任务数据流;其中,离线任务数据流包括预设的Hive数据和离线任务的前置任务的配置结果;按照执行顺序和每一离线任务对应的任务标识,调用离线任务和对应的离线任务数据流,并生成离线任务消息。
在一示例性实施例中,离线任务配置单元603还被配置为执行存储执行顺序,执行顺序对应的首个离线任务为Hive读取任务,Hive读取任务用于生成初始离线任务数据流。
关于上述实施例中的装置,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
图7是根据一示例性实施例示出的一种用于离线任务的处理的电子设备700的框图。例如,设备700可以是移动电话、计算机、数字广播终端、消息收发设备、游戏控制台、平板设备、医疗设备、健身设备、个人数字助理等。
参照图7,设备700可以包括以下一个或多个组件:处理组件702、存储器704、电力组件706、多媒体组件708、音频组件710、输入/输出(I/O)的接口712、传感器组件714以及通信组件716。
处理组件702通常控制设备700的整体操作,诸如与显示、电话呼叫、数据通信、相机操作和记录操作相关联的操作。处理组件702可以包括一个或多个处理器720来执行指令,以完成上述的方法的全部或部分步骤。此外,处理组件702可以包括一个或多个模块,便于处理组件702和其他组件之间的交互。例如,处理组件702可以包括多媒体模块,以方便多媒体组件708和处理组件702之间的交互。
存储器704被配置为存储各种类型的数据以支持在设备700的操作。这些数据的示例包括用于在设备700上操作的任何应用程序或方法的指令、联系人数据、电话簿数据、消息、图片、视频等。存储器704可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(SRAM)、电可擦除可编程只读存储器(EEPROM)、可擦除可编程只读存储器(EPROM)、可编程只读存储器(PROM)、只读存储器(ROM)、磁存储器、快闪存储器、磁盘或光盘。
电源组件706为设备700的各种组件提供电力。电源组件706可以包括电源管理系统,一个或多个电源,及其他与为设备700生成、管理和分配电力相关联的组件。
多媒体组件708包括在设备700和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(LCD)和触摸面板(TP)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件708包括一个前置摄像头和/或后置摄像头。当设备700处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
音频组件710被配置为输出和/或输入音频信号。例如,音频组件710包括一个麦克风(MIC),当设备700处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器704或经由通信组件716发送。在一些实施例中,音频组件710还包括一个扬声器,用于输出音频信号。
I/O接口712为处理组件702和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
传感器组件714包括一个或多个传感器,用于为设备700提供各个方面的状态评估。例如,传感器组件714可以检测到设备700的打开/关闭状态,组件的相对定位,例如组件为设备700的显示器和小键盘,传感器组件714还可以检测设备700或设备700一个组件的位置改变,用户与设备700接触的存在或不存在,设备700方位或加速/减速和设备700的温度变化。传感器组件714可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件714还可以包括光传感器,如CMOS或CCD图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件714还可以包括加速度传感器、陀螺仪传感器、磁传感器、压力传感器或温度传感器。
通信组件716被配置为便于设备700和其他设备之间有线或无线方式的通信。设备700可以接入基于通信标准的无线网络,如WiFi,运营商网络(如2G、3G、4G或5G),或它们的组合。在一个示例性实施例中,通信组件716经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,通信组件716还包括近场通信(NFC)模块,以促进短程通信。
在示例性实施例中,设备700可以被一个或多个应用专用集成电路(ASIC)、数字信号处理器(DSP)、数字信号处理设备(DSPD)、可编程逻辑器件(PLD)、现场可编程门阵列(FPGA)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述方法。
在一示例性实施例中,还提供了一种存储介质,当存储介质中的指令由电子设备的处理器执行时,使得电子设备能够执行任一项实施例中的方法。
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器704,上述指令可由设备700的处理器720执行以完成上述方法。例如,非临时性计算机可读存储介质可以是ROM、随机存取存储器(RAM)、CD-ROM、磁带、软盘和光数据存储设备等。
在示例性实施例中,还提供一种计算机程序产品,程序产品包括计算机程序,计算机程序存储在可读存储介质中,设备的至少一个处理器从可读存储介质读取并执行计算机程序,使得设备执行任一项实施例中的离线任务的处理方法。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本公开的其它实施方案。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本公开的真正范围和精神由下面的权利要求指出。
应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限制。
Claims (16)
1.一种离线任务的处理方法,其特征在于,所述方法包括:
获取目标业务,所述目标业务包括对应的任务需求和配置参数;
根据所述任务需求,从预设的离线任务集中获取与所述任务需求对应的至少一个离线任务;其中,所述离线任务的类型包括可调用离线任务和可配置离线任务,所述可调用离线任务为根据预设需求进行代码编写、调试、测试后,得到的满足所述预设需求的离线任务,所述可配置离线任务为需要进行配置的离线任务,所述可调用离线任务的参数和内部结构已固定,所述可配置离线任务的内部结构可配置;
根据所述配置参数,对所述至少一个离线任务进行配置,生成离线任务消息,所述配置参数包括执行所述至少一个离线任务的任务标识、所述至少一个离线任务的执行顺序和所述至少一个离线任务对应的任务配置参数;
通过所述离线任务对应的应用程序接口发送所述离线任务消息。
2.根据权利要求1所述的方法,其特征在于,所述可调用离线任务的确定方式包括:
获取预设需求;
按照预设需求配置任务,得到所述可调用离线任务;
为所述可调用离线任务设置对应的根节点,按照所述根节点设置所述可调用离线任务。
3.根据权利要求2所述的方法,其特征在于,所述为所述可调用离线任务设置对应的根节点,按照所述根节点设置所述可调用离线任务,包括:
若需上线新的可调用离线任务,则对所述可配置离线任务进行配置,并对应增加新的根节点,按照所述新的根节点设置配置后的可配置离线任务,得到新的可调用离线任务;
若需下线所述可调用离线任务,则下线对应的根节点,以下线所述可调用离线任务。
4.根据权利要求1所述的方法,其特征在于,所述目标业务对应的任务需求存储于配置中心,所述目标业务对应的配置参数存储于Hive集群。
5.根据权利要求1所述的方法,其特征在于,所述可调用离线任务至少包括私信任务、第一资源分配任务、第二资源分配任务,所述私信任务对应的应用程序接口为私信服务接口,第一资源分配任务对应的应用程序接口为第一资源分配服务接口,第二资源分配任务对应的应用程序接口为第二资源分配服务接口。
6.根据权利要求1所述的方法,其特征在于,所述根据所述配置参数,对所述至少一个离线任务进行配置,生成离线任务消息,包括:
按照所述任务配置参数,对相应的离线任务进行配置,得到对应的离线任务数据流;其中,所述离线任务数据流包括预设的Hive数据和所述离线任务的前置任务的配置结果;
按照所述执行顺序和每一离线任务对应的任务标识,调用所述离线任务和对应的离线任务数据流,并生成所述离线任务消息。
7.根据权利要求6所述的方法,其特征在于,所述执行顺序对应的首个离线任务为Hive读取任务,所述Hive读取任务用于生成初始离线任务数据流。
8.一种离线任务的处理装置,其特征在于,所述装置包括:
目标业务获取单元,被配置为执行获取目标业务,所述目标业务包括对应的任务需求和配置参数;
离线任务确定单元,被配置为执行根据所述任务需求,从预设的离线任务集中获取与所述任务需求对应的至少一个离线任务;其中,所述离线任务的类型包括可调用离线任务和可配置离线任务,所述可调用离线任务为根据预设需求进行代码编写、调试、测试后,得到的满足所述预设需求的离线任务,所述可配置离线任务为需要进行配置的离线任务,所述可调用离线任务的参数和内部结构已固定,所述可配置离线任务的内部结构可配置;
离线任务配置单元,被配置为执行根据所述配置参数,对所述至少一个离线任务进行配置,生成离线任务消息,所述配置参数包括执行所述至少一个离线任务的任务标识、所述至少一个离线任务的执行顺序和所述至少一个离线任务对应的任务配置参数;
离线任务发送单元,被配置为执行通过所述离线任务对应的应用程序接口发送所述离线任务消息。
9.根据权利要求8所述的装置,其特征在于,所述离线任务确定单元还被配置为执行:
获取预设需求;
按照预设需求配置任务,得到所述可调用离线任务;
为所述可调用离线任务设置对应的根节点,按照所述根节点设置所述可调用离线任务。
10.根据权利要求9所述的装置,其特征在于,所述离线任务确定单元还被配置为执行:
若需上线新的可调用离线任务,则对所述可配置离线任务进行配置,并对应增加新的根节点,按照所述新的根节点设置配置后的可配置离线任务,得到新的可调用离线任务;
若需下线所述可调用离线任务,则下线对应的根节点,以下线所述可调用离线任务。
11.根据权利要求8所述的装置,其特征在于,所述目标业务获取单元还被配置为执行将目标业务对应的任务需求存储于配置中心,所述目标业务对应的配置参数存储于Hive集群。
12.根据权利要求8所述的装置,其特征在于,所述离线任务确定单元还被配置为执行存储所述可调用离线任务,所述可调用离线任务至少包括私信任务、第一资源分配任务、第二资源分配任务,所述私信任务对应的应用程序接口为私信服务接口,第一资源分配任务对应的应用程序接口为第一资源分配服务接口,第二资源分配任务对应的应用程序接口为第二资源分配服务接口。
13.根据权利要求8所述的装置,其特征在于,所述离线任务配置单元还被配置为执行:
按照所述任务配置参数,对相应的离线任务进行配置,得到对应的离线任务数据流;其中,所述离线任务数据流包括预设的Hive数据和所述离线任务的前置任务的配置结果;
按照所述执行顺序和每一离线任务对应的任务标识,调用所述离线任务和对应的离线任务数据流,并生成所述离线任务消息。
14.根据权利要求13所述的装置,其特征在于,所述离线任务配置单元还被配置为执行存储所述执行顺序,所述执行顺序对应的首个离线任务为Hive读取任务,所述Hive读取任务用于生成初始离线任务数据流。
15.一种电子设备,其特征在于,包括:
处理器;
用于存储所述处理器可执行指令的存储器;
其中,所述处理器被配置为执行所述指令,以实现如权利要求1至7中任一项所述的离线任务的处理方法。
16.一种存储介质,当所述存储介质中的指令由电子设备的处理器执行时,使得所述电子设备能够执行如权利要求1至7中任一项所述的离线任务的处理方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010711615.0A CN111857804B (zh) | 2020-07-22 | 2020-07-22 | 离线任务的处理方法、装置、电子设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010711615.0A CN111857804B (zh) | 2020-07-22 | 2020-07-22 | 离线任务的处理方法、装置、电子设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111857804A CN111857804A (zh) | 2020-10-30 |
CN111857804B true CN111857804B (zh) | 2024-07-09 |
Family
ID=72950678
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010711615.0A Active CN111857804B (zh) | 2020-07-22 | 2020-07-22 | 离线任务的处理方法、装置、电子设备及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN111857804B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112529522B (zh) * | 2020-12-04 | 2023-05-26 | 中国航空工业集团公司成都飞机设计研究所 | 一种综合机电管理软件架构系统 |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CA2840106A1 (en) * | 2012-04-24 | 2013-10-31 | Tencent Technology (Shenzhen) Company Limited | Offline download method, multimedia file download method and system thereof |
CN110471949A (zh) * | 2019-07-11 | 2019-11-19 | 阿里巴巴集团控股有限公司 | 数据血缘分析方法、装置、系统、服务器及存储介质 |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110750419B (zh) * | 2019-09-30 | 2023-03-14 | 北京百度网讯科技有限公司 | 离线任务的处理方法、装置、电子设备及存储介质 |
CN110806923B (zh) * | 2019-10-29 | 2023-02-24 | 百度在线网络技术(北京)有限公司 | 一种区块链任务的并行处理方法、装置、电子设备和介质 |
CN110781007B (zh) * | 2019-10-31 | 2023-12-26 | 广州市网星信息技术有限公司 | 任务处理方法、装置、服务器、客户端、系统和存储介质 |
-
2020
- 2020-07-22 CN CN202010711615.0A patent/CN111857804B/zh active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CA2840106A1 (en) * | 2012-04-24 | 2013-10-31 | Tencent Technology (Shenzhen) Company Limited | Offline download method, multimedia file download method and system thereof |
CN110471949A (zh) * | 2019-07-11 | 2019-11-19 | 阿里巴巴集团控股有限公司 | 数据血缘分析方法、装置、系统、服务器及存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN111857804A (zh) | 2020-10-30 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN111221559B (zh) | 应用更新方法、装置、存储介质、终端及服务器 | |
CN108156026B (zh) | 对讲机配置方法及装置 | |
CN105808305B (zh) | 静态资源的加载方法和装置 | |
CN104539476A (zh) | 数据包获取方法和装置 | |
CN110689378A (zh) | 广告位广告获取方法、装置及计算机可读存储介质 | |
CN111752598A (zh) | 页面生成方法、装置、电子设备及存储介质 | |
CN109117144B (zh) | 页面处理方法、装置、终端及存储介质 | |
CN110704030A (zh) | 接口配置信息生成方法、装置、电子设备及存储介质 | |
CN109684112B (zh) | 程序文件运行方法、装置、终端及存储介质 | |
CN111857804B (zh) | 离线任务的处理方法、装置、电子设备及存储介质 | |
CN112131135B (zh) | 一种密文运算调试方法、系统和用于密文运算调试的装置 | |
CN110989987B (zh) | 一种门户网页的生成方法、装置、客户端、服务器及存储介质 | |
CN114090303B (zh) | 软件模块调度方法、装置、电子设备、存储介质及产品 | |
CN111090463A (zh) | 资源标识方法及装置、计算机存储介质 | |
CN116166514A (zh) | 多渠道数据联动处理方法、装置、计算机设备和存储介质 | |
CN114546436A (zh) | 一种微前端服务更新方法、装置、电子设备及存储介质 | |
CN110995767B (zh) | 一种请求处理方法及装置 | |
CN114780334A (zh) | 功耗监测方法、功耗监测装置及存储介质 | |
CN111597106A (zh) | 一种埋点管理方法及装置 | |
CN105554141A (zh) | 智能设备资源管控方法及装置 | |
EP3222030A1 (en) | Telecommunications call augmentation system | |
CN110311968B (zh) | 流式加载文件的方法、装置及智能设备 | |
CN112102081B (zh) | 生成区块链的方法、装置、可读存储介质及区块链网络 | |
CN111143184B (zh) | 数据处理方法、装置及系统 | |
CN114727274B (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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant |