一种日志获取方法、终端及计算机可读存储介质与流程

文档序号:18160642发布日期:2019-07-13 09:19阅读:124来源:国知局
本发明涉及终端
技术领域
:,更具体地说,涉及一种日志获取方法、终端及计算机可读存储介质。
背景技术
::在用户使用手机过程中,偶尔会出现无线网络的异常中断或网络访问的异常中断。为了定位并解决网络异常问题,网络异常出现时的无线网络日志非常重要。但一般用户缺乏专业的网络知识,无法在网络异常出现后的第一时间开启相关无线网络日志,这就给研发人员分析解决无线网络问题增加了很大的难度。技术实现要素:本发明要解决的技术问题在于:普通用户在网络异常时,不会及时开启无线网络日志,导致研发人员无法根据无线网络日志对网络异常问题进行定位及解决,针对该技术问题,提供一种日志获取方法、终端及计算机可读存储介质。为解决上述技术问题,本发明提供一种日志获取方法,日志获取方法包括:通过wpa_supplicant(wi-fi网络安全接入请求者)进程监测网络异常;在wpa_supplicant进程监测到网络异常后,通过socket(套接字)通知日志获取守护进程当前出现网络异常;通过日志获取守护进程获取无线网络日志。可选的,通过socket通知日志获取守护进程当前出现网络异常之前,还包括:通过persist属性控制被默认处于关闭状态的日志获取守护进程启动。可选的,通过persist属性控制被默认处于关闭状态的日志获取守护进程启动包括:将init.rc脚本中目标persist属性的值设置为true,目标persist属性为控制日志获取守护进程的persist属性。可选的,通过日志获取守护进程获取无线网络日志之后,还包括:控制日志获取守护进程进行关闭状态。可选的,通过wpa_supplicant进程监测网络异常包括:通过wpa_supplicant进程监测无线网络的异常中断;和/或,通过wpa_supplicant进程监测无线网络访问的异常中断。可选的,无线网络日志包括tcpdump(传输控制协议文件备份)日志、wlan(wirelesslocalareanetworks,无线局域网)固件日志以及wlan驱动日志中的至少一种。可选的,若无线网络日志为tcpdump日志,则通过日志获取守护进程获取无线网络日志包括:通过日志获取守护进程调用tcp命令获取tcpdump日志。可选的,通过socket通知日志获取守护进程当前出现网络异常之前,还包括:接收输入指令;确定输入指令为用于控制终端进入日志自动获取模式的指令。进一步地,本发明还提供了一种终端,终端包括处理器、存储器及通信总线;通信总线用于实现处理器和存储器之间的连接通信;处理器用于执行存储器中存储的一个或者多个程序,以实现如上任一项的日志获取方法的步骤。进一步地,本发明还提供了一种计算机可读存储介质,该计算机可读存储介质存储有一个或者多个程序,一个或者多个程序可被一个或者多个处理器执行,以实现如上任一项的日志获取方法的步骤。有益效果本发明提供一种日志获取方法、终端及计算机可读存储介质,针对现有技术中网络异常时无线网络日志的获取需要用户手动开启,而用户因为缺乏相关专业知识,因此导致无线网络日志得不到及时开启,影响研发人员对无线网络异常问题的定位与解决的问题,本发明实施例提供的日志获取方法,通过wpa_supplicant进程监测网络异常,在wpa_supplicant进程监测到网络异常后,通过套接字socket通知日志获取守护进程当前出现网络异常,然后由日志获取守护进程自动地获取无线网络日志。所以,在网络异常之后,无需用户手动操作就能自动开启无线网络日志,从而利用无线网络日志收集网络异常的相关信息,为研发人员定位无线网络异常问题、解决无线网络异常问题提供依据,进而让无线网络异常问题能够顺利得到解决,提升用户的网络体验。附图说明下面将结合附图及实施例对本发明作进一步说明,附图中:图1为实现本发明各个实施例一个可选的移动终端的硬件结构示意图。图2为如图1所示的移动终端的无线通信系统示意图;图3为本发明第一实施例中提供的日志获取方法的一种流程图;图4为本发明第一实施例中提供的wpa_supplicant进程与日志获取守护进程的一种示意图;图5为本发明第一实施例中提供的终端的一种显示界面示意图;图6为本发明第一实施例中提供的终端的另一种显示界面示意图;图7为本发明第二实施例中提供的日志获取方法的一种流程图;图8为本发明第三实施例中提供的终端的一种硬件结构示意图。具体实施方式应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。在后续的描述中,使用用于表示元件的诸如“模块”、“部件”或“单元”的后缀仅为了有利于本发明的说明,其本身没有特定的意义。因此,“模块”、“部件”或“单元”可以混合地使用。终端可以以各种形式来实施。例如,本发明中描述的终端可以包括诸如手机、平板电脑、笔记本电脑、掌上电脑、个人数字助理(personaldigitalassistant,pda)、便捷式媒体播放器(portablemediaplayer,pmp)、导航装置、可穿戴设备、智能手环、计步器等移动终端,以及诸如数字tv、台式计算机等固定终端。后续描述中将以移动终端为例进行说明,本领域技术人员将理解的是,除了特别用于移动目的的元件之外,根据本发明的实施方式的构造也能够应用于固定类型的终端。请参阅图1,其为实现本发明各个实施例的一种移动终端的硬件结构示意图,该移动终端100可以包括:rf(radiofrequency,射频)单元101、wifi模块102、音频输出单元103、a/v(音频/视频)输入单元104、传感器105、显示单元106、用户输入单元107、接口单元108、存储器109、处理器110、以及电源111等部件。本领域技术人员可以理解,图1中示出的移动终端结构并不构成对移动终端的限定,移动终端可以包括比图示更多或更少的部件,或者组合某些部件,或者不同的部件布置。下面结合图1对移动终端的各个部件进行具体的介绍:射频单元101可用于收发信息或通话过程中,信号的接收和发送,具体的,将基站的下行信息接收后,给处理器110处理;另外,将上行的数据发送给基站。通常,射频单元101包括但不限于天线、至少一个放大器、收发信机、耦合器、低噪声放大器、双工器等。此外,射频单元101还可以通过无线通信与网络和其他设备通信。上述无线通信可以使用任一通信标准或协议,包括但不限于gsm(globalsystemofmobilecommunication,全球移动通讯系统)、gprs(generalpacketradioservice,通用分组无线服务)、cdma2000(codedivisionmultipleaccess2000,码分多址2000)、wcdma(widebandcodedivisionmultipleaccess,宽带码分多址)、td-scdma(timedivision-synchronouscodedivisionmultipleaccess,时分同步码分多址)、fdd-lte(frequencydivisionduplexing-longtermevolution,频分双工长期演进)和tdd-lte(timedivisionduplexing-longtermevolution,分时双工长期演进)等。wifi属于短距离无线传输技术,移动终端通过wifi模块102可以帮助用户收发电子邮件、浏览网页和访问流式媒体等,它为用户提供了无线的宽带互联网访问。虽然图1示出了wifi模块102,但是可以理解的是,其并不属于移动终端的必须构成,完全可以根据需要在不改变发明的本质的范围内而省略。音频输出单元103可以在移动终端100处于呼叫信号接收模式、通话模式、记录模式、语音识别模式、广播接收模式等等模式下时,将射频单元101或wifi模块102接收的或者在存储器109中存储的音频数据转换成音频信号并且输出为声音。而且,音频输出单元103还可以提供与移动终端100执行的特定功能相关的音频输出(例如,呼叫信号接收声音、消息接收声音等等)。音频输出单元103可以包括扬声器、蜂鸣器等等。a/v输入单元104用于接收音频或视频信号。a/v输入单元104可以包括图形处理器(graphicsprocessingunit,gpu)1041和麦克风1042,图形处理器1041对在视频捕获模式或图像捕获模式中由图像捕获装置(如摄像头)获得的静态图片或视频的图像数据进行处理。处理后的图像帧可以显示在显示单元106上。经图形处理器1041处理后的图像帧可以存储在存储器109(或其它存储介质)中或者经由射频单元101或wifi模块102进行发送。麦克风1042可以在电话通话模式、记录模式、语音识别模式等等运行模式中经由麦克风1042接收声音(音频数据),并且能够将这样的声音处理为音频数据。处理后的音频(语音)数据可以在电话通话模式的情况下转换为可经由射频单元101发送到移动通信基站的格式输出。麦克风1042可以实施各种类型的噪声消除(或抑制)算法以消除(或抑制)在接收和发送音频信号的过程中产生的噪声或者干扰。移动终端100还包括至少一种传感器105,比如光传感器、运动传感器以及其他传感器。具体地,光传感器包括环境光传感器及接近传感器,其中,环境光传感器可根据环境光线的明暗来调节显示面板1061的亮度,接近传感器可在移动终端100移动到耳边时,关闭显示面板1061和/或背光。作为运动传感器的一种,加速计传感器可检测各个方向上(一般为三轴)加速度的大小,静止时可检测出重力的大小及方向,可用于识别手机姿态的应用(比如横竖屏切换、相关游戏、磁力计姿态校准)、振动识别相关功能(比如计步器、敲击)等;至于手机还可配置的指纹传感器、压力传感器、虹膜传感器、分子传感器、陀螺仪、气压计、湿度计、温度计、红外线传感器等其他传感器,在此不再赘述。显示单元106用于显示由用户输入的信息或提供给用户的信息。显示单元106可包括显示面板1061,可以采用液晶显示器(liquidcrystaldisplay,lcd)、有机发光二极管(organiclight-emittingdiode,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还可以包括蓝牙模块等,在此不再赘述。为了便于理解本发明实施例,下面对本发明的移动终端所基于的通信网络系统进行描述。请参阅图2,图2为本发明实施例提供的一种通信网络系统架构图,该通信网络系统为通用移动通信技术的lte系统,该lte系统包括依次通讯连接的ue(userequipment,用户设备)201,e-utran(evolvedumtsterrestrialradioaccessnetwork,演进式umts陆地无线接入网)202,epc(evolvedpacketcore,演进式分组核心网)203和运营商的ip业务204。具体地,ue201可以是上述终端100,此处不再赘述。e-utran202包括enodeb2021和其它enodeb2022等。其中,enodeb2021可以通过回程(backhaul)(例如x2接口)与其它enodeb2022连接,enodeb2021连接到epc203,enodeb2021可以提供ue201到epc203的接入。epc203可以包括mme(mobilitymanagemententity,移动性管理实体)2031,hss(homesubscriberserver,归属用户服务器)2032,其它mme2033,sgw(servinggateway,服务网关)2034,pgw(pdngateway,分组数据网络网关)2035和pcrf(policyandchargingrulesfunction,政策和资费功能实体)2036等。其中,mme2031是处理ue201和epc203之间信令的控制节点,提供承载和连接管理。hss2032用于提供一些寄存器来管理诸如归属位置寄存器(图中未示)之类的功能,并且保存有一些有关服务特征、数据速率等用户专用的信息。所有用户数据都可以通过sgw2034进行发送,pgw2035可以提供ue201的ip地址分配以及其它功能,pcrf2036是业务数据流和ip承载资源的策略与计费控制策略决策点,它为策略与计费执行功能单元(图中未示)选择及提供可用的策略和计费控制决策。ip业务204可以包括因特网、内联网、ims(ipmultimediasubsystem,ip多媒体子系统)或其它ip业务等。虽然上述以lte系统为例进行了介绍,但本领域技术人员应当知晓,本发明不仅仅适用于lte系统,也可以适用于其他无线通信系统,例如gsm、cdma2000、wcdma、td-scdma以及未来新的网络系统等,此处不做限定。基于上述移动终端硬件结构以及通信网络系统,提出本发明方法各个实施例。第一实施例为了解决现有技术中无线网络日志的开启依赖于用户手动操作,导致无线网络日志不能在网络异常后的第一时间得到开启,无法及时收集无线网络异常的相关信息为研发人员定位、解决问题提供依据,影响无线网络异常问题的解决,影响了用户无线网络体验的问题,本实施例提供一种日志获取方法,图3为本实施例提供的日志获取方法基本流程图:s302:通过wpa_supplicant进程监测网络异常。在android(安卓)系统当中,存在wpa_supplicant进程。wpa_supplicant进程是一个独立运行的守护进程,其核心是一个消息循环,在消息循环中处理wpa状态机、控制命令、驱动事件、配置信息等。wpa_supplicant进程可以对终端的无线网络异常进行监测,也就是说,在终端的无线网络异常的时候,wpa_supplicant进程可以及时了解到。在本实施例中,无线网络异常至少包括以下两种,一种是无线网络的异常中断,另外一种是无线网络访问的异常中断。其中,无线网络的异常中断是指终端在wifi通信的过程中,突然无法接入之前接入的wifi热点,也即与wifi热点之间的连接被中断。例如,终端a原本正常接入到wifi名称为“123”的wifi热点进行网络访问,但因为某些不明确的突发原因,导致终端a与wifi热点“123”的连接断开,终端a因此无法继续进行网络访问,这就属于无线网络的异常中断。而无线网络访问的异常中断则是指终端在通过wifi热点进行网络访问的过程中,突然无法继续进行网络访问,但与wifi热点之间的连接正常。例如,终端b同样接入到wifi名称为“123”的wifi热点下,终端b通过wifi热点“123”进行网络访问,如观看在线视频、文件上传下载以及与朋友的即时通讯等,但因为某些原因,终端b不能继续再进行这些网络访问,不过,虽然不能正常进行网络访问,但是终端b还是可以正常接入到wifi热点“123”下,这种情况就属于无线网络访问的异常中断。s304:在wpa_supplicant进程监测到网络异常后,通过socket通知日志获取守护进程当前出现网络异常。本实施例中,可以在android系统中,增加日志获取守护进程,该日志获取守护进程用于根据wpa_supplicant进程对无线网络异常的监测结果来进行无线网络日志的获取。在wpa_supplicant进程监测确定当前出现了网络异常之后,可以将这一情况通知给日志获取守护进程,以便日志获取守护进程能够了解到无线网络异常,并进行日志获取。在本实施例的一些示例当中,wpa_supplicant进程可以通过socket向日志获取守护进程通知无线网络异常的消息。网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端就被称为一个socket。所以,在这些示例当中,终端可以在wpa_supplicant进程中建立一个socket,在日志获取守护进程中设置另外一个socket,从而通过这两个socket建立wpa_supplicant进程与日志守护进程之间的连接,实现二者之间的通信。请参见图4示出的wpa_supplicant进程41与日志获取守护进程42通过socket连接,其中,wpa_supplicant进程41中设置有socket发送模块410,而日志守护进程42中设置有socket接收模块420,在wpa_supplicant进程41与日志守护进程42之间通过socket通信连接之后,wpa_supplicant进程41可以将网络异常消息发送给日志守护进程42。s306:通过日志获取守护进程获取无线网络日志。日志获取守护进程通过socket连接接收到wpa_supplicant进程发送的网络异常消息后,可以进行无线网络日志的获取。在本实施例中,日志获取守护进程获取的无线网络日志包括以下几种中的至少一种:·tcpdump日志;·wlan驱动日志;·wlan固件日志。其中,对于tcpdump日志,日志获取守护进程可以通过调用响应的tcp命令获取。而对于wlan驱动日志以及wlan固件日志,日志获取守护进程则可以利用cnss_diag进行调用。在本实施例的一些示例当中,终端只有处于“日志自动获取模式”的时候,才会自动进行无线网络日志的启动与抓取。也就是说,wpa_supplicant进程在通过socket通知日志获取守护进程当前出现网络异常之前,需要确定终端当前是处于日志自动获取模式下的。如果终端当前并未处于日志自动获取模式,则即便是wpa_supplicant进程监测到了无线网络的异常,其也可以不必通过socket通知日志获取守护进程。在本实施例的一些示例当中,用户可以通过向终端输入指令,并通过该输入指令控制终端进入到日志自动获取模式。例如,用户通过终端的触控屏向终端下发输入指令,当终端判断用户的输入指令是用于控制进入日志自动获取模式的指令后,终端可以控制终端进入日志自动获取模式。请参见图5-图6示出的终端交互界面示意图:终端50的“设置”界面中,示出有日志自动获取模式的开关控件51,用户可以通过选择是否开启该开关,从而决定是否进入日志自动获取模式。在图5当中,日志自动获取模式的开关控件51处于关闭状态,用户通过触控该开关控件51则可以改变日志自动获取模式的状态。图6示出的终端交互界面示意图是由用户对图5中开关控件51进行操作之后的一种示意图,在图6当中,日志自动获取模式的开关控件51则处于开启状态,在后续过程中,当终端的无线网络出现异常时,终端可以在无需用户操作的情况下自动获取对应的无线网络日志,实现无线网络异常相关信息的收集。在本实施例的一些示例当中,日志获取守护进程是默认处于关闭状态下的,只有在wpa_supplicant进程监测到了无线网络的异常,需要日志获取守护进程进行日志获取的时候,才会控制日志获取守护进程从关闭状态进入开启状态,这样,可以保证日志获取守护进程有针对性地进行日志获取,在无线网络正常的情况下,不获取不必要的无线网络日志占用终端的处理资源;同时又保证在终端的无线网络出现异常后,能够在第一时间启动日志获取,避免丢失无线网络异常情况下的无线网络日志信息。终端可以通过persist属性控制日志获取守护进程的启动关闭,例如,终端可以在andorid系统的init.rc脚本中设置一个与日志获取守护进程相对应的persist属性,为了便于介绍,本实施例中将该与日志获取守护进程相对应的persist属性称为“目标persist属性”。在通常情况下,init.rc脚本中的目标persist属性的值为false,此时,日志获取守护进程处于关闭状态;当目标persist的值被设置为true之后,则日志获取守护进程开启。例如,在一个示例当中,通过“1”表征true,通过“0”表征false,则在默认情况下,init.rc脚本中的目标persist属性的值为“0”。在wpa_supplicant进程监测到无线网络的异常中断或者无线网络访问的异常中断之后,可以将目标persist属性的值设置为“1”,这样就可以控制日志获取守护进程启动了。当然,本领域技术人员可以理解的是,在本实施例的其他一些示例当中,也可以通过“0”表征true,同时采用“1”来表征false,或者是在采用“0”表征true的同时,采用非0值来表征false,这些都是可以灵活选择的,本实施例中不限定为具体的某一种实现方式。当然,在日志获取守护进程完成无线网络日志的获取之后,终端可以控制将该进程关闭掉,避免日志获取守护进程继续工作,从而节省终端的处理器资源。当然终端可以将目标persist属性的值再次设置为“0”,也即false,这样就可以实现日志获取守护进程的关闭。在本实施例的另外一些示例当中,终端可以设置日志获取守护进程的开启时间,例如,终端设置日志守护获取进程每次开启的时间是10s,则终端可以在日志获取守护进程开启的时刻开始计时,当10s的计时完成之后,终端可以通过改变init.rc脚本中目标persist属性的值完成日志获取守护进程的关闭。本领域技术人员可以理解的是,日志获取守护进程开启10s仅仅是一种示例,在实际情况中,可以由终端研发人员根据日志获取守护进程抓取无线网络日志所需要的时间来设置该守护进程的开启时间,并不限于10s。本实施例提供的日志获取方法,通过wpa_supplicant进程监测网络异常,在wpa_supplicant进程监测到网络异常后,通过套接字socket通知日志获取守护进程当前出现网络异常,然后由日志获取守护进程自动地获取无线网络日志。在网络异常之后,在没有用户手动操作的情况下就能自动开启无线网络日志,记录无线网络异常的相关信息,从而为研发人员定位、解决无线网络异常问题提供依据,让无线网络异常问题能够顺利得到解决,增强了用户的网络体验。更进一步地,终端中日志获取守护进程是默认处于关闭状态下的,只有在wpa_supplicant进程监测到了无线网络的异常,需要日志获取守护进程进行日志获取的时候,才会控制日志获取守护进程从关闭状态进入开启状态,这样,可以保证日志获取守护进程有针对性地进行日志获取,在无线网络正常的情况下,不获取不必要的无线网络日志占用终端的处理资源。第二实施例为了使本领域技术人员对第一实施例中所提供的日志获取方法的优点与细节更加清楚,本实施例将结合示例对该日志获取方法做进一步说明,请参见图7示出的日志获取方法的一种流程图:s702:wpa_supplicant进程进行网络监测。可以理解的是,wpa_supplicant进程在监测无线网络异常的时候,只要无线网络异常中断的情况与无线网络访问异常中断两种情况中出现了某一种,则可以认定当前出现了无线网络异常。当然,在通常情况下,这两种情况也不会同时出现。假定本实施例中的终端为用户的手机,用户通过将该手机连接到家里的wifi热点“11-12”下,然后通过wifi热点“11-12”进行网络访问。如果在某一时刻,用户的手机突然不能正常进行网络访问了,则可能是因为出现了以下两种情况:情况一,手机不能够连接到wifi热点“11-12”了,但是用户家里的wifi热点“11-12”尚处于正常工作状态目其他设备均可以正常连接到该热点。情况二,手机能够连接到wifi热点“11-12”,但是无法通过wifi热点“11-12”进行网络访问,但是用户家里的其他移动设备则可以连接到wifi热点“11-12”,并进行网络访问。s704:判断是否出现无线网络异常。若判断结果为是,则说明当前出现了无线网络异常,如果判断结果为否,则需要让wpa_supplicant进程继续进行无线网络监测。s706:通过修改init.rc脚本中的目标persist属性控制日志获取守护进程开启。在本实施例中,默认情况下,init.rc脚本中与日志获取守护进程对应的目标persist属性的取值为表征false的“0”,当wpa_supplicant进程监测到无线网络异常之后,终端可以对init.rc脚本中的目标persist属性的取值进行修改,将其值设置为表征true的“1”,从而控制日志获取守护进程开启,以便让日志获取守护进程能够自动进行无线网络日志的抓取。s708:wpa_supplicant进程通过socket连接向日志获取守护进程发送网络异常消息。在本实施例中,wpa_supplicant进程与日志获取守护进程中均设置有socket,当日志获取守护进程被开启之后,将会通过socket与wpa_supplicant进程建立起连接,从而实现wpa_supplicant进程与日志获取守护进程之间的通信。当wpa_supplicant进程与日志获取守护进程之间可以通信之后,wpa_supplicant进程将会向日志获取守护进程发送网络异常消息,从而通过该网络异常消息告知日志获取守护进程当前出现了网络异常,因此需要进行日志抓取。s710:日志获取守护进程根据网络异常消息获取无线网络日志。在本实施例中,日志获取守护进程获取的无线网络日志同时包括tcpdump日志、wlan固件日志以及wlan驱动日志三种,其中,tcpdump日志由日志获取守护进程通过tcp命令获取,而wlan固件日志以及wlan驱动日志,则由日志获取守护进程基于cnss_diag获取到。可以理解的是,在本实施例的其他一些示例当中,日志获取守护进程在获取无线网络日志的时候,也可以不必同时获取上述三种日志,而是选择其中的部分日志进行获取。s712:通过修改init.rc脚本中的目标persist属性控制日志获取守护进程关闭。在日志获取守护进程完成无线网络日志的获取之后,终端可以控制将该进程关闭掉,避免日志获取守护进程继续工作,从而节省终端的处理器资源。当然终端可以将目标persist属性的值再次设置为“0”,也即false,这样就可以实现日志获取守护进程的关闭。应当明白的是,由于日志获取守护进程获取无线网络日志通常是在用户使用终端的阶段进行无线网络异常相关信息的收集,而收集抓取的这些无线网络日志需要传递给终端的研发人员,才能够让研发人员基于无线网络日志中提供的网络异常信息进行网络异常问题的定位与解决,所以在本实施例中,当终端获取到无线网络日志,且无线网络异常恢复之后,需要将获取到的无线网络日志上传到服务器,以供研发人员查询。本实施例提供的日志获取方法,通过在wpa_supplicant进程中设置socket,并在安卓系统中增加日志获取守护进程,让日志获取守护进程与wpa_supplicant进程通过socket通信。在wpa_supplicant进程监测到终端的无线网络出现异常之后,通过socket通知日志获取守护进程金慈宁宫无线网络日志的自动抓取,避免了要求用户手动启动无线网络日志所带来的各种问题,保证了无线网络异常的时候终端能够及时启动无线网络日志进行异常相关信息的收集,降低了用户负担,增强了用户体验。而且,在本实施例中,日志获取守护进程默认处于关闭状态,在需要对日志获取守护进程的开关状态进行控制的时候,可以通过日志获取守护进程对应的persist属性进行控制,增强了终端中日志获取守护进程进行无线网络日志获取的灵活性,在保证终端顺利获取无线网络异常时的无线网络日志的基础上,也避免了日志获取守护进程在不需要的时候处于工作状态,占用终端处理资源的问题,有利于实现终端处理资源的优化配置。第三实施例本实施例将提供一种计算机可读存储介质和一种终端,首先对该计算机可读存储介质进行介绍:该计算机可读存储介质中存储一个或多个可供存储器读取、编译或执行的计算机程序,其中就包括日志获取程序,该显示控制程序可供处理器执行从而实现第一或第二实施例中提供的日志获取方法。请参见图8提供的终端的硬件结构示意图:终端80包括处理器81、存储器82以及用于连接处理器81与存储器82的通信总线83,其中存储器82可以为前述存储有日志获取程序的计算机可读存储介质。终端80的处理器81可以执行存储器82中存储日志获取程序以实现前述实施例中的日志获取方法:处理器81通过wpa_supplicant进程监测网络异常,在wpa_supplicant进程监测到网络异常后,处理器81通过socket通知日志获取守护进程当前出现网络异常,通过日志获取守护进程获取无线网络日志。在本实施例的一种示例中,处理器81通过socket通知日志获取守护进程当前出现网络异常之前,还会通过persist属性控制被默认处于关闭状态的日志获取守护进程启动。可选的,处理器81可以将init.rc脚本中目标persist属性的值设置为true,目标persist属性为控制日志获取守护进程的persist属性。在本实施例的一种示例中,通过日志获取守护进程获取无线网络日志之后,处理器81还控制日志获取守护进程进行关闭状态。在本实施例中,处理器81通过wpa_supplicant进程监测的无线网络异常至少包括以下两种中的至少一种,一种是无线网络的异常中断,另外一种是无线网络访问的异常中断。处理器81控制日志获取守护进程获取的无线网络日志包括tcpdump日志、wlan固件日志以及wlan驱动日志中的至少一种。日志获取守护进程在获取tcpdump日志,是通过调用tcp命令获取的。在本实施例的一些示例当中,终端80只有处于“日志自动获取模式”的时候,才会自动进行无线网络日志的启动与抓取。也就是说,wpa_supplicant进程在通过socket通知日志获取守护进程当前出现网络异常之前,需要确定终端当前是处于日志自动获取模式下的。如果终端当前并未处于日志自动获取模式,则即便是wpa_supplicant进程监测到了无线网络的异常,其也可以不必通过socket通知日志获取守护进程。本实施例提供的终端,通过wpa_supplicant进程监测网络异常,在wpa_supplicant进程监测到网络异常后,通过套接字socket通知日志获取守护进程当前出现网络异常,然后由日志获取守护进程自动地获取无线网络日志。在网络异常之后,在没有用户手动操作的情况下就能自动开启无线网络日志,记录无线网络异常的相关信息,从而为研发人员定位、解决无线网络异常问题提供依据,让无线网络异常问题能够顺利得到解决,增强了用户的网络体验。更进一步地,终端中日志获取守护进程是默认处于关闭状态下的,只有在wpa_supplicant进程监测到了无线网络的异常,需要日志获取守护进程进行日志获取的时候,才会控制日志获取守护进程从关闭状态进入开启状态,这样,可以保证日志获取守护进程有针对性地进行日志获取,在无线网络正常的情况下,不获取不必要的无线网络日志占用终端的处理资源。需要说明的是,在本文中,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者装置不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者装置所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括该要素的过程、方法、物品或者装置中还存在另外的相同要素。上述本发明实施例序号仅仅为了描述,不代表实施例的优劣。通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到上述实施例方法可借助软件加必需的通用硬件平台的方式来实现,当然也可以通过硬件,但很多情况下前者是更佳的实施方式。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质(如rom/ram、磁碟、光盘)中,包括若干指令用以使得一台终端(可以是手机,计算机,服务器,空调器,或者网络设备等)执行本发明各个实施例所述的方法。上面结合附图对本发明的实施例进行了描述,但是本发明并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本发明的启示下,在不脱离本发明宗旨和权利要求所保护的范围情况下,还可做出很多形式,这些均属于本发明的保护之内。当前第1页12当前第1页12
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1