一种对Python中并发进程的日志处理方法及装置与流程

文档序号:13685620阅读:194来源:国知局
一种对Python中并发进程的日志处理方法及装置与流程

本发明实施例涉及计算机技术领域,具体涉及一种对python中并发进程的日志处理方法及装置。



背景技术:

在python项目开发中,都要记录进程执行的日志,并将日志按天进行分割,方便调试问题与记录过程。因为进程有上下文切换,所以各个进程的操作不一样,并且有干扰(例如,有的进程在删除,有的进程还在写),因此会存在并发问题。

目前,通常用来解决python多进程下日志分割后的进程并发问题的方法是:给文件加进程锁来解决并发问题,即在多进程写日志文件过程中,只能有一个进程获取文件句柄操作的权限。但是,使用进程文件锁会有个问题:文件锁的性能比较低。

鉴于此,如何解决python多进程下日志分割后的进程并发问题,并提升性能成为目前需要解决的技术问题。



技术实现要素:

由于现有方法存在上述问题,本发明实施例提出一种对python中并发进程的日志处理方法及装置。

第一方面,本发明实施例提出一种对python中并发进程的日志处理方法,包括:

获取python中当前运行的各并发进程的当前时间戳;

对于所述各并发进程中的任一进程,利用预先设置的用户自定义类,判断当前进程的当前时间戳与当前日志文件的时间是否匹配;

若判断获知当前进程的当前时间戳与当前日志文件的时间不匹配,则创建一个以当前进程的当前时间戳命名的目标日志文件,以利用所述目标日志文件记录当前进程的事件。

可选地,所述当前日志文件以当前日志文件的时间命名,相应地,所述对于所述各并发进程中的任一进程,利用预先设置的用户自定义类,判断当前进程的当前时间戳与当前日志文件的时间是否匹配,包括:

对于所述各并发进程中的任一进程,利用预先设置的用户自定义类,通过判断当前进程的当前时间戳与当前日志文件的文件名是否匹配,来确定当前进程的当前时间戳与当前日志文件的时间是否匹配。

可选地,在所述对于所述各并发进程中的任一进程,利用预先设置的用户自定义类,判断当前进程的当前时间戳与当前日志文件的时间是否匹配之前,所述方法还包括:

预先设置用户自定义类,所述用户自定义类继承python标准库中的handler类,并增加第一函数和第二函数;

其中,所述第一函数,用于判断进程的当前时间戳与当前日志文件的时间是否匹配;

所述第二函数,用于若判断获知进程的当前时间戳与当前日志文件的时间不匹配,则创建一个以当前进程的当前时间戳命名的目标日志文件,以利用所述目标日志文件记录当前进程的事件。

可选地,所述第二函数,还用于若判断获知进程的当前时间戳与当前日志文件的时间相匹配,则利用当前日志文件记录当前进程的事件;

相应地,在所述判断当前进程的当前时间戳与当前日志文件的时间是否匹配之后,所述方法还包括:

若判断获知当前进程的当前时间戳与当前日志文件的时间相匹配,则利用当前日志文件记录当前进程的事件。

第二方面,本发明实施例还提出一种对python中并发进程的日志处理装置,包括:

获取模块,用于获取python中当前运行的各并发进程的当前时间戳;

判断模块,用于对于所述各并发进程中的任一进程,利用预先设置的用户自定义类,判断当前进程的当前时间戳与当前日志文件的时间是否匹配;

创建模块,用于若判断获知当前进程的当前时间戳与当前日志文件的时间不匹配,则创建一个以当前进程的当前时间戳命名的目标日志文件,以利用所述目标日志文件记录当前进程的事件。

可选地,所述当前日志文件以当前日志文件的时间命名;

相应地,所述判断模块,具体用于

对于所述各并发进程中的任一进程,利用预先设置的用户自定义类,通过判断当前进程的当前时间戳与当前日志文件的文件名是否匹配,来确定当前进程的当前时间戳与当前日志文件的时间是否匹配。

可选地,所述装置还包括:

设置模块,用于预先设置用户自定义类,所述用户自定义类继承python标准库中的handler类,并增加第一函数和第二函数;

其中,所述第一函数,用于判断进程的当前时间戳与当前日志文件的时间是否匹配;

所述第二函数,用于若判断获知进程的当前时间戳与当前日志文件的时间不匹配,则创建一个以当前进程的当前时间戳命名的目标日志文件,以利用所述目标日志文件记录当前进程的事件。

