System.ArgumentOutOfRangeException: 索引和长度必须引用该字符串内的位置。 参数名: length 在 System.String.Substring(Int32 startIndex, Int32 length) 在 zhuanliShow.Bind()
【技术实现步骤摘要】
本申请涉及计算机,尤其涉及基于php-fpm的异步处理方法、装置、设备及介质。
技术介绍
1、随着移动网络的进步,基于php(hypertext preprocessor,超文本预处理器)的web(网络)服务,即php-fpm(fastcgi process manager,fastcgi进程管理器)已被广泛使用,但是由于php-fpm缺乏异步处理功能,例如,针对日志记录、信息上报等场景的业务数据均需要与常规逻辑排队,按顺序执行,使得数据处理效率低。
技术实现思路
1、为克服相关技术中存在的问题,本申请提供基于php-fpm的异步处理方法、装置、设备及介质,以实现业务数据的异步处理,提高数据处理效率。
2、本申请第一方面提供基于php-fpm的异步处理方法,包括:
3、在php-fpm主进程启动后,确定满足预设条件的第一fpm进程;
4、控制所述第一fpm进程拉起旁路守护进程,并由所述旁路守护进程拉起至少一个旁路工作进程;
5、控制所述旁路工作进程监控与其对应的消息队列,以获取所述消息队列中的所述业务数据,对所述业务数据进行异步处理。
6、作为本申请一种可能的实施方式,在该实施方式中,所述控制所述第一fpm进程拉起旁路守护进程,并由所述旁路守护进程拉起至少一个旁路工作进程,包括:
7、控制所述第一fpm进程拉起第一旁路守护进程,并由所述第一旁路守护进程拉起第二旁路守护进程,进而由所述第二旁路守护进程拉起至少一个
8、作为本申请一种可能的实施方式,在该实施方式中,还包括:
9、控制所述第一旁路守护进程退出,由所述第二旁路守护进程监测所述至少一个旁路工作进程的存活状态,以在监测到具有退出状态的旁路工作进程时,将所述退出状态的旁路工作进程拉起。
10、作为本申请一种可能的实施方式,在该实施方式中,所述确定满足预设条件的第一fpm进程,包括:
11、确定抢占到信号量,且确定共享内存的指定空间中不具有进程id的fpm进程为满足预设条件的第一fpm进程;其中,所述抢占到信号量指代为将所述信号量由未抢占状态切换到已抢占状态。
12、作为本申请一种可能的实施方式,在该实施方式中,还包括:
13、将所述旁路守护进程的进程id存入所述共享内存的指定空间中;
14、控制所述第一fpm进程归还所述信号量,其中,所述归还所述信号量指代为由所述已抢占状态切换到所述未抢占状态。
15、作为本申请一种可能的实施方式,在该实施方式中,还包括:
16、控制拉起的至少一个第二fpm进程判断所述信号量是否处于已抢占状态,若是,禁止所述第二fpm进程拉起旁路守护进程;
17、若否,在所述第二fpm进程抢占到所述信号量后,控制所述第二fpm进程判断所述共享内存的指定空间是否具有进程id,若是,且确定所述进程id所属进程为有效进程,则禁止所述第二fpm进程拉起旁路守护进程。
18、作为本申请一种可能的实施方式,在该实施方式中,所述控制所述第一fpm进程拉起旁路守护进程,包括:
19、控制所述第一fpm进程调用指定函数复制所述第一fpm进程中的一个子进程,作为旁路守护进程。
20、本申请第二方面提供基于php-fpm的异步处理装置,包括:
21、确定进程单元,用于在php-fpm主进程启动后,确定满足预设条件的第一fpm进程;
22、拉起进程单元,用于控制所述第一fpm进程拉起旁路守护进程,并由所述旁路守护进程拉起至少一个旁路工作进程;
23、第一控制单元,用于控制所述旁路工作进程监控与其对应的系统消息队列,以获取所述系统消息队列中的所述业务数据,对所述业务数据进行异步处理。
24、本申请第三方面提供一种电子设备,包括:
25、处理器;以及
26、存储器,其上存储有可执行代码,当所述可执行代码被所述处理器执行时,使所述处理器执行如上所述的方法。
27、本申请第四方面提供一种非暂时性机器可读存储介质,其上存储有可执行代码,当所述可执行代码被电子设备的处理器执行时,使所述处理器执行如上所述的方法。
28、本申请提供了基于php-fpm的异步处理方法,通过在php-fpm主进程启动后,确定满足预设条件的第一fpm进程;控制所述第一fpm进程拉起旁路守护进程,并由所述旁路守护进程拉起至少一个旁路工作进程;控制所述旁路工作进程监控与其对应的消息队列,以获取所述消息队列中的业务数据,对所述业务数据进行异步处理;由此可见,本申请能够通过拉起的旁路工作进程进行业务数据的异步处理,提高了数据处理的效率。
29、应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本申请。
本文档来自技高网...【技术保护点】
1.基于PHP-FPM的异步处理方法,其特征在于,包括:
2.根据权利要求1所述的方法,其特征在于,所述控制所述第一FPM进程拉起旁路守护进程,并由所述旁路守护进程拉起至少一个旁路工作进程,包括:
3.根据权利要求2所述的方法,其特征在于,还包括:
4.根据权利要求1所述的方法,其特征在于,所述确定满足预设条件的第一FPM进程,包括:
5.根据权利要求4所述的方法,其特征在于,还包括:
6.根据权利要求5所述的方法,其特征在于,还包括:
7.根据权利要求1所述的方法,其特征在于,所述控制所述第一FPM进程拉起旁路守护进程,包括:
8.基于PHP-FPM的异步处理装置,其特征在于,包括:
9.一种电子设备,其特征在于,包括:
10.一种非暂时性机器可读存储介质,其上存储有可执行代码,当所述可执行代码被电子设备的处理器执行时,使所述处理器执行如权利要求1-7中任一项所述的方法。
【技术特征摘要】
1.基于php-fpm的异步处理方法,其特征在于,包括:
2.根据权利要求1所述的方法,其特征在于,所述控制所述第一fpm进程拉起旁路守护进程,并由所述旁路守护进程拉起至少一个旁路工作进程,包括:
3.根据权利要求2所述的方法,其特征在于,还包括:
4.根据权利要求1所述的方法,其特征在于,所述确定满足预设条件的第一fpm进程,包括:
5.根据权利要求4所述的方法,其特征在于,还包括:
<...【专利技术属性】
技术研发人员:姜晓腾,
申请(专利权)人:海南值选科技有限公司,
类型:发明
国别省市:
还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。