CN110048900B - 日志管理方法、移动终端及计算机可读存储介质 - Google Patents
日志管理方法、移动终端及计算机可读存储介质 Download PDFInfo
- Publication number
- CN110048900B CN110048900B CN201910468131.5A CN201910468131A CN110048900B CN 110048900 B CN110048900 B CN 110048900B CN 201910468131 A CN201910468131 A CN 201910468131A CN 110048900 B CN110048900 B CN 110048900B
- Authority
- CN
- China
- Prior art keywords
- log
- logs
- target process
- cutting
- cut
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L41/00—Arrangements for maintenance, administration or management of data switching networks, e.g. of packet switching networks
- H04L41/06—Management of faults, events, alarms or notifications
- H04L41/069—Management of faults, events, alarms or notifications using logs of notifications; Post-processing of notifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04M—TELEPHONIC COMMUNICATION
- H04M1/00—Substation equipment, e.g. for use by subscribers
- H04M1/72—Mobile telephones; Cordless telephones, i.e. devices for establishing wireless links to base stations without route selection
- H04M1/724—User interfaces specially adapted for cordless or mobile telephones
- H04M1/72403—User interfaces specially adapted for cordless or mobile telephones with means for local support of applications that increase the functionality
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Human Computer Interaction (AREA)
- Debugging And Monitoring (AREA)
Abstract
本发明公开了一种日志管理方法,该方法包括:在检测到日志裁剪指令时,获取日志缓冲区对系统内存的占用率;当所述占用率超过预设占用率阈值时,从所述日志缓冲区中划分出裁剪区;根据所述占用率计算待裁剪日志的数量;获取预设黑名单,对所述裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪,直至裁剪数量达到所述待裁剪日志的数量。本发明还公开了一种移动终端及计算机可读存储介质。本发明能够降低日志缓冲区对系统内存的占用率,从而避免系统卡顿,保证移动终端运行的流畅性。
Description
技术领域
本发明涉及移动终端技术领域,尤其涉及一种日志管理方法、移动终端及计算机可读存储介质。
背景技术
日志(log)用来记录移动终端运行情况和用户使用情况的详细信息,这些信息是查看运行状态和排查问题的主要依据。例如,某个应用出现崩溃情况,可以从程序事件日志中找到相应的记录,从而帮助相关技术人员分析并解决问题。
然而,随着时间的推移,越来越多的日志存储于日志缓冲区(logd)中,会导致日志缓冲区占用较多的系统内存,导致系统卡顿,影响了移动终端运行的流畅性。
发明内容
本发明的主要目的在于提供一种日志管理方法、移动终端及计算机可读存储介质,旨在解决日志缓冲区占用较多的系统内存,导致系统卡顿,影响移动终端运行流畅性的技术问题。
为实现上述目的,本发明提供一种日志管理方法,所述日志管理方法包括以下步骤:
在检测到日志裁剪指令时,获取日志缓冲区对系统内存的占用率;
当所述占用率超过预设占用率阈值时,从所述日志缓冲区中划分出裁剪区;
根据所述占用率计算待裁剪日志的数量;
获取预设黑名单,对所述裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪,直至裁剪数量达到所述待裁剪日志的数量。
可选地,所述从所述日志缓冲区中划分出裁剪区的步骤包括:
获取所述日志缓冲区中第一次被进程读取的日志的时间戳,作为目标时间戳;
根据所述目标时间戳从所述日志缓冲区中划分出裁剪区。
可选地,所述根据所述目标时间戳从所述日志缓冲区中划分出裁剪区的步骤包括:
将所述目标时间戳之前预设间隔时长的时间戳确定为临界时间戳;
在所述日志缓冲区中,将所述临界时间戳之前的区域确定为裁剪区。
可选地,所述根据所述占用率计算待裁剪日志的数量的步骤包括:
计算所述占用率和系统内存大小的乘积,得到所述日志缓冲区的大小;
根据所述日志缓冲区的大小以及每条日志的大小计算待裁剪日志的数量。
可选地,所述对所述裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪的步骤包括:
A、统计每个目标进程对应的日志数量,并确定当前日志数量最多的第一目标进程和日志数量第二多的第二目标进程;
B、对所述第一目标进程对应的日志进行逐条裁剪,直至所述第一目标进程对应的日志数量少于所述第二目标进程对应的日志数量、或直至所述第一目标进程的日志数量等于第二目标进程的日志数量且为零;
C、判断各目标进程对应的剩余日志总数量是否为零;
若是,则完成对各目标进程对应的日志的裁剪;
若否,则再次执行步骤A、B、C,直至各目标进程对应的剩余日志总数量为零。
可选地,所述对所述裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪的步骤之后,包括:
若所述裁剪区中各目标进程对应的日志总数量少于所述待裁剪日志的数量,则在完成对各目标进程对应的日志的裁剪之后,按照时间戳先后顺序对所述裁剪区中的剩余日志进行裁剪,直至裁剪数量达到所述待裁剪日志的数量。
可选地,所述对所述裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪的步骤之后,包括:
若所述裁剪区中各目标进程对应的日志总数量少于所述待裁剪日志的数量,则在完成对各目标进程对应的日志的裁剪之后,对所述裁剪区中日志打印频率超过预设阈值的进程对应的日志进行裁剪,直至裁剪数量达到所述待裁剪日志的数量。
可选地,所述在检测到日志裁剪指令时,获取日志缓冲区对系统内存的占用率的步骤之前,包括:
禁止不符合预设等级的日志写入所述日志缓冲区。
此外,为实现上述目的,本发明还提供一种移动终端,所述移动终端包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的日志管理程序,所述日志管理程序被所述处理器执行时实现如上所述的日志管理方法的步骤。
此外,为实现上述目的,本发明还提供一种计算机可读存储介质,所述计算机可读存储介质上存储有日志管理程序,所述日志管理程序被处理器执行时实现如上所述的日志管理方法的步骤。
本发明提供一种日志管理方法、移动终端及计算机可读存储介质,在检测到日志裁剪指令时,首先获取日志缓冲区对系统内存的占用率;当日志缓冲区对系统内存的占用率超过预设占用率阈值时,从日志缓冲区中划分出裁剪区;然后根据占用率计算待裁剪日志的数量;获取预设黑名单,对裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪,直至裁剪数量达到待裁剪日志的数量,本发明通过上述方式,实现了对日志缓冲区中部分特定日志的清除,减少了日志缓冲区保留的日志数,从而降低了日志缓冲区对系统内存的占用率,避免了系统卡顿,保证了移动终端运行的流畅性。
附图说明
图1为实现本发明各个实施例的一种移动终端的硬件结构示意图;
图2为本发明实施例提供的一种通信网络系统架构图;
图3为本发明日志管理方法第一实施例的流程示意图;
图4为本发明日志管理方法第一实施例涉及的裁剪区划分示意图。
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。
终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如手机、平板电脑、笔记本电脑、掌上电脑、个人数字助理(Personal Digital Assistant,PDA)、便捷式媒体播放器(Portable Media Player,PMP)、导航装置、可穿戴设备、智能手环、计步器等移动终端,以及诸如数字TV、台式计算机等固定终端。
后续描述中将以移动终端为例进行说明,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。
请参阅图1,其为实现本发明各个实施例的一种移动终端的硬件结构示意图,该移动终端100可以包括:RF(Radio Frequency,射频)单元101、Wi-Fi模块102、音频输出单元103、A/V(音频/视频)输入单元104、传感器105、显示单元106、用户输入单元107、接口单元108、存储器109、处理器110、以及电源111等部件。本领域技术人员可以理解,图1中示出的移动终端结构并不构成对移动终端的限定,移动终端可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
下面结合图1对移动终端的各个部件进行具体的介绍:
射频单元101可用于收发信息或通话过程中,信号的接收和发送,具体的,将基站的下行信息接收后,给处理器110处理;另外,将上行的数据发送给基站。通常,射频单元101包括但不限于天线、至少一个放大器、收发信机、耦合器、低噪声放大器、双工器等。此外,射频单元101还可以通过无线通信与网络和其他设备通信。上述无线通信可以使用任一通信标准或协议,包括但不限于GSM(Global System of Mobile communication,全球移动通讯系统)、GPRS(General Packet Radio Service,通用分组无线服务)、CDMA2000(CodeDivision Multiple Access 2000,码分多址2000)、WCDMA(Wideband Code DivisionMultiple Access,宽带码分多址)、TD-SCDMA(Time Division-Synchronous CodeDivision Multiple Access,时分同步码分多址)、FDD-LTE(Frequency DivisionDuplexing-Long Term Evolution,频分双工长期演进)和TDD-LTE(Time DivisionDuplexing-Long Term Evolution,分时双工长期演进)等。
WiFi属于短距离无线传输技术,移动终端通过WiFi模块102可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图1示出了WiFi模块102,但是可以理解的是,其并不属于移动终端的必须构成,完全可以根据需要在不改变发明的本质的范围内而省略。
音频输出单元103可以在移动终端100处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将射频单元101或WiFi模块102接收的或者在存储器109中存储的音频数据转换成音频信号并且输出为声音。而且,音频输出单元103还可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出单元103可以包括扬声器、蜂鸣器等等。
A/V输入单元104用于接收音频或视频信号。A/V输入单元104可以包括图形处理器(Graphics Processing Unit,GPU)1041和麦克风1042,图形处理器1041对在视频捕获模式或图像捕获模式中由图像捕获装置(如摄像头)获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元106上。经图形处理器1041处理后的图像帧可以存储在存储器109(或其它存储介质)中或者经由射频单元101或WiFi模块102进行发送。麦克风1042可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风1042接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由射频单元101发送到移动通信基站的格式输出。麦克风1042可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。
移动终端100还包括至少一种传感器105,比如光传感器、运动传感器以及其他传感器。具体地,光传感器包括环境光传感器及接近传感器,其中,环境光传感器可根据环境光线的明暗来调节显示面板1061的亮度,接近传感器可在移动终端100移动到耳边时,关闭显示面板1061和/或背光。作为运动传感器的一种,加速计传感器可检测各个方向上(一般为三轴)加速度的大小,静止时可检测出重力的大小及方向,可用于识别手机姿态的应用(比如横竖屏切换、相关游戏、磁力计姿态校准)、振动识别相关功能(比如计步器、敲击)等;至于手机还可配置的指纹传感器、压力传感器、虹膜传感器、分子传感器、陀螺仪、气压计、湿度计、温度计、红外线传感器等其他传感器,在此不再赘述。
显示单元106用于显示由用户输入的信息或提供给用户的信息。显示单元106可包括显示面板1061,可以采用液晶显示器(Liquid Crystal Display,LCD)、有机发光二极管(Organic Light-Emitting Diode,OLED)等形式来配置显示面板1061。
用户输入单元107可用于接收输入的数字或字符信息,以及产生与移动终端的用户设置以及功能控制有关的键信号输入。具体地,用户输入单元107可包括触控面板1071以及其他输入设备1072。触控面板1071,也称为触摸屏,可收集用户在其上或附近的触摸操作(比如用户使用手指、触笔等任何适合的物体或附件在触控面板1071上或在触控面板1071附近的操作),并根据预先设定的程式驱动相应的连接装置。触控面板1071可包括触摸检测装置和触摸控制器两个部分。其中,触摸检测装置检测用户的触摸方位,并检测触摸操作带来的信号,将信号传送给触摸控制器;触摸控制器从触摸检测装置上接收触摸信息,并将它转换成触点坐标,再送给处理器110,并能接收处理器110发来的命令并加以执行。此外,可以采用电阻式、电容式、红外线以及表面声波等多种类型实现触控面板1071。除了触控面板1071,用户输入单元107还可以包括其他输入设备1072。具体地,其他输入设备1072可以包括但不限于物理键盘、功能键(比如音量控制按键、开关按键等)、轨迹球、鼠标、操作杆等中的一种或多种,具体此处不做限定。
进一步的,触控面板1071可覆盖显示面板1061,当触控面板1071检测到在其上或附近的触摸操作后,传送给处理器110以确定触摸事件的类型,随后处理器110根据触摸事件的类型在显示面板1061上提供相应的视觉输出。虽然在图1中,触控面板1071与显示面板1061是作为两个独立的部件来实现移动终端的输入和输出功能,但是在某些实施例中,可以将触控面板1071与显示面板1061集成而实现移动终端的输入和输出功能,具体此处不做限定。
接口单元108用作至少一个外部装置与移动终端100连接可以通过的接口。例如,外部装置可以包括有线或无线头戴式耳机端口、外部电源(或电池充电器)端口、有线或无线数据端口、存储卡端口、用于连接具有识别模块的装置的端口、音频输入/输出(I/O)端口、视频I/O端口、耳机端口等等。接口单元108可以用于接收来自外部装置的输入(例如,数据信息、电力等等)并且将接收到的输入传输到移动终端100内的一个或多个元件或者可以用于在移动终端100和外部装置之间传输数据。
存储器109可用于存储软件程序以及各种数据。存储器109可主要包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需的应用程序(比如声音播放功能、图像播放功能等)等;存储数据区可存储根据手机的使用所创建的数据(比如音频数据、电话本等)等。此外,存储器109可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件、闪存器件、或其他易失性固态存储器件。
处理器110是移动终端的控制中心,利用各种接口和线路连接整个移动终端的各个部分,通过运行或执行存储在存储器109内的软件程序和/或模块,以及调用存储在存储器109内的数据,执行移动终端的各种功能和处理数据,从而对移动终端进行整体监控。处理器110可包括一个或多个处理单元;优选的,处理器110可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器110中。
移动终端100还可以包括给各个部件供电的电源111(比如电池),优选的,电源111可以通过电源管理系统与处理器110逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。
尽管图1未示出,移动终端100还可以包括蓝牙模块等,在此不再赘述。
基于上述终端硬件结构,提出本发明终端的各个实施例。
请参照图1,在本发明终端的一实施例中,该终端包括:存储器109、处理器110和存储在所述存储器109上并可在所述处理器110上运行的日志管理程序,所述日志管理程序被所述处理器110执行时实现以下步骤:
在检测到日志裁剪指令时,获取日志缓冲区对系统内存的占用率;
当所述占用率超过预设占用率阈值时,从所述日志缓冲区中划分出裁剪区;
根据所述占用率计算待裁剪日志的数量;
获取预设黑名单,对所述裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪,直至裁剪数量达到所述待裁剪日志的数量。
进一步地,所述日志管理程序被所述处理器110执行时还实现以下步骤:
获取所述日志缓冲区中第一次被进程读取的日志的时间戳,作为目标时间戳;
根据所述目标时间戳从所述日志缓冲区中划分出裁剪区。
进一步地,所述日志管理程序被所述处理器110执行时还实现以下步骤:
将所述目标时间戳之前预设间隔时长的时间戳确定为临界时间戳;
在所述日志缓冲区中,将所述临界时间戳之前的区域确定为裁剪区。
进一步地,所述日志管理程序被所述处理器110执行时还实现以下步骤:
计算所述占用率和系统内存大小的乘积,得到所述日志缓冲区的大小;
根据所述日志缓冲区的大小以及每条日志的大小计算待裁剪日志的数量。
进一步地,所述日志管理程序被所述处理器110执行时还实现以下步骤:
A、统计每个目标进程对应的日志数量,并确定当前日志数量最多的第一目标进程和日志数量第二多的第二目标进程;
B、对所述第一目标进程对应的日志进行逐条裁剪,直至所述第一目标进程对应的日志数量少于所述第二目标进程对应的日志数量、或直至所述第一目标进程的日志数量等于第二目标进程的日志数量且为零;
C、判断各目标进程对应的剩余日志总数量是否为零;
若是,则完成对各目标进程对应的日志的裁剪;
若否,则再次执行步骤A、B、C,直至各目标进程对应的剩余日志总数量为零。
进一步地,所述日志管理程序被所述处理器110执行时还实现以下步骤:
若所述裁剪区中各目标进程对应的日志总数量少于所述待裁剪日志的数量,则在完成对各目标进程对应的日志的裁剪之后,按照时间戳先后顺序对所述裁剪区中的剩余日志进行裁剪,直至裁剪数量达到所述待裁剪日志的数量。
进一步地,所述日志管理程序被所述处理器110执行时还实现以下步骤:
若所述裁剪区中各目标进程对应的日志总数量少于所述待裁剪日志的数量,则在完成对各目标进程对应的日志的裁剪之后,对所述裁剪区中日志打印频率超过预设阈值的进程对应的日志进行裁剪,直至裁剪数量达到所述待裁剪日志的数量。
进一步地,所述日志管理程序被所述处理器110执行时还实现以下步骤:
禁止不符合预设等级的日志写入所述日志缓冲区。
为了便于理解本发明实施例,下面对本发明的移动终端所基于的通信网络系统进行描述。
请参阅图2,图2为本发明实施例提供的一种通信网络系统架构图,该通信网络系统为通用移动通信技术的LTE系统,该LTE系统包括依次通讯连接的UE(User Equipment,用户设备)201,E-UTRAN(Evolved UMTS Terrestrial Radio Access Network,演进式UMTS陆地无线接入网)202,EPC(Evolved Packet Core,演进式分组核心网)203和运营商的IP业务204。
具体地,UE201可以是上述终端100,此处不再赘述。
E-UTRAN202包括eNodeB2021和其它eNodeB2022等。其中,eNodeB2021可以通过回程(backhaul)(例如X2接口)与其它eNodeB2022连接,eNodeB2021连接到EPC203,eNodeB2021可以提供UE201到EPC203的接入。
EPC203可以包括MME(Mobility Management Entity,移动性管理实体)2031,HSS(Home Subscriber Server,归属用户服务器)2032,其它MME2033,SGW(Serving Gate Way,服务网关)2034,PGW(PDN Gate Way,分组数据网络网关)2035和PCRF(Policy andCharging Rules Function,政策和资费功能实体)2036等。其中,MME2031是处理UE201和EPC203之间信令的控制节点,提供承载和连接管理。HSS2032用于提供一些寄存器来管理诸如归属位置寄存器(图中未示)之类的功能,并且保存有一些有关服务特征、数据速率等用户专用的信息。所有用户数据都可以通过SGW2034进行发送,PGW2035可以提供UE 201的IP地址分配以及其它功能,PCRF2036是业务数据流和IP承载资源的策略与计费控制策略决策点,它为策略与计费执行功能单元(图中未示)选择及提供可用的策略和计费控制决策。
IP业务204可以包括因特网、内联网、IMS(IP Multimedia Subsystem,IP多媒体子系统)或其它IP业务等。
虽然上述以LTE系统为例进行了介绍,但本领域技术人员应当知晓,本发明不仅仅适用于LTE系统,也可以适用于其他无线通信系统,例如GSM、CDMA2000、WCDMA、TD-SCDMA以及未来新的网络系统等,此处不做限定。
基于上述终端硬件结构以及通信网络系统,提出本发明日志管理方法各个实施例。
本发明提供一种日志管理方法。
参照图3,图3为本发明日志管理方法第一实施例的流程示意图。
在本实施例中,所述日志管理方法可选应用于图1中所述的移动终端,所述日志管理方法包括以下步骤:
步骤S10,在检测到日志裁剪指令时,确定日志缓冲区对系统内存的占用率;
在本实施例中,步骤S10之前,包括:禁止不符合预设等级的日志写入所述日志缓冲区。
即,为了减少写入日志缓冲区中的日志,预先根据日志等级对日志的写入进行控制,日志等级从高到底:Error>Warn>Info>Debug,其中,Error表明出现了系统错误和异常,无法正常完成目标操作,Warn表明系统出现轻微的不合理但不影响运行和使用,Info用于打印程序应该出现的正常状态信息,Debug级别最低主要用于开发过程中打印一些运行信息,因此,Error和Warn级别的日志的重要程度较高,将Error和Warn级别作为预设等级,仅允许Error和Warn级别的日志写入日志缓冲区,禁止Info和Debug级别的日志写入日志缓冲区。
在本实施例中,日志裁剪指令的触发方式包括:a、预先设置定时触发模式,在定时的时间到达时,自动触发日志裁剪指令;b、预先设置与日志裁剪功能对应的触控操作手势,或者预先对移动终端已有的实体按键复用出日志裁剪功能,在侦测到该触控操作手势时或者接收到作用于该实体按键的按压操作时,触发日志裁剪指令。移动终端在检测到日志裁剪指令时,首先日志缓冲区(logd)对系统内存的占用率。
步骤S20,当所述占用率超过预设占用率阈值时,从所述日志缓冲区中划分出裁剪区;
之后,判断日志缓冲区对系统内存的占用率是否超过预设占用率阈值(该预设占用率阈值作为判定阈值可以根据实际灵活设置,比如12.5%),如果日志缓冲区对系统内存的占用率超过预设占用率阈值,则从日志缓冲区中划分出待裁剪区。具体地,所述从所述日志缓冲区中划分出裁剪区的步骤包括:
获取所述日志缓冲区中第一次被进程读取的日志的时间戳,作为目标时间戳;
根据所述目标时间戳从所述日志缓冲区中划分出裁剪区。
其中,所述根据所述目标时间戳从所述日志缓冲区中划分出裁剪区的步骤包括:将所述目标时间戳之前预设间隔时长的时间戳确定为临界时间戳;在所述日志缓冲区中,将所述临界时间戳之前的区域确定为裁剪区。
即,每一条日志写入日志缓冲区时均打上一个对应的时间戳,写入日志缓冲区的所有日志按照时间戳先后顺序(也可以是早晚顺序)进行排列存储,最新的日志排在最前列。在判定日志缓冲区对系统内存的占用率超过预设占用率阈值时,确定日志缓冲区中第一次被进程读取的日志的时间戳(定义为目标时间戳),可以理解的是,早于目标时间戳的日志,没有进程去读取,为了保留更重要的日志,基于目标时间戳从缓冲区中划分出裁剪区,具体地,根据目标时间戳确定临界时间戳,将目标时间戳之前预设间隔时长的时间戳确定为临界时间戳,将临界时间戳之前的区域确定为裁剪区,为更好理解如何从日志缓冲区中划分出裁剪区,可以参照图3,图3为裁剪区划分示意图,以A进程表示第一次从日志缓冲区中读取日志的进程,以B进程表示第二次从日志缓冲区中读取日志的进程,若以Real_A_Time表示A进程读取的日志的时间戳(目标时间戳),Real_B_Time则表示B进程读取的日志的时间戳,则Real_A_Time早于Real_B_Time,以预设间隔时长为3秒为例,在Real_A_Time之前3秒的时间戳即为临界时间戳(用watermark表示),watermark之前的区域即为裁剪区。
步骤S30,根据所述占用率计算待裁剪日志的数量;
在从日志缓冲区中划分出裁剪区后,根据日志缓冲区对系统内存的占用率计算待裁剪日志的数量,具体地,所述根据所述占用率计算待裁剪日志的数量的步骤包括:
计算所述占用率和系统内存大小的乘积,得到所述日志缓冲区的大小;
根据所述日志缓冲区的大小以及每条日志的大小计算待裁剪日志的数量。
即,计算系统内存大小与日志缓冲区对系统内存的占用率的乘积,得到日志缓冲区的大小,基于日志缓冲区的大小计算待裁剪日志的条数,可以根据实际需要预先设置日志缓冲区需减少的内存占比,例如日志缓冲区需减少八分之一的内存,则以日志缓冲区大小的八分之一计算待裁剪日志的条数,将日志缓冲区大小的八分之一除以每条日志的大小,得到待裁剪日志的条数。
步骤S40,获取预设黑名单,对所述裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪,直至裁剪数量达到所述待裁剪日志的数量。
在本实施例中,考虑到实际中第三方应用打印的日志数较多,将第三方应用的进程对应的日志作为优先裁剪的对象,因此预先设置黑名单,也就是第三方应用进程名单,可以根据应用的进程号设置黑名单(第三方应用的进程号大于10000),将黑名单中第三方应用的进程定义为目标进程,由此,在计算得到待裁剪日志的数量之后,获取黑名单,对所述裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪,直至裁剪数量达到所述待裁剪日志的数量。应当理解的是,实现步骤S40的前提条件是,裁剪区中属于预设黑名单的各目标进程对应的日志总数大于等于待裁剪日志的数量。
其中,所述对所述裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪的步骤包括:A、统计每个目标进程对应的日志数量,并确定当前日志数量最多的第一目标进程和日志数量第二多的第二目标进程;B、对所述第一目标进程对应的日志进行逐条裁剪,直至所述第一目标进程对应的日志数量少于所述第二目标进程对应的日志数量、或直至所述第一目标进程的日志数量等于第二目标进程的日志数量且为零;C、判断各目标进程对应的剩余日志总数量是否为零;若是,则完成对各目标进程对应的日志的裁剪;若否,则再次执行步骤A、B、C,直至各目标进程对应的剩余日志总数量为零。例如,目标进程a对应10条日志,目标进程b对应5条日志,目标进程c对应2条日志,第一轮裁剪为:目标进程a为第一目标进程,目标进程b为第二目标进程,先对目标进程a的日志进行逐条裁剪,当裁剪至剩余4条时,此时目标进程a的日志数量少于目标进程b的日志数量,且各目标进程对应的日志总数量不为零,进入第二轮裁剪(此时目标进程a剩余4条,目标进程b对应5条,目标进程c对应2条):将目标进程b作为第一目标进程,对目标进程b的日志进行逐条裁剪,当裁剪至剩余3条,此时目标进程b的日志数量少于目标进程a的日志数量,且各目标进程对应的日志总数量不为零,进入第三轮裁剪(此时目标进程a剩余4条,目标进程b剩余3条,目标进程c对应2条):将目标进程a作为第一目标进程,对目标进程a的日志进行逐条裁剪,当裁剪至剩余2条时,此时目标进程a的日志数量少于目标进程b的日志数量,且各目标进程对应的日志总数量不为零,进入第四轮裁剪(此时目标进程a剩余2条,目标进程b剩余3条,目标进程c对应2条):将目标进程b作为第一目标进程,对目标进程b的日志进行逐条裁剪,当裁剪至剩余1条时,此时目标进程b的日志数量少于目标进程a和目标进程c的日志数量,且各目标进程对应的日志总数量不为零,进入第五轮裁剪(此时目标进程a剩余2条,目标进程b剩余1条,目标进程c对应2条):从目标进程a和目标进程c(比如目标进程c)任意选一个作为第一目标进程,对目标进程c的日志进行逐条裁剪,当裁剪至剩余1条时,此时目标进程c的日志数量少于目标进程a的日志数量,且各目标进程对应的日志总数量不为零,进入第六轮裁剪(此时目标进程a剩余2条,目标进程b剩余1条,目标进程c对应1条):将目标进程a作为第一目标进程,对目标进程a的日志进行逐条裁剪,当裁剪至剩余0条时,此时目标进程a的日志数量少于目标进程b和目标进程c的日志数量,且各目标进程对应的日志总数量不为零,进入第七轮裁剪(此时目标进程a剩余0条,目标进程b剩余1条,目标进程c对应1条):从目标进程b和目标进程c(比如目标进程b)任意选一个作为第一目标进程,对目标进程b的日志进行逐条裁剪,当裁剪至剩余0条时,此时目标进程b的日志数量少于目标进程c的日志数量,且各目标进程对应的日志总数量不为零,进入第八轮裁剪(此时目标进程a剩余0条,目标进程b剩余0条,目标进程c对应1条):目标进程c作为第一目标进程,目标进程a或目标进程b作为第二目标进程,对目标进程c的日志进行逐条裁剪,裁剪至0条,此时第一目标进程的剩余日志数量相等且为零,裁剪完成,如此,使得每一轮裁剪都是选取当前日志数量最多的进程对应的日志进行逐条裁剪。
在更多的实施中,考虑到执行裁剪日志操作时,无法执行日志写入日志缓冲区的操作,为避免出现日志缓冲区长时间写入不了日志的问题,可以根据实际对每次检测到裁剪指令时所裁剪的日志数量进行限定,如果限定的裁剪数量小于计算的待裁剪日志数量,则裁剪至限定的裁剪数为止,在下一次检测裁剪指令时,优先对上一次的剩余日志进行裁剪。
本实施例提供一种日志管理方法,在检测到日志裁剪指令时,首先获取日志缓冲区对系统内存的占用率;当日志缓冲区对系统内存的占用率超过预设占用率阈值时,从日志缓冲区中划分出裁剪区;然后根据占用率计算待裁剪日志的数量;获取预设黑名单,对裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪,直至裁剪数量达到待裁剪日志的数量,本发明通过上述方式,实现了对日志缓冲区中部分特定日志的清除,减少了日志缓冲区保留的日志数,从而降低了日志缓冲区对系统内存的占用率,避免了系统卡顿,保证了移动终端运行的流畅性。
进一步地,基于第一实施例提出本发明日志管理方法的第二实施例。
日志管理方法的第二实施例与日志管理方法的第一实施例的区别在于,所述对所述裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪的步骤之后,包括:
若所述裁剪区中各目标进程对应的日志总数量少于所述待裁剪日志的数量,则在完成对各目标进程对应的日志的裁剪之后,按照时间戳先后顺序对所述裁剪区中的剩余日志进行裁剪,直至裁剪数量达到所述待裁剪日志的数量。
考虑到裁剪区中各目标进程对应的日志总数量达不到待裁剪日志数量的情况,在本实施例中,在完成对各目标进程对应的日志的裁剪之后,在裁剪区中按照时间戳先后(或早晚)顺序进行日志裁剪,即,从时间戳最早的日志开始,按照时间戳从早往晚的顺序逐条进行裁剪,直至裁剪数量达到待裁剪日志的数量,从而对较早写入日志缓冲区的日志进行裁剪,保留较晚写入的日志,进一步减少保留的日志数,降低了日志缓冲区对系统内存的占用率。应当理解,上述过程对应系统时间无异常的情况,日志缓冲区的日志排列顺序依然按照从早到晚的顺序排列。
考虑到系统时间跳变的情况,如人为修改时间、系统时钟异常或者时区发生改变的时候,例如,系统时间从8:00跳转至7:00,由于日志缓冲区中的每条日志是之前就写入的,所以每条日志的时间戳是不会变化的(时间戳对应7:30的仍然是7:30),从系统时间跳变发生的时刻起,跳变后随着系统计时,写入日志缓冲区中的每条日志所打上的时间戳记录为7:00、7:01、…,那么在日志缓冲区中,系统时间跳变前写入日志缓冲区的日志X(系统时间跳变前的时间戳记录为7:55),就排在系统时间跳变后才写入日志缓冲区的日志Y(系统时间跳变前的时间戳记录为7:01)之后,即,日志缓冲区的日志排列顺序已然不是按照从早到晚的顺序排列。而当系统时间跳变后,随着时间的推移,系统时间从7:00正常计时到7:30,如果时间戳为7:00到7:30之间的某个时间点的日志(比如7:01的日志)为日志缓冲区中第一次被进程读取的日志,系统时间跳变后临界时间戳watermar为7:00:57,那么在裁剪区中按照系统跳变后的日志排序逐条进行裁剪,实际上先写入的日志X则不满足裁剪条件(系统时间跳变后临界时间戳早于日志X的时间戳),无法被裁掉。因此,如果在裁剪区中按照系统跳变后的日志排序逐条进行裁剪时,检测到时间戳比当前系统时间大(比如大10秒)的日志就裁剪掉该日志,避免实际先写入的日志未被裁掉的情况。
进一步地,基于第一实施例提出本发明日志管理方法的第三实施例。
日志管理方法的第三实施例与日志管理方法的第一实施例的区别在于,所述对所述裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪的步骤之后,包括:
若所述裁剪区中各目标进程对应的日志总数量少于所述待裁剪日志的数量,则在完成对各目标进程对应的日志的裁剪之后,对所述裁剪区中日志打印频率超过预设阈值的进程对应的日志进行裁剪,直至裁剪数量达到所述待裁剪日志的数量。
作为一种实施方式,对于裁剪区中各目标进程对应的日志总数量达不到待裁剪日志数量的情况,考虑到实际中传感器和触摸事件频繁上报日志,日志缓冲区中传感器和触摸事件上报的日志非常多,可以对裁剪区中日志打印频率超过预设频率阈值的进程对应的日志进行裁剪,直至裁剪数量达到待裁剪日志的数量。具体地,日志打印频率表示1s内打印日志的次数,由于进程一次打印一条日志,对于黑名单以外的进程(进程号大于10000的进程),获取每个进程当前1s内打印的日志条数,然后获取每个进程在之前N秒(N≥2)打印的总数M,计算M与N的比值,得到每个进程之前N秒中平均每秒打印的日志数,以每个进程平均每秒打印的日志数的两倍作为每个进程的预设阈值,将每个进程当前1s内打印的日志条数与每个进程的预设阈值进行比对,确定出当前1s内打印的日志条数大于相应预设阈值的进程,然后在裁剪区中对当前1s内打印的日志条数大于相应预设阈值的进程的日志进行裁剪,直至裁剪数量达到待裁剪日志的数量。
此外,本发明实施例还提出一种计算机可读存储介质。
本发明计算机可读存储介质上存储有日志管理程序,所述日志管理程序被处理器执行时实现如下步骤:
在检测到日志裁剪指令时,获取日志缓冲区对系统内存的占用率;
当所述占用率超过预设占用率阈值时,从所述日志缓冲区中划分出裁剪区;
根据所述占用率计算待裁剪日志的数量;
获取预设黑名单,对所述裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪,直至裁剪数量达到所述待裁剪日志的数量。
其中,在所述处理器上运行的日志管理程序被执行时所实现的方法可参照本发明日志管理方法各个实施例,此处不再赘述。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者系统不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者系统所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者系统中还存在另外的相同要素。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。
以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本发明的专利保护范围内。
Claims (8)
1.一种日志管理方法,其特征在于,所述日志管理方法包括以下步骤:
在检测到日志裁剪指令时,获取日志缓冲区对系统内存的占用率;
当所述占用率超过预设占用率阈值时,从所述日志缓冲区中划分出裁剪区;
根据所述占用率计算待裁剪日志的数量;
获取预设黑名单,对所述裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪,直至裁剪数量达到所述待裁剪日志的数量;
所述从所述日志缓冲区中划分出裁剪区的步骤包括:
获取所述日志缓冲区中第一次被进程读取的日志的时间戳,作为目标时间戳;
根据所述目标时间戳从所述日志缓冲区中划分出裁剪区;
所述根据所述目标时间戳从所述日志缓冲区中划分出裁剪区的步骤包括:
将所述目标时间戳之前预设间隔时长的时间戳确定为临界时间戳;
在所述日志缓冲区中,将所述临界时间戳之前的区域确定为裁剪区。
2.如权利要求1所述的日志管理方法,其特征在于,所述根据所述占用率计算待裁剪日志的数量的步骤包括:
计算所述占用率和系统内存大小的乘积,得到所述日志缓冲区的大小;
根据所述日志缓冲区的大小以及每条日志的大小计算待裁剪日志的数量。
3.如权利要求1所述的日志管理方法,其特征在于,所述对所述裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪的步骤包括:
A、统计每个目标进程对应的日志数量,并确定当前日志数量最多的第一目标进程和日志数量第二多的第二目标进程;
B、对所述第一目标进程对应的日志进行逐条裁剪,直至所述第一目标进程对应的日志数量少于所述第二目标进程对应的日志数量、或直至所述第一目标进程的日志数量等于第二目标进程的日志数量且为零;
C、判断各目标进程对应的剩余日志总数量是否为零;
若是,则完成对各目标进程对应的日志的裁剪;
若否,则再次执行步骤A、B、C,直至各目标进程对应的剩余日志总数量为零。
4.如权利要求1所述的日志管理方法,其特征在于,所述对所述裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪的步骤之后,包括:
若所述裁剪区中各目标进程对应的日志总数量少于所述待裁剪日志的数量,则在完成对各目标进程对应的日志的裁剪之后,按照时间戳先后顺序对所述裁剪区中的剩余日志进行裁剪,直至裁剪数量达到所述待裁剪日志的数量。
5.如权利要求1所述的日志管理方法,其特征在于,所述对所述裁剪区中属于预设黑名单的各目标进程对应的日志进行裁剪的步骤之后,包括:
若所述裁剪区中各目标进程对应的日志总数量少于所述待裁剪日志的数量,则在完成对各目标进程对应的日志的裁剪之后,对所述裁剪区中日志打印频率超过预设阈值的进程对应的日志进行裁剪,直至裁剪数量达到所述待裁剪日志的数量。
6.如权利要求1至5中任一项所述的日志管理方法,其特征在于,所述在检测到日志裁剪指令时,获取日志缓冲区对系统内存的占用率的步骤之前,包括:
禁止不符合预设等级的日志写入所述日志缓冲区。
7.一种移动终端,其特征在于,所述移动终端包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的日志管理程序,所述日志管理程序被所述处理器执行时实现如权利要求1至6中任一项所述的日志管理方法的步骤。
8.一种计算机可读存储介质,其特征在于,所述计算机可读存储介质上存储有日志管理程序,所述日志管理程序被处理器执行时实现如权利要求1至6中任一项所述的日志管理方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910468131.5A CN110048900B (zh) | 2019-05-29 | 2019-05-29 | 日志管理方法、移动终端及计算机可读存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910468131.5A CN110048900B (zh) | 2019-05-29 | 2019-05-29 | 日志管理方法、移动终端及计算机可读存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN110048900A CN110048900A (zh) | 2019-07-23 |
CN110048900B true CN110048900B (zh) | 2023-07-25 |
Family
ID=67284355
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910468131.5A Active CN110048900B (zh) | 2019-05-29 | 2019-05-29 | 日志管理方法、移动终端及计算机可读存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110048900B (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112527614A (zh) * | 2020-12-08 | 2021-03-19 | 广东小天才科技有限公司 | 一种智能设备日志量预警系统及方法 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2007034416A (ja) * | 2005-07-22 | 2007-02-08 | Toshiba Corp | ログデータを管理する情報処理システム、ログデータ管理方法およびプログラム |
CN105190623A (zh) * | 2013-03-15 | 2015-12-23 | 亚马逊科技公司 | 日志记录管理 |
CN106815363A (zh) * | 2017-01-24 | 2017-06-09 | 郑州云海信息技术有限公司 | 一种基于linux日志轮转管理方法与装置 |
CN106844172A (zh) * | 2016-12-28 | 2017-06-13 | 福建三元达网络技术有限公司 | 一种高效定位系统故障的日志记录方法及系统 |
-
2019
- 2019-05-29 CN CN201910468131.5A patent/CN110048900B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2007034416A (ja) * | 2005-07-22 | 2007-02-08 | Toshiba Corp | ログデータを管理する情報処理システム、ログデータ管理方法およびプログラム |
CN105190623A (zh) * | 2013-03-15 | 2015-12-23 | 亚马逊科技公司 | 日志记录管理 |
CN106844172A (zh) * | 2016-12-28 | 2017-06-13 | 福建三元达网络技术有限公司 | 一种高效定位系统故障的日志记录方法及系统 |
CN106815363A (zh) * | 2017-01-24 | 2017-06-09 | 郑州云海信息技术有限公司 | 一种基于linux日志轮转管理方法与装置 |
Also Published As
Publication number | Publication date |
---|---|
CN110048900A (zh) | 2019-07-23 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110175062B (zh) | 一种移动终端的屏幕刷新帧率方法、移动终端及存储介质 | |
CN109663353B (zh) | 游戏操作方法、移动终端及计算机可读存储介质 | |
CN110087287B (zh) | 终端搜网的控制方法、装置、移动终端及存储介质 | |
CN108512625B (zh) | 摄像头的抗干扰方法、移动终端及存储介质 | |
CN109195213B (zh) | 移动终端屏幕控制方法、移动终端及计算机可读存储介质 | |
CN109144705B (zh) | 应用程序管理方法、移动终端及计算机可读存储介质 | |
CN109753210B (zh) | 移动终端的信息显示方法、移动终端、可读存储介质 | |
CN110113779B (zh) | eSIM卡的测试方法、系统和介质 | |
CN112689191B (zh) | 一种投屏控制方法、终端及计算机可读存储介质 | |
CN110096375B (zh) | 一种应用程序共享数据方法、装置及计算机可读存储介质 | |
CN109766119B (zh) | 恢复分区升级方法、终端和计算机可读存储介质 | |
CN108958936B (zh) | 应用程序切换方法、移动终端及计算机可读存储介质 | |
CN109545120B (zh) | 屏幕光感传感器调节方法、移动终端和计算机可读存储介质 | |
CN109445945B (zh) | 应用程序的内存分配方法、移动终端、服务器及存储介质 | |
CN108579081B (zh) | 基于游戏的事件处理方法、设备及计算机存储介质 | |
CN112347067B (zh) | 一种日志信息管控方法、设备及计算机可读存储介质 | |
CN111970738B (zh) | 一种网络切换控制方法、设备及计算机可读存储介质 | |
CN108377292B (zh) | 解决内存泄露的方法、终端、服务器及计算机存储介质 | |
CN110048900B (zh) | 日志管理方法、移动终端及计算机可读存储介质 | |
CN111443818B (zh) | 一种屏幕亮度调控方法、设备及计算机可读存储介质 | |
CN110334559B (zh) | 一种扫码识别方法、终端及计算机可读存储介质 | |
CN110046151B (zh) | 一种数据清洗方法、服务器及计算机可读存储介质 | |
CN109948368B (zh) | 一种隐私权限控制方法、设备及计算机可读存储介质 | |
CN109740121B (zh) | 一种移动终端的搜索方法、移动终端及存储介质 | |
CN109388947B (zh) | 一种后台管理方法、设备及计算机可读存储介质 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |