[发明专利]一种多线程任务处理方法、装置及电子设备有效
| 申请号: | 202010946007.8 | 申请日: | 2020-09-10 |
| 公开(公告)号: | CN112000455B | 公开(公告)日: | 2022-02-01 |
| 发明(设计)人: | 王明星;包明生;杨接康 | 申请(专利权)人: | 华云数据控股集团有限公司 |
| 主分类号: | G06F9/48 | 分类号: | G06F9/48;G06F9/50 |
| 代理公司: | 苏州友佳知识产权代理事务所(普通合伙) 32351 | 代理人: | 储振 |
| 地址: | 214000 江*** | 国省代码: | 江苏;32 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 一种 多线程 任务 处理 方法 装置 电子设备 | ||
1.一种多线程任务处理方法,其特征在于,包括:
为线程池的核心线程数设置初始化阈值范围;
对输入线程池的任务过滤出IO密集型任务;
采用轮询方式获取宿主机的指标数据,确定是否创建或者删除核心线程,以确定线程池的核心线程数是否触发调整初始化阈值范围以得到当前阈值范围的事件;
其中,是否触发调整初始化阈值范围的事件基于宿主机的指标数据予以确定,所述初始化阈值范围由核心线程数最大值与核心线程数最小值予以确定。
2.根据权利要求1所述的多线程任务处理方法,其特征在于,所述初始化阈值范围仅由线程池根据宿主机的指标数据予以确定,所述当前阈值范围由线程池仅根据对宿主机执行轮询的前一个状态中宿主机的指标数据予以确定。
3.根据权利要求1所述的多线程任务处理方法,其特征在于,所述核心线程使用饱和策略响应由线程池所接收的自外部发起的多线程任务的访问请求,所述饱和策略由线程池下发。
4.根据权利要求1至3中任一项所述的多线程任务处理方法,所述宿主机的指标数据至少由CPU开销和/或磁盘IOPS予以定义。
5.根据权利要求4所述的多线程任务处理方法,其特征在于,采用轮询方式获取宿主机的指标数据后判断线程池中是否存在响应IO密集型任务所匹配的核心线程;
若是,则不更改初始化阈值范围或者当前阈值范围;
若否,则基于宿主机的指标数据予以确定初始化阈值范围或者当前阈值范围的调节趋势,其中调节趋势为增加核心线程数或者减少核心线程数。
6.根据权利要求4所述的多线程任务处理方法,其特征在于,所述多线程任务处理方法还包括:对初始化阈值范围或者当前阈值范围设置安全阈值范围,所述安全阈值范围大于初始化阈值范围的最小值或者当前阈值范围的最小值且小于初始化阈值范围的最大值或者当前阈值范围的最大值。
7.一种多线程任务处理装置,其特征在于,包括:
初始化模块,为线程池的核心线程数设置初始化阈值范围;
任务过滤模块,对输入线程池的任务过滤出IO密集型任务;
轮询模块,采用轮询方式获取宿主机的指标数据,确定是否创建或者删除核心线程,以确定线程池的核心线程数是否触发调整初始化阈值范围以得到当前阈值范围的事件;
阈值调整模块,基于宿主机的指标数据确定是否触发调整初始化阈值范围的事件予以确定,所述初始化阈值范围由核心线程数最大值与核心线程数最小值予以确定。
8.根据权利要求7所述的多线程任务处理装置,其特征在于,所述初始化阈值范围仅由线程池根据宿主机的指标数据予以确定,所述当前阈值范围由线程池仅根据对宿主机执行轮询的前一个状态中宿主机的指标数据予以确定。
9.根据权利要求7所述的多线程任务处理装置,其特征在于,所述宿主机的指标数据至少由CPU开销和/或磁盘IOPS予以定义。
10.根据权利要求7所述的多线程任务处理装置,其特征在于,基于所述阈值调整模块对初始化阈值范围或者当前阈值范围设置安全阈值范围,所述安全阈值范围大于初始化阈值范围的最小值或者当前阈值范围的最小值且小于初始化阈值范围的最大值或者当前阈值范围的最大值。
11.一种电子设备,其特征在于,包括:
处理器,由至少一个存储单元组成的存储装置,以及
在处理器与存储装置之间建立通信连接的通信总线;
所述处理器用于执行存储装置中存储的一个或者多个程序,以实现如权利要求1至6中任一项所述的多线程任务处理方法。
12.根据权利要求11所述的电子设备,其特征在于,所述电子设备至少被配置为计算机、服务器、数据中心、虚拟集群、便携式移动终端、金融支付平台或者ERP系统。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于华云数据控股集团有限公司,未经华云数据控股集团有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202010946007.8/1.html,转载请声明来源钻瓜专利网。





