[发明专利]基于云监控的线程控制方法、装置、电子设备及存储介质在审
申请号: | 201811537798.8 | 申请日: | 2018-12-15 |
公开(公告)号: | CN109840142A | 公开(公告)日: | 2019-06-04 |
发明(设计)人: | 陈东杰 | 申请(专利权)人: | 平安科技(深圳)有限公司 |
主分类号: | G06F9/48 | 分类号: | G06F9/48;G06F9/50;G06F9/54 |
代理公司: | 深圳市赛恩倍吉知识产权代理有限公司 44334 | 代理人: | 杨毅玲 |
地址: | 518000 广东省深圳市福田区福*** | 国省代码: | 广东;44 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 使用率 线程 数据请求 云监控 预设 存储介质 电子设备 获取系统 进程信息 线程执行 线程数 阈值时 最大线程数 控制装置 系统运行 系统资源 消息队列 应用程序 预先配置 合理化 放入 创建 保证 | ||
一种基于云监控的线程控制方法,包括:当接收到数据请求时,获取系统当前运行的应用程序的进程信息;根据进程信息获取系统的当前线程数;根据当前线程数和预先配置的最大线程数,计算当前线程使用率;判断当前线程使用率是否大于预设线程使用率阈值;当当前线程使用率小于预设线程使用率阈值时,创建新的线程执行所述数据请求;当当前线程使用率大于或者等于预设线程使用率阈值时,将数据请求放入消息队列中。本发明还提供一种基于云监控的线程控制装置、电子设备及存储介质。本发明能够通过云监控当前线程使用率确定是否需要创建新的线程执行新的数据请求,使得系统运行的线程数永远保持或低于最优线程数,保证了系统资源能够最大程度得到合理化的利用。
技术领域
本发明涉及计算机技术领域,具体涉及一种基于云监控的线程控制方法、装置、电子设备及存储介质。
背景技术
计算机系统中,会使用各种系统资源进行任务处理,当有任务需要处理时,系统会收到访问指定系统资源的请求,系统对该请求建立线程,然后利用所建立的线程对该请求进行处理。为了充分利用系统资源,通常会采用多线程方式实现对多个请求的并行处理。然而过高的线程数量会因资源争用、线程切换等导致过多的资源消耗在非必要任务操作上,使得系统因资源消耗过多而导致系统不稳定,影响对请求进行处理的效率。因此,需要对线程数量进行控制以使资源利用达到最优。
现有技术中,通常是在系统启动时,设置一个最大线程数量,并控制当前已建立的线程数量不大于所预先设置的该最大线程数量,进而实现线程控制。
然而,在系统运行负载较大的时候,如果继续根据现有技术中的最大线程数来建立线程,可能会出现建立的线程数量接近最大线程数,从而引起系统不稳定,或者引起系统运行卡死,进而影响系统的资源利用率。
发明内容
鉴于以上内容,有必要提出一种基于云监控的线程控制方法、装置、电子设备及存储介质,能够通过云监控系统当前线程使用率来确定是否需要创建新的线程执行新的数据请求,使得系统运行的线程数永远保持或低于最优线程数。
本发明的第一方面提供一种基于云监控的线程控制方法,所述方法包括:
当接收到数据请求时,获取系统当前运行的应用程序的进程信息;
根据所述进程信息获取系统的当前线程数;
根据所述当前线程数和预先配置的最大线程数,计算当前线程使用率;
判断所计算的当前线程使用率是否大于预设线程使用率阈值;
当所计算的当前线程使用率小于所述预设线程使用率阈值时,创建新的线程执行所述数据请求;或者
当所计算的当前线程使用率大于或者等于预设线程使用率阈值时,将所述数据请求放入消息队列中。
根据本发明的一个优选实施例,所述根据所述进程信息获取系统的当前线程数包括:
获取当前运行的所有应用程序;
从每个运行的应用程序对应的进程信息中获取每个应用程序使用的线程数;
将每个应用程序使用的线程数进行累加,得到系统当前的线程数。
根据本发明的一个优选实施例,在所述创建新的线程处理所述数据请求时,所述方法还包括:
获取所述数据请求中的线程请求数;
计算所述线程请求数与所述当前线程数之和,得到未来线程数;
根据所述未来线程数计算未来线程使用率;
判断所述未来线程使用率是否小于所述预设线程使用率阈值;
当所述未来线程使用率小于或者等于所述预设线程使用率阈值时,创建所述线程请求数对应的线程执行所述数据请求。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于平安科技(深圳)有限公司,未经平安科技(深圳)有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201811537798.8/2.html,转载请声明来源钻瓜专利网。