[发明专利]一种定时任务处理方法及装置在审
| 申请号: | 202011410625.7 | 申请日: | 2020-12-04 |
| 公开(公告)号: | CN112579269A | 公开(公告)日: | 2021-03-30 |
| 发明(设计)人: | 刘沛峰;陈朝亮;卢道和;陈晔 | 申请(专利权)人: | 深圳前海微众银行股份有限公司 |
| 主分类号: | G06F9/48 | 分类号: | G06F9/48;G06F16/27 |
| 代理公司: | 北京同达信恒知识产权代理有限公司 11291 | 代理人: | 张怀阳 |
| 地址: | 518027 广东省深圳市*** | 国省代码: | 广东;44 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 一种 定时 任务 处理 方法 装置 | ||
本发明公开了一种定时任务处理方法及装置,该方法包括获取定时任务,并将定时任务存储在缓存中,根据缓存中定时任务的标识和各实例的标识,为各实例分配缓存中的定时任务,按照预设时间间隔将定时任务同步到各实例的本地缓存中,以使各实例以预设频率从各实例的本地缓存中获取符合时间条件的定时任务进行处理。实例在处理定时任务时,是在实例自己的本地缓存中获取相应的定时任务进行处理,不会实时的从服务器的缓存获取定时任务,因而不会增加服务器的吞吐量,也不会降低服务器的缓存性能。
技术领域
本发明涉及金融科技(Fintech)技术领域,尤其涉及一种定时任务处理方法及装置。
背景技术
随着计算机技术的发展,越来越多的技术应用在金融领域,传统金融业正在逐步向金融科技转变,但由于金融行业的安全性、实时性要求,也对技术提出的更高的要求。在金融领域的客服作业系统中,如何处理定时任务是一个重要的问题。
目前,在客服作业系统场景中处理定时任务时,大部分是由后台服务器设定定时任务,通过不同的任务设置不同的定时器,但是在任务场景复杂且任务多的情况下,对不同的任务设置不同的定时器的这种方式,会占用过高的系统资源,导致服务器性能大幅下降。
发明内容
本发明实施例提供一种定时任务处理方法及装置,用以提高服务器的性能,降低占用的系统资源。
第一方面,本发明实施例提供一种定时任务处理方法,包括:
获取定时任务,并将所述定时任务存储在缓存中;
根据所述缓存中定时任务的标识和各实例的标识,为所述各实例分配所述缓存中的定时任务;
按照预设时间间隔将所述定时任务同步到所述各实例的本地缓存中,以使所述各实例以预设频率从所述各实例的本地缓存中获取符合时间条件的定时任务进行处理。
上述技术方案中,实例在处理定时任务时,是在实例自己的本地缓存中获取相应的定时任务进行处理,不会实时的从服务器的缓存获取定时任务,因而不会增加服务器的吞吐量,也不会降低服务器的缓存性能。
可选的,所述根据所述缓存中定时任务的标识和各实例的标识,为所述各实例分配所述缓存中的定时任务,包括:
针对所述缓存中任一定时任务和所述各实例中的任一实例,将所述任一定时任务的标识和所述任一实例的标识进行哈希处理后,确定出所述任一定时任务的标识和所述任一实例的标识在预设整数范围区间中的位置;
若所述缓存中第一定时任务的位置小于第一实例的位置且距离所述第一实例的位置最近,则将所述第一定时任务分配给所述第一实例;
若所述缓存中所述第一定时任务的位置大于任一实例的位置,则将所述第一定时任务分配给距离所述预设整数范围区间的起始位置最近的实例。
上述技术方案中,通过判断各定时任务在预设整数范围区间中的位置来为实例分配任务,可以合理的为各实例分配任务,提高定时任务的处理效率,同时可以避免出现同一定时任务由多个实例处理的情况,降低了定时任务被分配给多个实例的风险。
可选的,所述为所述各实例分配所述缓存中的定时任务之后,还包括:
若所述各实例中任一实例发生故障,则将发生故障的实例从所述预设整数范围区间中清除,并将分配给所述发生故障的实例的定时任务重新分配。
上述技术方案中,通过将发生故障的实例进行清除,重新分配定时任务,可以保证定时任务的正常执行。
可选的,所述将所述任一定时任务的标识和所述任一实例的标识进行哈希处理后,确定出所述任一定时任务的标识和所述任一实例的标识在预设整数范围区间中的位置,包括:
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于深圳前海微众银行股份有限公司,未经深圳前海微众银行股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202011410625.7/2.html,转载请声明来源钻瓜专利网。
- 上一篇:一种多功能医用管腔复合支架
- 下一篇:一种高功率充电器防护系统