可选地,所述第二函数,还用于若判断获知进程的当前时间戳与当前日志文件的时间相匹配,则利用当前日志文件记录当前进程的事件;

相应地,所述装置还包括:

记录模块,用于若判断获知当前进程的当前时间戳与当前日志文件的时间相匹配,则利用当前日志文件记录当前进程的事件。

第三方面,本发明实施例还提出一种电子设备,包括:处理器、存储器、总线及存储在存储器上并可在处理器上运行的计算机程序;

其中,所述处理器,存储器通过所述总线完成相互间的通信;

所述处理器执行所述计算机程序时实现上述方法。

第四方面,本发明实施例提供一种非暂态计算机可读存储介质,所述非暂态计算机可读存储介质上存储有计算机程序,该计算机程序被处理器执行时实现上述方法。

由上述技术方案可知,本发明实施例通过获取python中当前运行的各并发进程的当前时间戳;对于各并发进程中的任一进程,利用预先设置的用户自定义类,判断当前进程的当前时间戳与当前日志文件的时间是否匹配;若判断获知当前进程的当前时间戳与当前日志文件的时间不匹配,则创建一个以当前进程的当前时间戳命名的目标日志文件,以利用所述目标日志文件记录当前进程的事件,由此,能够解决python多进程下日志分割后的进程并发问题,并且继承了python原生模块的函数,避免了不必要损耗性能的进程文件锁,提升了性能。

附图说明

为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些图获得其他的附图。

图1为本发明一实施例提供的一种对python中并发进程的日志处理方法的流程示意图;

图2为本发明一实施例提供的一种对python中并发进程的日志处理装置的结构示意图;

图3为本发明一实施例提供的电子设备的实体结构示意图。

具体实施方式

下面结合附图,对本发明的具体实施方式作进一步描述。以下实施例仅用于更加清楚地说明本发明的技术方案,而不能以此来限制本发明的保护范围。

图1示出了本发明一实施例提供的一种对python中并发进程的日志处理方法的流程示意图,如图1所示,本实施例的对python中并发进程的日志处理方法,包括:

s101、获取python中当前运行的各并发进程的当前时间戳。

s102、对于所述各并发进程中的任一进程,利用预先设置的用户自定义类,判断当前进程的当前时间戳与当前日志文件的时间是否匹配。

s103、若判断获知当前进程的当前时间戳与当前日志文件的时间不匹配,则创建一个以当前进程的当前时间戳命名的目标日志文件,以利用所述目标日志文件记录当前进程的事件。

可以理解的是,本实施例只通过利用预先设置的用户自定义类增加了一个判断逻辑,再根据判断结果进行相应处理,就可以避免意外操作以及现有技术中的进程文件锁所带来的性能损耗。

本实施例的解决python多进程下日志分割后的进程并发问题的方法,可以利用处理器实现,通过获取python中当前运行的各并发进程的当前时间戳;对于各并发进程中的任一进程,利用预先设置的用户自定义类,判断当前进程的当前时间戳与当前日志文件的时间是否匹配;若判断获知当前进程的当前时间戳与当前日志文件的时间不匹配,则创建一个以当前进程的当前时间戳命名的目标日志文件,以利用所述目标日志文件记录当前进程的事件,由此,能够解决python多进程下日志分割后的进程并发问题,并且继承了python原生模块的函数,避免了不必要损耗性能的进程文件锁,提升了性能。

进一步地,在上述方法实施例的基础上,本实施例所述当前日志文件可以以当前日志文件的时间命名,相应地,上述步骤s102可以包括:

对于所述各并发进程中的任一进程,利用预先设置的用户自定义类,通过判断当前进程的当前时间戳与当前日志文件的文件名是否匹配,来确定当前进程的当前时间戳与当前日志文件的时间是否匹配。

举例来说,可以利用python中的正则表达式re.sub()函数来判断当前进程的当前时间戳与当前日志文件的文件名是否匹配。本实施例并不对其进行限制,也可以利用其他函数或方法来判断当前进程的当前时间戳与当前日志文件的文件名是否匹配。

可以理解的是,在当前日志文件以当前日志文件的时间命名时,若当前进程的当前时间戳与当前日志文件的文件名相匹配,则可以确定当前进程的当前时间戳与当前日志文件的时间相匹配;若当前进程的当前时间戳与当前日志文件的文件名不匹配,则可以确定当前进程的当前时间戳与当前日志文件的时间不匹配。

