预览加载中,请您耐心等待几秒...
1/10
2/10
3/10
4/10
5/10
6/10
7/10
8/10
9/10
10/10

亲,该文档总共14页,到这已经超出免费预览范围,如果喜欢就直接下载吧~

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

(19)国家知识产权局(12)发明专利申请(10)申请公布号CN115934277A(43)申请公布日2023.04.07(21)申请号202211542469.9(22)申请日2022.12.02(71)申请人华南农业大学地址510000广东省广州市天河区五山街道五山路483号(72)发明人李震雷昂然左嘉明(74)专利代理机构北京慕达星云知识产权代理事务所(特殊普通合伙)11465专利代理师符继超(51)Int.Cl.G06F9/48(2006.01)权利要求书2页说明书6页附图5页(54)发明名称应对油样分析请求的调度方法、系统、装置及存储介质(57)摘要本发明提供了一种应对油样分析请求的调度方法、系统、装置及存储介质,包括:采集油样数据,生成任务并发送任务请求;主线程创建子线程构成线程池,子线程创建相应协程;空闲协程空转执行idle方法,以监听并添加任务;基于任务请求,创建调度协程,指定线程或空闲线程执行run方法,从任务队列中取出任务,线程包括主线程和子线程;执行提取任务步骤的协程作为用户态的任务执行载体执行任务;任务执行完成,任务执行载体主动切回调度协程,结束本次任务调度。本发明通过实现用户态的执行任务载体以及调度方法、模型,解决了大规模的油样数据采集设备在短时间内产生高并发请求的场景下,后台系统资源被抢占导致调度过慢的问题。CN115934277ACN115934277A权利要求书1/2页1.一种应对油样分析请求的调度方法,其特征在于,包括以下步骤:S1:采集油样数据,生成任务并发送任务请求;S2:主线程创建子线程构成线程池,子线程创建相应协程;S3:空闲协程空转执行idle方法,以监听并添加任务;S4:基于任务请求,创建调度协程,指定线程或空闲线程执行run方法,从任务队列中取出任务,线程包括主线程和子线程;S5:执行提取任务步骤的协程作为用户态的任务执行载体执行任务;S6:任务执行完成,任务执行载体主动切回调度协程,结束本次任务调度。2.根据权利要求1所述的应对油样分析请求的调度方法,其特征在于,所述S1中,生成的任务通过指定协议发送任务请求,包括:传输控制协议、用户数据包协议、超文本传输协议或WebSocket协议。3.根据权利要求1所述的应对油样分析请求的调度方法,其特征在于,所述S2具体包括以下子步骤:S21:根据需求创建N个子线程,N为所述调度方法所应用装置的处理器核心数二倍;S22:每个子线程自动创建一个主协程,其根据任务需求批量创建或销毁;协程数量上限为M,M根据所述调度方法所应用设备的内存空间大小确定。4.根据权利要求1所述的应对油样分析请求的调度方法,其特征在于,所述S3具体包括以下子步骤:S31:空闲协程执行idle方法;S32:设置需要监听并响应的事件,事件为读写事件组合,所述事件由任务触发产生;S33:判断调度器是否停止,如果已经停止则终止当前idle方法;S34:设置监听行为的超时时间,并循环监听事件集合;S35:判断跳出循环的原因:如果是硬件中断导致跳出循环,则继续进行S34;否则进一步判断是否为S34预设的超时时间到达,若是超时时间到达,则加入超时任务集合,并先执行超时任务集合内已超时任务,执行完毕后再进入S36;S36:判断响应事件是否存在异常:如果响应为EPOLLERR或EPOLLHUP,标记删除该事件;不存在异常则标记对应读写事件;S37:根据当前协程是否属于调度器调度范围,决定协程切换回调度协程还是所在线程的主协程。5.根据权利要求1所述的应对油样分析请求的调度方法,其特征在于,所述S4具体包括以下子步骤:S41:判断当前线程号是否等于调度器所在线程号,如果不相等,确定当前线程的主协程是该线程的调度协程;S42:循环遍历任务队列获取待处理任务;S43:判断待处理任务状态:如果待处理任务具有指定的执行线程则tickle通知指定线程;如果当前协程处于运行状态,则跳过该任务;否则直接调度该任务,将工作线程加入活跃线程池,然后跳出循环;S44:遍历结束后,判断任务队列是否非空,如果任务队列非空,tickle通知空闲线程执行run方法进行处理,否则切换至步骤S3。2CN115934277A权利要求书2/2页6.根据权利要求1所述的应对油样分析请求的调度方法,其特征在于,所述S5所执行任务种类根据需求确定。7.根据权利要求1所述的应对油样分析请求的调度方法,其特征在于,所述S6具体包括以下子步骤:协程切换时,根据任务调度方法所在的计算机设备保存相关寄存器,所述相关寄存器中保存执行现场上下文,包括协程切换时,任务的执行状态、数据变量值、寄存器信息。8.一种根据权利要求1‑7中任一项所述的应对油样分析请求的调度方法的调度系统,其特征在于,包括:任务单元、协程单元、调度单元和时间管理单元;其中