[发明专利]基于分布式系统的异步任务控制方法及系统有效
申请号: | 201610854007.9 | 申请日: | 2016-09-26 |
公开(公告)号: | CN107870822B | 公开(公告)日: | 2020-11-24 |
发明(设计)人: | 唐雁斌 | 申请(专利权)人: | 平安科技(深圳)有限公司 |
主分类号: | G06F9/54 | 分类号: | G06F9/54 |
代理公司: | 深圳市沃德知识产权代理事务所(普通合伙) 44347 | 代理人: | 高杰;于志光 |
地址: | 518000 广东省深*** | 国省代码: | 广东;44 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 基于 分布式 系统 异步 任务 控制 方法 | ||
本发明公开了一种基于分布式系统的异步任务控制方法,包括:异步任务控制系统为对应的分布式系统的异步任务建立异步任务队列,并对异步任务队列中的异步任务数量进行监控;若异步任务数量小于预设阈值,则从数据库系统获取数据库锁,为分布式系统抓取预设数量的异步任务,并放入异步任务队列中;为抓取的各个异步任务生成对应的任务处理中标识,以防止抓取的各个异步任务被其他异步任务控制系统抓取,并释放获取的数据库锁,以供各个分布式系统对应的异步任务控制系统进行获取。本发明还公开了一种基于分布式系统的异步任务控制系统。本发明充分利用了每一分布式系统来进行异步任务处理,有效地提升了整个分布式系统的异步任务处理能力。
技术领域
本发明涉及计算机技术领域,尤其涉及一种基于分布式系统的异步任务控制方法及系统。
背景技术
随着移动互联网、云计算、大数据时代的到来,现有的分布式系统的异步任务处理往往只能单线程或指定单台服务器处理,经常容易出现有的分布式系统超负荷运行,而有的分布式系统处于空闲状态的情况发生,无法充分利用整个分布式系统的性能来进行异步任务处理,造成任务处理效率低下。
发明内容
本发明的主要目的在于提供一种基于分布式系统的异步任务控制方法及系统,旨在提高分布式系统的异步任务处理能力。
为实现上述目的,本发明提供的一种基于分布式系统的异步任务控制方法,所述方法包括以下步骤:
异步任务控制系统为对应的分布式系统的异步任务建立异步任务队列,并对所述异步任务队列中的异步任务数量进行监控;
若所述异步任务队列中的异步任务数量小于预设阈值,则从数据库系统获取数据库锁;
若成功从所述数据库系统获取到数据库锁,则为所述分布式系统抓取预设数量的异步任务,并放入所述异步任务队列中;
为抓取的各个异步任务生成对应的任务处理中标识,以防止抓取的各个异步任务被其他分布式系统对应的异步任务控制系统抓取,并释放获取的数据库锁,以供各个分布式系统对应的异步任务控制系统进行获取。
优选地,所述若成功从所述数据库系统获取到数据库锁,则为所述分布式系统抓取预设数量的异步任务,并放入所述异步任务队列中的步骤包括:
若所述异步任务控制系统成功从所述数据库系统获取到数据库锁,且所述预设阈值与所述异步任务队列中的异步任务数量的差值数量大于或等于预设固定数量,则为所述分布式系统抓取预设固定数量的异步任务,并放入所述异步任务队列中,以供所述分布式系统对所述异步任务队列中的异步任务进行处理。
优选地,所述若成功从所述数据库系统获取到数据库锁,则为所述分布式系统抓取预设数量的异步任务放入所述异步任务队列中的步骤包括:
若所述异步任务控制系统成功从所述数据库系统获取到数据库锁,且所述预设阈值与所述异步任务队列中的异步任务数量的差值数量小于预设固定数量,则为所述分布式系统抓取所述差值数量的异步任务,并放入所述异步任务队列中,以供所述分布式系统对所述异步任务队列中的异步任务进行处理。
优选地,该方法还包括:
若所述异步任务队列中的异步任务数量大于或等于预设阈值,则所述异步任务控制系统停止从所述数据库系统获取数据库锁。
此外,为实现上述目的,本发明还提供一种基于分布式系统的异步任务控制系统,所述异步任务控制系统包括:
建立模块,用于为对应的分布式系统的异步任务建立异步任务队列,并对所述异步任务队列中的异步任务数量进行监控;
获取模块,用于若所述异步任务队列中的异步任务数量小于预设阈值,则从数据库系统获取数据库锁;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于平安科技(深圳)有限公司,未经平安科技(深圳)有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201610854007.9/2.html,转载请声明来源钻瓜专利网。
- 上一篇:应用程序的跨平台调用方法及系统
- 下一篇:一种养胃豆干的生产工艺