进一步地,在上述方法实施例的基础上,在上述步骤s102之前,所述方法还包括:

预先设置用户自定义类,所述用户自定义类继承python标准库中的handler类(即python自带的logging库中的handler类),并增加第一函数和第二函数;

其中,所述第一函数,用于判断进程的当前时间戳与当前日志文件的时间是否匹配;

所述第二函数,用于若判断获知进程的当前时间戳与当前日志文件的时间不匹配,则创建一个以当前进程的当前时间戳命名的目标日志文件,以利用所述目标日志文件记录当前进程的事件。

在具体应用中,所述预先设置的用户自定义类可以为processsavehandler类。

可以理解的是,本实施例预先设置用户自定义类增加了一个判断逻辑(即更改逻辑代码),再根据判断结果进行相应处理,可以避免意外操作以及现有技术中的进程文件锁所带来的性能损耗。

进一步地,在上述方法实施例的基础上,所述第二函数,还可用于若判断获知进程的当前时间戳与当前日志文件的时间相匹配,则利用当前日志文件记录当前进程的事件;

相应地,在上述步骤s102之后,所述方法还可以包括:

若判断获知当前进程的当前时间戳与当前日志文件的时间相匹配,则利用当前日志文件记录当前进程的事件。

本实施例的对python中并发进程的日志处理方法,能够解决python多进程下日志分割后的进程并发问题,并且继承了python原生模块的函数,更改逻辑代码避免了不必要损耗性能的进程文件锁,提升了性能。

图2示出了本发明一实施例提供的一种对python中并发进程的日志处理装置的结构示意图,如图2所示,本实施例的对python中并发进程的日志处理装置,包括:获取模块21、判断模块22和创建模块23;其中:

所述获取模块21,用于获取python中当前运行的各并发进程的当前时间戳;

所述判断模块22,用于对于所述各并发进程中的任一进程,利用预先设置的用户自定义类,判断当前进程的当前时间戳与当前日志文件的时间是否匹配;

所述创建模块23,用于若判断获知当前进程的当前时间戳与当前日志文件的时间不匹配,则创建一个以当前进程的当前时间戳命名的目标日志文件,以利用所述目标日志文件记录当前进程的事件。

具体地,所述获取模块21获取python中当前运行的各并发进程的当前时间戳;所述判断模块22对于所述各并发进程中的任一进程,利用预先设置的用户自定义类,判断当前进程的当前时间戳与当前日志文件的时间是否匹配;所述创建模块23若判断获知当前进程的当前时间戳与当前日志文件的时间不匹配,则创建一个以当前进程的当前时间戳命名的目标日志文件,以利用所述目标日志文件记录当前进程的事件。

可以理解的是,本实施例只通过利用预先设置的用户自定义类增加了一个判断逻辑,再根据判断结果进行相应处理,就可以避免意外操作以及现有技术中的进程文件锁所带来的性能损耗。

本实施例的对python中并发进程的日志处理装置,可以利用处理器实现,能够解决python多进程下日志分割后的进程并发问题,并且继承了python原生模块的函数,避免了不必要损耗性能的进程文件锁,提升了性能。

进一步地,在上述实施例的基础上,本实施例所述当前日志文件可以以当前日志文件的时间命名;

相应地,所述判断模块22,可具体用于

对于所述各并发进程中的任一进程,利用预先设置的用户自定义类,通过判断当前进程的当前时间戳与当前日志文件的文件名是否匹配,来确定当前进程的当前时间戳与当前日志文件的时间是否匹配。

举例来说,可以利用python中的正则表达式re.sub()函数来判断当前进程的当前时间戳与当前日志文件的文件名是否匹配。本实施例并不对其进行限制,也可以利用其他函数或方法来判断当前进程的当前时间戳与当前日志文件的文件名是否匹配。

可以理解的是,在当前日志文件以当前日志文件的时间命名时,若当前进程的当前时间戳与当前日志文件的文件名相匹配,则可以确定当前进程的当前时间戳与当前日志文件的时间相匹配;若当前进程的当前时间戳与当前日志文件的文件名不匹配,则可以确定当前进程的当前时间戳与当前日志文件的时间不匹配。

进一步地,在上述实施例的基础上,本实施例所述装置还可以包括图中未示出的:

设置模块,用于预先设置用户自定义类,所述用户自定义类继承python标准库中的handler类,并增加第一函数和第二函数;

其中,所述第一函数,用于判断进程的当前时间戳与当前日志文件的时间是否匹配;

所述第二函数,用于若判断获知进程的当前时间戳与当前日志文件的时间不匹配,则创建一个以当前进程的当前时间戳命名的目标日志文件,以利用所述目标日志文件记录当前进程的事件。

在具体应用中,所述预先设置的用户自定义类可以为processsavehandler类。

可以理解的是,本实施例预先设置用户自定义类增加了一个判断逻辑(即更改逻辑代码),再根据判断结果进行相应处理,可以避免意外操作以及现有技术中的进程文件锁所带来的性能损耗。

进一步地,在上述实施例的基础上,所述第二函数,还可用于

若判断获知进程的当前时间戳与当前日志文件的时间相匹配,则利用当前日志文件记录当前进程的事件;

相应地,本实施例所述装置还可以包括图中未示出的:

记录模块,用于若判断获知当前进程的当前时间戳与当前日志文件的时间相匹配,则利用当前日志文件记录当前进程的事件。

本实施例的对python中并发进程的日志处理装置,能够解决python多进程下日志分割后的进程并发问题,并且继承了python原生模块的函数,更改逻辑代码避免了不必要损耗性能的进程文件锁,提升了性能。

本实施例的对python中并发进程的日志处理装置,可以用于执行前述方法实施例的技术方案,其实现原理和技术效果类似,此处不再赘述。

图3示出了本发明实施例提供的一种电子设备的实体结构示意图,如图3所示,该电子设备可以包括:处理器31、存储器32、总线33及存储在存储器32上并可在处理器31上运行的计算机程序;

其中,所述处理器31,存储器32通过所述总线33完成相互间的通信;

所述处理器31执行所述计算机程序时实现上述各方法实施例所提供的方法,例如包括:获取python中当前运行的各并发进程的当前时间戳;对于所述各并发进程中的任一进程,利用预先设置的用户自定义类,判断当前进程的当前时间戳与当前日志文件的时间是否匹配;若判断获知当前进程的当前时间戳与当前日志文件的时间不匹配,则创建一个以当前进程的当前时间戳命名的目标日志文件,以利用所述目标日志文件记录当前进程的事件。

本发明实施例提供一种非暂态计算机可读存储介质,其上存储有计算机程序,该计算机程序被处理器执行时实现上述各方法实施例所提供的方法,例如包括:获取python中当前运行的各并发进程的当前时间戳;对于所述各并发进程中的任一进程,利用预先设置的用户自定义类,判断当前进程的当前时间戳与当前日志文件的时间是否匹配;若判断获知当前进程的当前时间戳与当前日志文件的时间不匹配,则创建一个以当前进程的当前时间戳命名的目标日志文件,以利用所述目标日志文件记录当前进程的事件。

本领域内的技术人员应明白,本申请的实施例可提供为方法、装置、或计算机程序产品。因此,本申请可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本申请可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、cd-rom、光学存储器等)上实施的计算机程序产品的形式。

本申请是参照根据本申请实施例的方法、装置、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置/系统。

这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。

这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。

需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。术语“上”、“下”等指示的方位或位置关系为基于附图所示的方位或位置关系,仅是为了便于描述本发明和简化描述,而不是指示或暗示所指的装置或元件必须具有特定的方位、以特定的方位构造和操作,因此不能理解为对本发明的限制。除非另有明确的规定和限定,术语“安装”、“相连”、“连接”应做广义理解,例如,可以是固定连接,也可以是可拆卸连接,或一体地连接;可以是机械连接,也可以是电连接;可以是直接相连,也可以通过中间媒介间接相连,可以是两个元件内部的连通。对于本领域的普通技术人员而言,可以根据具体情况理解上述术语在本发明中的具体含义。

本发明的说明书中,说明了大量具体细节。然而能够理解的是,本发明的实施例可以在没有这些具体细节的情况下实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。类似地,应当理解,为了精简本发明公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释呈反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多的特征。更确切地说,如权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。需要说明的是,在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互组合。本发明并不局限于任何单一的方面,也不局限于任何单一的实施例,也不局限于这些方面和/或实施例的任意组合和/或置换。而且,可以单独使用本发明的每个方面和/或实施例或者与一个或更多其他方面和/或其实施例结合使用。

最后应说明的是:以上各实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述各实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分或者全部技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的范围,其均应涵盖在本发明的权利要求和说明书的范围当中。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1