CN109117630B - 减少日志丢失的方法、移动终端及可读存储介质 - Google Patents
减少日志丢失的方法、移动终端及可读存储介质 Download PDFInfo
- Publication number
- CN109117630B CN109117630B CN201811137200.6A CN201811137200A CN109117630B CN 109117630 B CN109117630 B CN 109117630B CN 201811137200 A CN201811137200 A CN 201811137200A CN 109117630 B CN109117630 B CN 109117630B
- Authority
- CN
- China
- Prior art keywords
- log
- application
- reducing
- white list
- saving process
- 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
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/50—Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
- G06F21/52—Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems during program execution, e.g. stack integrity ; Preventing unwanted data erasure; Buffer overflow
- G06F21/54—Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems during program execution, e.g. stack integrity ; Preventing unwanted data erasure; Buffer overflow by adding security routines or objects to programs
-
- 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 Security & Cryptography (AREA)
- Software Systems (AREA)
- Theoretical Computer Science (AREA)
- Computer Hardware Design (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Mobile Radio Communication Systems (AREA)
- Debugging And Monitoring (AREA)
Abstract
本发明公开了一种减少日志丢失的方法、移动终端及可读存储介质,其中,所述减少日志丢失的方法包括:在识别到第一应用运行时,判断日志系统中是否存在与第一应用对应的白名单;若是,则建立所述白名单对应的第一日志保存进程与应用层的进程通信连接;判断所述第一应用是否退出运行;若是,则建立所述第二日志保存进程与应用层的进程通信连接。本发明有效避免其它系统应用对应的日志信息的抓取,从而保证第一应用运行期间抓log的完整性。本发明通过添加白名单机制,避免UDP协议产生的可能出现丢包,从而导致应用部分log信息丢失的问题,有效保证第一应用运行能够完整的抓取log信息。
Description
技术领域
本发明涉及移动终端领域,尤其涉及一种减少日志丢失的方法、移动终端及可读存储介质。
背景技术
目前Android系统上log实现的原理是应用运行期间调用log接口写log时,通过socket资源与logd进程进行通信,使得应用层能够在logd进程中写数据,其中,Android系统即安卓系统,log在计算机程序中翻译为日志,log信息是用于记录系统的运行信息,如手机使用信息,应用故障bug的记录;socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄,可以用来实现不同虚拟机或不同计算机之间的通信,在Internet上的主机一般运行了多个服务软件,同时提供几种服务,每种服务都打开一个Socket,并绑定到一个端口上,不同的端口对应于不同的服务;logd进程即日志保存进程,logd将数据写到其缓存中,当使用logcat(日志过滤工具)去获取数据的时候,也是通过基于UDP协议的进程通信通信去获取数据。
目前的技术方案下,为了保持运行效率各个应用在运行期间的进程都是通过基于UDP协议的进程通信跨进程通信方式将log信息传递给logd进程来保存下来的,但同时与logd进程进行进程通信的应用进程较多时,由于UDP协议本身的不可靠性,就可能会出现丢包,从而导致应用部分log信息丢失,且同时写Log的应用进程越多,log丢失情况越严重。
发明内容
本发明的主要目的在于提供一种减少日志丢失的方法、移动终端及可读存储介质,旨在解决现有应用测试中容易出现日志信息不完整的问题。
为实现上述目的,本发明提供一种减少日志丢失的方法,所述减少日志丢失的方法包括以下步骤:
在识别到第一应用运行时,判断日志系统中是否存在与第一应用对应的白名单;
若是,则建立所述白名单对应的第一日志保存进程与应用层的进程通信连接;
判断所述第一应用是否退出运行;
若是,则建立所述第二日志保存进程与应用层的进程通信连接,其中,所述第二日志保存进程为系统框架中除所述第一日志保存进程以外的日志保存进程。
优选地,所述在识别到第一应用运行时,判断日志系统中是否存在与第一应用对应的白名单的步骤之前,所述减少日志丢失的方法还包括:
将所述白名单加入所述日志系统;
开启所述日志系统。
优选地,所述在识别到第一应用运行时,判断日志系统中是否存在与第一应用对应的白名单的步骤包括:
在识别到第一应用运行时,调用所述日志系统的应用进程;
判断所述应用进程中是否存在与第一应用对应的白名单进程。
优选地,在执行所述判断所述第一应用是否退出运行的步骤时,减少日志丢失的方法还包括:
基于所述应用层在第一日志保存进程中写入第一日志信息。
优选地,所述建立所述白名单对应的第一日志保存进程与应用层的进程通信连接的步骤包括:
建立所述白名单对应的第一日志保存进程与应用层的进程通信连接,且关闭所述第二日志保存进程与应用层的进程通信连接。
优选地,所述若是,则建立所述第二日志保存进程与应用层的进程通信连接的步骤包括:
在识别到第二应用运行时,建立所述第二日志保存进程与应用层的进程通信连接,其中,所述第二应用为系统应用中除第一应用以外的应用;
基于所述应用层在所述第二日志保存进程中写入第二日志信息。
优选地,所述第一应用运行的识别、第二应用运行的识别及判断所述第一应用是否退出运行均通过所述系统框架的进程管理进行判断。
优选地,所述第一日志保存进程与应用层的进程之间、第二日志保存进程与应用层的进程之间均采用UDP协议进行通信。
此外,为实现上述目的,本发明还提供一种移动终端,所述移动终端包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的减少日志丢失的程序,所述减少日志丢失的程序被所述处理器执行时实现上述任一项所述的减少日志丢失的方法的步骤。
此外,为实现上述目的,本发明还提供一种可读存储介质,所述可读存储介质上存储有减少日志丢失的程序,所述减少日志丢失的程序被处理器执行时实现上述任一项所述的减少日志丢失的方法的步骤。
本发明在第一应用运行时,先判断日志系统中是否存在与第一应用对应的白名单,若存在,仅建立白名单对应的第一日志保存进程与应用层的进程通信连接,使得只有白名单的第一应用独占进程通信资源与日志保存进程进行通信写log,即写入第一日志信息,有效避免其它应用对应的日志信息的抓取,从而保证第一应用运行期间抓log的完整性。本发明通过添加白名单机制,避免UDP协议产生的可能出现丢包,从而导致应用部分log信息丢失的问题,有效保证第一应用运行能够完整的抓取log信息。
附图说明
图1为本发明各个实施例一种移动终端的硬件结构示意图;
图2为本发明实施例提供的一种通信网络系统框架图;
图3为本发明减少日志丢失的方法第一实施例的流程示意图;
图4为本发明减少日志丢失的方法第二实施例的流程示意图;
图5为本发明减少日志丢失的方法第三实施例的流程示意图;
图6为本发明减少日志丢失的方法第四实施例的流程示意图。
本发明目的的实现、功能特点及优点将结合实施例,参照附图做进一步说明。
具体实施方式
应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。
终端可以以各种形式来实施。例如,本发明中描述的移动终端可以包括诸如手机、平板电脑、笔记本电脑、掌上电脑、个人数字助理(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中示出的移动终端100结构并不构成对移动终端100的限定,移动终端100可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。
下面结合图1对移动终端100的各个部件进行具体的介绍:
射频单元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,分时双工长期演进)等。
Wi-Fi属于短距离无线传输技术,移动终端100通过Wi-Fi模块102可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图1示出了Wi-Fi模块102,但是可以理解的是,其并不属于移动终端100的必须构成,完全可以根据需要在不改变发明的本质的范围内而省略。
音频输出单元103可以在移动终端100处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将射频单元101或Wi-Fi模块102接收的或者在存储器109中存储的音频数据转换成音频信号并且输出为声音。而且,音频输出单元103还可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出单元103可以包括扬声器、蜂鸣器等等。
A/V输入单元104用于接收音频或视频信号。A/V输入单元104可以包括图形处理器(Graphics Processing Unit,GPU)1041和麦克风1042,图形处理器1041对在视频捕获模式或图像捕获模式中由图像捕获装置(如摄像头)获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元106上。经图形处理器1041处理后的图像帧可以存储在存储器109(或其它存储介质)中或者经由射频单元101或Wi-Fi模块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是移动终端100的控制中心,利用各种接口和线路连接整个移动终端的各个部分,通过运行或执行存储在存储器109内的软件程序和/或模块,以及调用存储在存储器109内的数据,执行移动终端100的各种功能和处理数据,从而对移动终端100进行整体监控。处理器110可包括一个或多个处理单元;优选的,处理器110可集成应用处理器和调制解调处理器,其中,应用处理器主要处理操作系统、用户界面和应用程序等,调制解调处理器主要处理无线通信。可以理解的是,上述调制解调处理器也可以不集成到处理器110中。
此外,在图1所示的移动终端中,处理器110用于调用存储器109中存储的减少日志丢失的程序,并执行以下操作:
在识别到第一应用运行时,判断日志系统中是否存在与第一应用对应的白名单;
若是,则建立所述白名单对应的第一日志保存进程与应用层的进程通信连接;
判断所述第一应用是否退出运行;
若是,则建立所述第二日志保存进程与应用层的进程通信连接,其中,所述第二日志保存进程为系统框架中除所述第一日志保存进程以外的日志保存进程。
进一步地,处理器110用于调用存储器109中存储的减少日志丢失的程序,还执行以下操作:
将所述白名单加入所述日志系统;
开启所述日志系统。
进一步地,处理器110用于调用存储器109中存储的减少日志丢失的程序,还执行以下操作:
在识别到第一应用运行时,调用所述日志系统的应用进程;
判断所述应用进程中是否存在与第一应用对应的白名单进程。
进一步地,处理器110用于调用存储器109中存储的减少日志丢失的程序,还执行以下操作:
基于所述应用层在第一日志保存进程中写入第一日志信息。
进一步地,处理器110用于调用存储器109中存储的减少日志丢失的程序,还执行以下操作:
建立所述白名单对应的第一日志保存进程与应用层的进程通信连接,且关闭所述第二日志保存进程与应用层的进程通信连接。
进一步地,处理器110用于调用存储器109中存储的减少日志丢失的程序,还执行以下操作:
在识别到第二应用运行时,建立所述第二日志保存进程与应用层的进程通信连接,其中,所述第二应用为系统应用中除第一应用以外的应用;
基于所述应用层在所述第二日志保存进程中写入第二日志信息。
移动终端100还可以包括给各个部件供电的电源111(比如电池),优选的,电源111可以通过电源管理系统与处理器110逻辑相连,从而通过电源管理系统实现管理充电、放电、以及功耗管理等功能。
尽管图1未示出,移动终端100还可以包括蓝牙模块等,在此不再赘述。
为了便于理解本发明实施例,下面对本发明的移动终端所基于的通信网络系统进行描述。
请参阅图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为本发明减少日志丢失的方法第一实施例的流程示意图。
在本实施例中,该减少日志丢失的方法包括以下步骤:
步骤S10,在识别到第一应用运行时,判断日志系统中是否存在与第一应用对应的白名单。
在本实施例中,在识别到第一应用运行时,判断日志系统中是否存在与第一应用对应的白名单。首先,将白名单添加到日志系统中,在第一应用运行时,便于日志框架调用日志系统中的白名单。
安卓(Android)系统提供了一个灵活的日志系统(logging系统),允许应用程序和系统组件等整个系统记录logging信息,它是独立于Linux Kernel的一个logging系统,kernel是通过”pr_info”、”printk”等存储,通过“dmesg”或“cat/proc/kmsg”获取。日志系统是日志的具体实现,经典的有log4j;jdk自带的有java.util.Logging;还有logBack等等。如果只存在一种日志系统,日志框架完全没有必要存在(logBack无法独立使用),但事与愿违,为了解决多个日志系统的兼容问题,日志框架应运而生。
白名单的概念与“黑名单”相对应。例如:在电脑系统里,有很多软件都应用到了黑白名单规则,操作系统、防火墙、杀毒软件、邮件系统、应用软件等,凡是涉及到控制方面几乎都应用了黑白名单规则。
黑名单启用后,被列入到黑名单的用户(或IP地址、IP包、邮件、病毒等)不能通过。如果设立了白名单,则在白名单中的用户(或IP地址、IP包、邮件等)会优先通过,不会被当成垃圾邮件拒收,安全性和快捷性都大大提高。将其含义扩展一步,那么凡有黑名单功能的应用,就会有白名单功能与其对应。
本案是对第一应用设定了白名单,使得除了第一应用对应的第一日志保存进程与应用层的进程通信能够连接,其它没有白名单的日志保存进程与应用层的进程通信均无法连接,从而保证应用层在第一日志保存进程中写入第一日志信息。
因此,采用日志框架调用日志系统的形式,便于多个日志系统的调配,并且,在日志系统中添加了第一应用对应的白名单,若日志系统中存在与第一应用对应的白名单,那么通过白名单,便于在日志保存进程与应用层的进程通信时能够优先开启。
步骤S20,若是,则建立所述白名单对应的第一日志保存进程与应用层的进程通信连接。
在本实施例中,若日志系统中存在与第一应用对应的白名单,则建立所述白名单对应的第一日志保存进程与应用层的进程通信连接。进程通信连接即socket连接,网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为一个socket。
建立网络通信连接至少要一对端口号(socket)。socket本质是编程接口(API),对TCP/IP的封装,TCP/IP也要提供可供程序员做网络开发所用的接口,这就是Socket编程接口;HTTP是轿车,提供了封装或者显示数据的具体形式;Socket是发动机,提供了网络通信的能力。
Socket的英文原义是“孔”或“插座”。作为BSD UNIX的进程通信机制,取后一种意思。通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄,可以用来实现不同虚拟机或不同计算机之间的通信。在Internet上的主机一般运行了多个服务软件,同时提供几种服务。每种服务都打开一个Socket,并绑定到一个端口上,不同的端口对应于不同的服务。Socket正如其英文原义那样,像一个多孔插座。一台主机犹如布满各种插座的房间,每个插座有一个编号,有的插座提供220伏交流电,有的提供110伏交流电,有的则提供有线电视节目。客户软件将插头插到不同编号的插座,就可以得到不同的服务。
日志保存进程,即logd,logd是Android L版本提出来的概念,其作用是保存Android运行期间的log(日志)。在Android L之前,log由kernel的ring buffer保存,在Android L之后,log保存在用户空间。
在检测到第一应用在运行时,调用日志系统的应用进程,若应用进程中存在与第一应用对应的白名单进程,仅开启白名单对应的第一日志保存进程与应用层的进程通信连接,且关闭白名单以外的日志进程与应用层的进程通信连接
步骤S30,判断所述第一应用是否退出运行。
在本实施例中,在开启白名单后,使得第一日志保存进程与应用层的进程能够通信连接。在第一应用运行时,应用层在第一日志保存进程中写入第一日志内容,并且,通过系统框架的进程管理机制判断第一应用是否退出运行,在第一应用完成测试时,进程管理机制会检测到第一应用自动退出运行的退出信息,且第一日志内容会记载第一应用已退出运行,因此,进程管理机制能得知第一应用是否退出运行。
步骤S40,若是,则建立所述第二日志保存进程与应用层的进程通信连接,其中,所述第二日志保存进程为所述日志框架中除所述第一日志保存进程以外的日志保存进程。
本实施例中,在判定第一应用退出运行后,建立第二日志保存进程与应用层的进程通信连接。第二日志保存进程为所述日志框架中除所述白名单对应的第一日志保存进程以外的日志保存进程。由于第一应用已经退出运行,因此,允许白名单以外的日志保存进程与应用层的进程能够通信连接。当然,在第一应用退出运行时,已能完整抓取第一应用运行时的所有log信息,因此,在第一应用运行退出后,可允许第二日志保存进程与应用层的进程通信连接,便于第二应用运行时的log信息抓取。
本发明在在第一应用运行时,先判断日志系统中是否存在与第一应用对应的白名单,若存在,仅建立白名单对应的第一日志保存进程与应用层的进程通信连接,使得只有白名单的第一应用独占进程通信资源与日志保存进程进行通信写log,即写入第一日志信息,有效避免其它应用对应的日志信息的抓取,从而保证第一应用运行期间抓log的完整性。本发明通过添加白名单机制,避免UDP协议产生的可能出现丢包,从而导致应用部分log信息丢失的问题,有效保证第一应用运行能够完整的抓取log信息。
基于第一实施例,提出本发明减少日志丢失的方法的第二实施例,参照图4,在本实施例中,步骤S10之前,减少日志丢失的方法还包括:
步骤S11,将所述白名单加入所述日志系统;
步骤S12,开启所述日志系统。
本实施例中,在识别到第一应用运行前,先将白名单添加至日志系统中,接着,打开日志系统,再运行第一应用。比如,在测试安卓系统中的日历应用时,先将日历应用的白名单添加到日志系统中,在开启日志系统后,开始运行日历应用,使得对日历应用进行测试,并且,在测试时,会抓取日历应用测试时的日志信息,即log信息。
通过在运行第一应用前添加与第一应用对应的白名单至日志系统中,使得在第一应用运行时,至抓取第一应用对应的日志信息,保证log信息的完整性,有效避免丢包问题。
基于第一实施例,提出本发明减少日志丢失的方法的第三实施例,参照图5,在本实施例中,步骤S10包括:
步骤S100,在识别到第一应用运行时,调用所述日志系统的应用进程;
步骤S101,判断所述应用进程中是否存在与第一应用对应的白名单进程。
本实施例中,在识别到第一应用运行时,判断日志系统中是否存在与第一应用对应的白名单具体为:在识别到第一应用运行时,调用所述日志系统的应用进程,判断所述应用进程中是否存在与第一应用对应的白名单进程。
通过进程管理机制识别第一应用运行时,调用日志系统中的应用进程,对应用进程进行判断,若应用进程中存在与第一应用对应的白名单进程,则调用该白名单进程,从而实现白名单对应的第一日志保存进程与应用层的进程通信连接的开启。
进一步地,在执行步骤S30时,本发明的减少日志丢失的方法还包括:
基于所述应用层在第一日志保存进程中写入第一日志信息。
本实施例中,在判断第一应用是否退出运行的同时,应用层在第一日志保存进程中写入第一日志信息。由于其他日志进程与应用层的进程通信已被关闭,因此,能够完整的抓取第一日志信息并保存。
若第一应用未测试完成,那么就会处于运行状态,需要持续抓取log信息,并且,关闭了其它安卓应用对应的第二日志保存进程与应用层的进程通信连接,使得第一应用在运行时,能够完整的抓取log信息。
进一步地,步骤S20包括:
建立所述白名单对应的第一日志保存进程与应用层的进程通信连接,且关闭所述第二日志保存进程与应用层的进程通信连接。
本实施例中,在第一应用运行时,开启所述白名单对应的第一日志保存进程与应用层的进程通信连接,且关闭所述第二日志保存进程与应用层的进程通信连接。开启所述白名单对应的第一日志保存进程与应用层的进程通信连接,使得应用层能够在第一日志保存进程中写入第一日志信息;关闭所述第二日志保存进程与应用层的进程通信连接,避免应用层在第二日志进程中写入第二日志信息,从而有效保证第一日志信息的完整性。
基于第一实施例,提出本发明减少日志丢失的方法的第四实施例,参照图6,在本实施例中,步骤S40包括:
步骤S41,在识别到第二应用运行时,建立所述第二日志保存进程与应用层的进程通信连接,其中,所述第二应用为系统应用中除第一应用以外的应用;
步骤S42,基于所述应用层在所述第二日志保存进程中写入第二日志信息。
本实施例中,若判断第一应用退出运行,则建立第二日志保存进程与应用层的进程通信连接,具体为:在识别到第二应用运行时,建立所述第二日志保存进程与应用层的进程通信连接,其中,所述第二应用为系统应用中除第一应用以外的应用,基于所述应用层在所述第二日志保存进程中写入第二日志信息。
由于第一应用已退出运行,因此,在测试其它应用时,可以按照常规的测试方法,常规的抓log方法,开启第二应用对应的第二日志保存进程与应用层的进程通信连接后,应用层便可在第二日志保存进程中写入第二日志信息。
进一步地,第一应用运行的识别、第二应用运行的识别及判断所述第一应用是否退出运行均通过所述系统框架的进程管理进行判断。
第一应用运行的识别、第二应用运行的识别及判断所述第一应用是否退出运行均通过所述系统框架的进程管理进行判断。进程管理为系统框架中用于管理如应用进程等一系列进程的管理,不管是应用运行的识别、应用退出运行的识别判断,均通过进程管理机制获取。
进一步地,所述第一日志保存进程与应用层的进程之间、第二日志保存进程与应用层的进程之间均采用UDP协议进行通信。
UDP是User Data gram Protocol的简称,中文名是用户数据报协议,是OSI(OpenSystem Interconnection,开放式系统互联)参考模型中一种无连接的传输层协议,提供面向事务的简单不可靠信息传送服务,IETF RFC 768是UDP的正式规范。UDP在IP报文的协议号是17。
UDP协议全称是用户数据报协议,在网络中它与TCP协议一样用于处理数据包,是一种无连接的协议。在OSI模型中,在第四层——传输层,处于IP协议的上一层。UDP有不提供数据包分组、组装和不能对数据包进行排序的缺点,也就是说,当报文发送之后,是无法得知其是否安全完整到达的。UDP用来支持那些需要在计算机之间传输数据的网络应用。包括网络视频会议系统在内的众多的客户/服务器模式的网络应用都需要使用UDP协议。UDP协议从问世至今已经被使用了很多年,虽然其最初的光彩已经被一些类似协议所掩盖,但是即使是在今天UDP仍然不失为一项非常实用和可行的网络传输层协议。
与所熟知的TCP(传输控制协议)协议一样,UDP协议直接位于IP(网际协议)协议的顶层。根据OSI(开放系统互连)参考模型,UDP和TCP都属于传输层协议。UDP协议的主要作用是将网络数据流量压缩成数据包的形式。一个典型的数据包就是一个二进制数据的传输单位。每一个数据包的前8个字节用来包含报头信息,剩余字节则用来包含具体的传输数据。
UDP是OSI参考模型中一种无连接的传输层协议,它主要用于不要求分组顺序到达的传输中,分组传输顺序的检查与排序由应用层完成,提供面向事务的简单不可靠信息传送服务。UDP协议基本上是IP协议与上层协议的接口。UDP协议适用端口分别运行在同一台设备上的多个应用程序。
UDP提供了无连接通信,且不对传送数据包进行可靠性保证,适合于一次传输少量数据,UDP传输的可靠性由应用层负责。常用的UDP端口号有:DNS 53、TFTP 69、SNMP 161。而UDP报文没有可靠性保证、顺序保证和流量控制字段等,可靠性较差。
UDP以其简单、传输快的优势,在越来越多场景下取代了TCP,如实时游戏。具体为:
1)网速的提升给UDP的稳定性提供可靠网络保障,丢包率很低,如果使用应用层重传,能够确保传输的可靠性;
2)TCP为了实现网络通信的可靠性,使用了复杂的拥塞控制算法,建立了繁琐的握手过程,由于TCP内置的系统协议栈中,极难对其进行改进。
采用TCP,一旦发生丢包,TCP会将后续的包缓存起来,等前面的包重传并接收到后再继续发送,延时会越来越大,基于UDP对实时性要求较为严格的情况下,采用自定义重传机制,能够把丢包产生的延迟降到最低,尽量减少网络问题对游戏性造成影响。
因此,本案采用UDP协议,结合添加白名单机制,有效减少某一安卓应用测试时日志丢包现象,针对某一安卓应用的测试,不但具有简单、传输快的优势,而且,能够完整的抓取测试过程中的log信息。
此外,本发明实施例还提出一种可读存储介质,所述可读存储介质上存储有减少日志丢失的程序,所述减少日志丢失的程序被处理器执行时实现如下操作:
在识别到第一应用运行时,判断日志系统中是否存在与第一应用对应的白名单;
若是,则建立所述白名单对应的第一日志保存进程与应用层的进程通信连接;
判断所述第一应用是否退出运行;
若是,则建立所述第二日志保存进程与应用层的进程通信连接,其中,所述第二日志保存进程为系统框架中除所述第一日志保存进程以外的日志保存进程。
进一步地,所述减少日志丢失的程序被处理器执行时还实现如下操作:
将所述白名单加入所述日志系统;
开启所述日志系统。
进一步地,所述减少日志丢失的程序被处理器执行时还实现如下操作:
在识别到第一应用运行时,调用所述日志系统的应用进程;
判断所述应用进程中是否存在与第一应用对应的白名单进程。
进一步地,所述减少日志丢失的程序被处理器执行时还实现如下操作:
基于所述应用层在第一日志保存进程中写入第一日志信息。
进一步地,所述减少日志丢失的程序被处理器执行时还实现如下操作:
建立所述白名单对应的第一日志保存进程与应用层的进程通信连接,且关闭所述第二日志保存进程与应用层的进程通信连接。
进一步地,所述减少日志丢失的程序被处理器执行时还实现如下操作:
在识别到第二应用运行时,建立所述第二日志保存进程与应用层的进程通信连接,其中,所述第二应用为系统应用中除第一应用以外的应用;
基于所述应用层在所述第二日志保存进程中写入第二日志信息。
需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者终端不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者终端所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者终端中还存在另外的相同要素。
上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在如上所述的一个存储介质(如ROM/RAM、磁碟、光盘)中,包括若干指令用以使得一台终端设备(可以是移动终端,计算机,移动终端,空调器,或者网络设备等)执行本发明各个实施例所述的方法。
以上仅为本发明的优选实施例,并非因此限制本发明的专利范围,凡是利用本发明说明书及附图内容所作的等效结构或等效流程变换,或直接或间接运用在其他相关的技术领域,均同理包括在本发明的专利保护范围内。
Claims (8)
1.一种减少日志丢失的方法,其特征在于,所述减少日志丢失的方法包括以下步骤:
在识别到第一应用运行时,判断日志系统中是否存在与第一应用对应的白名单;
若是,则建立所述白名单对应的第一日志保存进程与应用层的进程通信连接,并关闭第二日志保存进程与应用层的进程通信连接,以供所述应用层在所述第一日志保存进程中写入第一日志信息,不在所述第二日志保存进程中写入第二日志信息;
判断所述第一应用是否退出运行;
若是,则建立所述第二日志保存进程与应用层的进程通信连接,其中,所述第二日志保存进程为系统框架中除所述第一日志保存进程以外的日志保存进程。
2.如权利要求1所述的减少日志丢失的方法,其特征在于,所述在识别到第一应用运行时,判断日志系统中是否存在与第一应用对应的白名单的步骤之前,所述减少日志丢失的方法还包括:
将所述白名单加入所述日志系统;
开启所述日志系统。
3.如权利要求1所述的减少日志丢失的方法,其特征在于,所述在识别到第一应用运行时,判断日志系统中是否存在与第一应用对应的白名单的步骤包括:
在识别到第一应用运行时,调用所述日志系统的应用进程;
判断所述应用进程中是否存在与第一应用对应的白名单进程。
4.如权利要求1所述的减少日志丢失的方法,其特征在于,所述若是,则建立所述第二日志保存进程与应用层的进程通信连接的步骤包括:
在识别到第二应用运行时,建立所述第二日志保存进程与应用层的进程通信连接,其中,所述第二应用为系统应用中除第一应用以外的应用;
基于所述应用层在所述第二日志保存进程中写入第二日志信息。
5.如权利要求1至4中任一项所述的减少日志丢失的方法,其特征在于,所述第一应用运行的识别、第二应用运行的识别及判断所述第一应用是否退出运行均通过所述系统框架的进程管理进行判断。
6.如权利要求1所述的减少日志丢失的方法,其特征在于,所述第一日志保存进程与应用层的进程之间、第二日志保存进程与应用层的进程之间均采用UDP协议进行通信。
7.一种移动终端,其特征在于,所述移动终端包括:存储器、处理器及存储在所述存储器上并可在所述处理器上运行的减少日志丢失的程序,所述减少日志丢失的程序被所述处理器执行时实现如权利要求1至6中任一项所述的减少日志丢失的方法的步骤。
8.一种可读存储介质,其特征在于,所述可读存储介质上存储有减少日志丢失的程序,所述减少日志丢失的程序被处理器执行时实现如权利要求1至6中任一项所述的减少日志丢失的方法的步骤。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811137200.6A CN109117630B (zh) | 2018-09-27 | 2018-09-27 | 减少日志丢失的方法、移动终端及可读存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811137200.6A CN109117630B (zh) | 2018-09-27 | 2018-09-27 | 减少日志丢失的方法、移动终端及可读存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN109117630A CN109117630A (zh) | 2019-01-01 |
CN109117630B true CN109117630B (zh) | 2023-08-01 |
Family
ID=64856959
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201811137200.6A Active CN109117630B (zh) | 2018-09-27 | 2018-09-27 | 减少日志丢失的方法、移动终端及可读存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN109117630B (zh) |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2001318810A (ja) * | 2000-05-11 | 2001-11-16 | Ricoh Co Ltd | プロセス間通信ログ方式及び装置並びに通信ログの手順を記録した記録媒体 |
CN103019824A (zh) * | 2012-12-21 | 2013-04-03 | 曙光信息产业(北京)有限公司 | 元数据服务器下日志系统的多进程处理方法和系统 |
CN105138901A (zh) * | 2015-08-03 | 2015-12-09 | 浪潮电子信息产业股份有限公司 | 一种基于白名单的云主机主动防御实现方法 |
CN108549815A (zh) * | 2018-04-02 | 2018-09-18 | 郑州云海信息技术有限公司 | 一种白名单库管理系统及方法 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP6712922B2 (ja) * | 2016-07-22 | 2020-06-24 | 株式会社日立ソリューションズ | データ漏洩防止システム及びデータ漏洩防止方法 |
-
2018
- 2018-09-27 CN CN201811137200.6A patent/CN109117630B/zh active Active
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2001318810A (ja) * | 2000-05-11 | 2001-11-16 | Ricoh Co Ltd | プロセス間通信ログ方式及び装置並びに通信ログの手順を記録した記録媒体 |
CN103019824A (zh) * | 2012-12-21 | 2013-04-03 | 曙光信息产业(北京)有限公司 | 元数据服务器下日志系统的多进程处理方法和系统 |
CN105138901A (zh) * | 2015-08-03 | 2015-12-09 | 浪潮电子信息产业股份有限公司 | 一种基于白名单的云主机主动防御实现方法 |
CN108549815A (zh) * | 2018-04-02 | 2018-09-18 | 郑州云海信息技术有限公司 | 一种白名单库管理系统及方法 |
Also Published As
Publication number | Publication date |
---|---|
CN109117630A (zh) | 2019-01-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10237291B2 (en) | Session processing method and device, server and storage medium | |
CN109195213B (zh) | 移动终端屏幕控制方法、移动终端及计算机可读存储介质 | |
CN110162418B (zh) | 应用冷启动方法、移动终端及计算机可读存储介质 | |
CN110784898A (zh) | 网络切换方法、移动终端及计算机可读存储介质 | |
CN107135128B (zh) | 调用链数据采集方法、移动终端及计算机可读存储介质 | |
CN110096375B (zh) | 一种应用程序共享数据方法、装置及计算机可读存储介质 | |
CN112631535A (zh) | 一种投屏反向控制方法及装置、移动终端、存储介质 | |
CN109862603A (zh) | Apn自适应方法、移动终端和可读存储介质 | |
CN108958936B (zh) | 应用程序切换方法、移动终端及计算机可读存储介质 | |
CN111427709B (zh) | 一种应用程序分身控制方法、设备及计算机可读存储介质 | |
CN109660973A (zh) | 蓝牙控制方法、移动终端及存储介质 | |
CN110113779B (zh) | eSIM卡的测试方法、系统和介质 | |
WO2019184763A1 (zh) | 通信范围信息的处理方法及终端 | |
CN112770279B (zh) | 网络共享方法、移动终端及计算机可读存储介质 | |
CN107517487B (zh) | 通话控制方法及移动终端 | |
CN108900503A (zh) | 数据通信方法、通信处理设备、终端及可读存储介质 | |
CN110475303B (zh) | 一种数据传输方法及终端设备 | |
CN107729236A (zh) | 应用程序的管理方法、装置、移动终端及存储介质 | |
CN109117630B (zh) | 减少日志丢失的方法、移动终端及可读存储介质 | |
CN108183833B (zh) | 一种响应处理方法、装置及计算机可读存储介质 | |
CN107204977B (zh) | 接口安全校验方法及装置、计算机可读存储介质 | |
CN110955397A (zh) | 游戏终端帧率的设置方法、游戏终端及存储介质 | |
CN107580106B (zh) | 一种通话控制方法、移动终端和计算机可读存储介质 | |
CN113179307B (zh) | 一种音频时延控制方法、设备及计算机可读存储介质 | |
CN110087290B (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 |