CN112799902A - 日志输出重定向方法、装置及相关设备 - Google Patents
日志输出重定向方法、装置及相关设备 Download PDFInfo
- Publication number
- CN112799902A CN112799902A CN201911111998.1A CN201911111998A CN112799902A CN 112799902 A CN112799902 A CN 112799902A CN 201911111998 A CN201911111998 A CN 201911111998A CN 112799902 A CN112799902 A CN 112799902A
- Authority
- CN
- China
- Prior art keywords
- application program
- target application
- embedded
- program
- equipment
- 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.)
- Pending
Links
- 238000000034 method Methods 0.000 title claims abstract description 76
- 230000008014 freezing Effects 0.000 claims abstract description 46
- 238000007710 freezing Methods 0.000 claims abstract description 31
- 238000004891 communication Methods 0.000 claims abstract description 25
- 238000004590 computer program Methods 0.000 claims description 13
- 238000012544 monitoring process Methods 0.000 claims description 7
- 230000006870 function Effects 0.000 description 40
- 230000000875 corresponding effect Effects 0.000 description 39
- 230000008569 process Effects 0.000 description 16
- 238000010586 diagram Methods 0.000 description 13
- 238000012545 processing Methods 0.000 description 12
- 230000007246 mechanism Effects 0.000 description 3
- 230000009286 beneficial effect Effects 0.000 description 2
- 230000005540 biological transmission Effects 0.000 description 2
- 230000008859 change Effects 0.000 description 2
- 230000006835 compression Effects 0.000 description 2
- 238000007906 compression Methods 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 2
- 241000282326 Felis catus Species 0.000 description 1
- 230000003044 adaptive effect Effects 0.000 description 1
- 230000000712 assembly Effects 0.000 description 1
- 238000000429 assembly Methods 0.000 description 1
- 230000003190 augmentative effect Effects 0.000 description 1
- 238000006243 chemical reaction Methods 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 238000006073 displacement reaction Methods 0.000 description 1
- 230000014509 gene expression Effects 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 238000004519 manufacturing process Methods 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 230000003068 static effect Effects 0.000 description 1
- 238000013024 troubleshooting Methods 0.000 description 1
- XLYOFNOQVPJJNP-UHFFFAOYSA-N water Substances O XLYOFNOQVPJJNP-UHFFFAOYSA-N 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3065—Monitoring arrangements determined by the means or processing involved in reporting the monitored data
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3003—Monitoring arrangements specially adapted to the computing system or computing system component being monitored
- G06F11/302—Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system component is a software system
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/3089—Monitoring arrangements determined by the means or processing involved in sensing the monitored data, e.g. interfaces, connectors, sensors, probes, agents
- G06F11/3093—Configuration details thereof, e.g. installation, enabling, spatial arrangement of the probes
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2201/00—Indexing scheme relating to error detection, to error correction, and to monitoring
- G06F2201/865—Monitoring of software
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- Quality & Reliability (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computing Systems (AREA)
- Mathematical Physics (AREA)
- Debugging And Monitoring (AREA)
Abstract
本申请实施例公开了日志输出重定向方法、装置及相关设备,应用于调试设备,调试设备与待调试的嵌入式设备通信连接,且调试设备具有远程控制嵌入式设备的权限。该方法的一具体实施方式包括:冻结嵌入式设备上运行的目标应用程序;保存目标应用程序的上下文;关闭与目标应用程序有关的文件描述符;将文件描述符对应的文件路径重定向至目标日志输出路径;打开文件描述符;在嵌入式设备上恢复保存的上下文,解除对目标应用程序的冻结。该实施方式实现了不添加额外硬件模块的前提下将应用程序日志发送至远端设备,同时,当进行本地调试时,该实施方式也十分简单方便。
Description
技术领域
本申请实施例涉及计算机技术领域,具体涉及日志输出重定向方法、装置及相关设备。
背景技术
应用程序日志保存着应用程序运行过程中的多种信息,如运行时间、运行结果、错误类型等等。应用程序日志是设备调试和问题排查不可或缺的重要信息。
嵌入式设备由嵌入式处理器、相关支撑硬件和嵌入式软件***组成,现有的嵌入式设备的应用程序日志通过串口路径输出到本地。
如何更好的获得应用程序日志仍是本领域技术人员亟待解决的技术难题。
发明内容
本申请实施例提出了日志输出重定向方法、装置及相关设备。
第一方面,本申请实施例提供了一种日志输出重定向方法,该方法应用于调试设备,调试设备与待调试的嵌入式设备通信连接,且调试设备具有远程控制嵌入式设备的权限,该方法包括:
冻结嵌入式设备上运行的目标应用程序;
保存目标应用程序的上下文;
关闭与目标应用程序有关的文件描述符;
将文件描述符对应的文件路径重定向至目标日志输出路径;
打开文件描述符;
在嵌入式设备上恢复保存的上下文,解除对目标应用程序的冻结。
在一些实施例中,冻结嵌入式设备上运行的目标应用程序,包括:
使用***调用函数Linux ptrace截获***对目标应用程序的Sleep函数的调用以冻结目标应用程序。
在一些实施例中,使用***调用函数Linux ptrace截获***对目标应用程序的Sleep函数的调用以冻结目标应用程序,包括:
使用***调用函数Linux ptrace监测***对目标应用程序的Sleep函数的调用,如果监测到,则截获***传递给目标应用程序的Sleep函数的调用参数以冻结目标应用程序。
在一些实施例中,在冻结嵌入式设备上运行的目标应用程序之前,方法还包括:
获得目标应用程序的标识信息;
冻结嵌入式设备上运行的目标应用程序,包括:根据标识信息,冻结嵌入式设备上运行的目标应用程序。
在一些实施例中,调试设备安装有用于实现远程控制的客户端应用程序,嵌入式设备安装有与客户端应用程序对应的服务端应用程序,客户端应用程序与服务端应用程序通信连接。
第二方面,本申请实施例提供了一种日志输出重定向装置,该装置应用于调试设备,调试设备与待调试的嵌入式设备通信连接,且调试设备具有远程控制嵌入式设备的权限,该装置包括:
程序冻结单元,用于冻结嵌入式设备上运行的目标应用程序;
上下文保存单元,用于保存目标应用程序的上下文;
描述符关闭单元,用于关闭与目标应用程序有关的文件描述符;
路径重定向单元,用于将文件描述符对应的文件路径重定向至目标日志输出路径;
描述符打开单元,用于打开文件描述符;
冻结解除单元,用于在嵌入式设备上恢复保存的上下文,解除对目标应用程序的冻结。
在一些实施例中,程序冻结单元具体用于:
使用***调用函数Linux ptrace截获***对目标应用程序的Sleep函数的调用以冻结目标应用程序。
在一些实施例中,程序冻结单元具体用于:
使用***调用函数Linux ptrace监测***对目标应用程序的Sleep函数的调用,如果监测到,则截获***传递给目标应用程序的Sleep函数的调用参数以冻结目标应用程序。
在一些实施例中,该装置还包括:标识获得单元,用于在程序冻结单元冻结嵌入式设备上运行的目标应用程序之前,获得目标应用程序的标识信息;
程序冻结单元,具体用于:根据标识信息,冻结嵌入式设备上运行的目标应用程序。
在一些实施例中,调试设备安装有用于实现远程控制的客户端应用程序,嵌入式设备安装有与客户端应用程序对应的服务端应用程序,客户端应用程序与服务端应用程序通信连接。
第三方面,本申请实施例提供了一种计算机可读介质,其上存储有计算机程序,其中,该程序被处理器执行时实现如第一方面中任一实现方式描述的方法。
第四方面,本申请实施例提供了一种处理器,该处理器用于运行程序,其中,该程序运行时执行如第一方面中任一实现方式描述的方法。
第五方面,本申请实施例提供了一种调试设备,包括:
一个或多个处理器;
存储装置,其上存储有一个或多个程序;
当上述一个或多个程序被上述一个或多个处理器执行时,使得该一个或多个处理器实现如第一方面中任一实现方式描述的方法。
本申请实施例提供的日志输出重定向方法、装置及相关设备,通过冻结待调试的嵌入式设备上运行的目标应用程序,而后保存目标应用程序的上下文,之后关闭与目标应用程序有关的文件描述符,接着将文件描述符对应的文件路径重定向至目标日志输出路径,然后打开文件描述符,最后在嵌入式设备上恢复保存的上下文,解除对目标应用程序的冻结,可以实现在不添加额外硬件模块的前提下将应用程序日志发送至远端设备,同时,当进行本地调试时,该实施方式也十分简单方便。
附图说明
为了更清楚地说明本申请实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍。显而易见地,下面描述中的附图仅仅是本申请的一些示例或实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据提供的附图获得其他的附图,而且还可以根据提供的附图将本申请应用于其它类似情景。除非从语言环境中显而易见或另做说明,图中相同标号代表相同结构或操作。
图1是本申请的一些实施例可以应用于其中的示例性***架构图;
图2是根据本申请的日志输出重定向方法的一个实施例的流程图;
图3是根据本申请的日志输出重定向方法的又一个实施例的流程图;
图4是根据本申请的日志输出重定向装置的一个实施例的结构示意图;
图5是适于用来实现本申请一些实施例的调试设备的结构示意图。
具体实施方式
下面结合附图和实施例对本申请作进一步的详细说明。可以理解的是,此处所描述的具体实施例仅仅用于解释相关发明,而非对该发明的限定。所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
需要说明的是,为了便于描述,附图中仅示出了与有关发明相关的部分。在不冲突的情况下,本申请中的实施例及实施例中的特征可以相互组合。
应当理解,本申请中使用的“***”、“装置”、“单元”和/或“模块”是用于区分不同级别的不同组件、元件、部件、部分或装配的一种方法。然而,如果其他词语可实现相同的目的,则可通过其他表达来替换该词语。
如本申请和权利要求书中所示,除非上下文明确提示例外情形,“一”、“一个”、“一种”和/或“该”等词并非特指单数,也可包括复数。一般说来,术语“包括”与“包含”仅提示包括已明确标识的步骤和元素,而这些步骤和元素不构成一个排它性的罗列,方法或者设备也可能包含其它的步骤或元素。由语句“包括一个……”限定的要素,并不排除在包括要素的过程、方法、商品或者设备中还存在另外的相同要素。
其中,在本申请实施例的描述中,除非另有说明,“/”表示或的意思,例如,A/B可以表示A或B;本文中的“和/或”仅仅是一种描述关联对象的关联关系,表示可以存在三种关系,例如,A和/或B,可以表示:单独存在A,同时存在A和B,单独存在B这三种情况。另外,在本申请实施例的描述中,“多个”是指两个或多于两个。
以下,术语“第一”、“第二”仅用于描述目的,而不能理解为指示或暗示相对重要性或者隐含指明所指示的技术特征的数量。由此,限定有“第一”、“第二”的特征可以明示或者隐含地包括一个或者更多个该特征。
本申请中使用了流程图用来说明根据本申请的实施例的***所执行的操作。应当理解的是,前面或后面操作不一定按照顺序来精确地执行。相反,可以按照倒序或同时处理各个步骤。同时,也可以将其他操作添加到这些过程中,或从这些过程移除某一步或数步操作。
图1示出了可以应用本申请的日志输出重定向方法或日志输出重定向装置的一些实施例的示例性***架构。
如图1所示,***架构可以包括调试设备001和嵌入式设备002。调试设备001和嵌入式设备002可以通过网络接口003进行通信,嵌入式设备002中包括通用异步收发传输器(UART,Universal Asynchronous Receiver/Transmitter)004。当调试设备001为远端设备时,调试设备001可以通过互联网与嵌入式设备002的网络接口003进行通信。
用户可以使用调试设备001通过网络与嵌入式设备002交互,以接收日志或发送命令等。调试设备001安装有用于实现远程控制的客户端应用程序,嵌入式设备002安装有与客户端应用程序对应的服务端应用程序,客户端应用程序与服务端应用程序通信连接。
调试设备001和嵌入式设备002可以是硬件,也可以是软件。当调试设备001和嵌入式设备002为硬件时,可以是各种电子设备,包括但不限于智能手机、平板电脑、可穿戴设备、车载设备、增强现实(augmented reality,AR)/虚拟现实(virtual reality,VR)设备、超级移动个人计算机(ultra-mobile personal computer,UMPC)、上网本、个人数字助理(personal digital assistant,PDA)、电子书阅读器、MP3(Moving Picture ExpertsGroup Audio Layer III,动态影像专家压缩标准音频层面3)播放器、MP4(Moving PictureExperts Group Audio Layer IV,动态影像专家压缩标准音频层面4)播放器、膝上型便携计算机、台式计算机、智能电表、智能水表、智能猫眼、网关等电子设备。当调试设备001和嵌入式设备002为软件时,可以安装在上述所列举的电子设备中。其可以实现成多个软件或软件模块(例如用来提供分布式服务),也可以实现成单个软件或软件模块。本申请实施例对电子设备的具体类型不作任何限制。
需要说明的是,本申请实施例所提供的日志输出重定向方法一般由调试设备001执行,相应地,日志输出重定向装置一般设置于调试设备001中。
应该理解,图1中的调试设备001和嵌入式设备002的数目仅仅是示意性的。根据实现需要,可以具有任意数目的调试设备和嵌入式设备。
如图2所示,其示出了根据本申请的日志输出重定向方法的一个实施例的流程,该方法应用于调试设备(例如图1所示的调试设备001),调试设备与待调试的嵌入式设备(例如图1所示的嵌入式设备002)通信连接,且调试设备具有远程控制嵌入式设备的权限。该方法可以包括:
S100、冻结嵌入式设备上运行的目标应用程序;
在一可选实施方式中,调试设备可以通过网络接口(如以太网接口)与待调试的嵌入式设备通信连接,该调试设备可以为本地调试设备,也可以为远程调试设备。嵌入式设备可以具有网络接口。可选的,嵌入式设备可以包括:UART。UART的具体实物表现为独立的模块化芯片,或作为集成于微处理器中的周边设备。UART一般是RS-232C规格的,与类似Maxim的MAX232之类的标准信号幅度变换芯片进行搭配,作为连接外部设备的接口。
其中,调试设备可以控制嵌入式设备以完成图2所示方法,具体的控制方式有多种,如调试设备通过向嵌入式设备发布命令来控制嵌入式设备根据命令执行相应的动作(如冻结应用程序、保存上下文、关闭文件描述符、对文件路径重定向、打开文件描述符、恢复上下文、解除应用程序的冻结等)。再如:嵌入式设备中保存有用于执行某些动作的程序代码或嵌入式设备中安装有用于执行某些动作的应用程序,该程序代码或应用程序可以被调试设备控制而开始执行相应的动作(如冻结应用程序、保存上下文、关闭文件描述符、对文件路径重定向、打开文件描述符、恢复上下文、解除应用程序的冻结等)。
在一可选实施方式中,调试设备安装有用于实现远程控制的客户端应用程序,嵌入式设备安装有与客户端应用程序对应的服务端应用程序,客户端应用程序与服务端应用程序通信连接。
其中,该客户端应用程序可以为Telnet客户端应用程序或SSH(Secure Shell,安全外壳协议)客户端应用程序等。其中,Telnet是Internet远程登录服务的标准协议和主要方式,它为用户提供了在本地计算机上完成远程主机工作的能力。SSH是专为远程登录会话和其他网络服务提供安全性的协议。可选的,目标应用程序与上述客户端应用程序不同,目标应用程序与上述服务端应用程序不同。
在一可选实施方式中,步骤S100可以具体包括:
使用***调用函数Linux ptrace截获***对目标应用程序的Sleep函数的调用以冻结目标应用程序。
其中,目标应用程序在嵌入式设备上运行。
其中,Linux ptrace提供了一种使父进程得以监视和控制其它进程的方式,它还能够改变子进程中的寄存器和内核映像,因而可以实现断点调试和***调用的跟踪。
在一可选实施方式中,嵌入式设备可以为Linux嵌入式设备。
Sleep函数可以使应用程序(进程,任务或线程)进入休眠,使其在一段时间内处于非活动状态。Sleep函数在各应用程序中普遍存在,因此本申请可以通过截获***对目标应用程序的该函数的调用来冻结目标应用程序。当然,在其他实施例中,本申请也可以通过截获***对目标应用程序的其他函数的调用来冻结目标应用程序,本申请对此不做限定。
进一步,上述的使用***调用函数Linux ptrace截获***对目标应用程序的Sleep函数的调用以冻结目标应用程序,可以包括:
使用***调用函数Linux ptrace监测***对目标应用程序的Sleep函数的调用,如果监测到,则截获***传递给目标应用程序的Sleep函数的调用参数以冻结目标应用程序。
由于无法获悉***什么时候会对目标应用程序的Sleep函数进行调用,因此本申请可以首先进行监测,如果监测到,再进行截获。
S200、保存目标应用程序的上下文;
可以理解的是,应用程序的上下文为应用程序的环境信息(如应用程序状态和变量状态),该上下文保存着CPU(Central Processing Unit,中央处理器)寄存器的值,这些值包括:应用程序的执行地址、函数流程返回值等。在将目标应用程序的上下文保存后,本申请可以根据该上下文恢复目标应用程序。
可选的,该上下文可以保存在嵌入式设备中,也可以保存在调试设备中。
S300、关闭与目标应用程序有关的文件描述符。
其中,内核(kernel)可以利用文件描述符(file descriptor)来访问文件。文件描述符是非负整数,当打开现存文件或新建文件时,内核会返回一个文件描述符。这里,与目标应用程序有关的文件描述符可以为标准文件描述符,标准文件描述符可以包括:0、1、2等。0为标准输入描述符(stdin),1为标准输出描述符(stdout),2为标准错误输出描述符(stderr)。其中,不同的标准文件描述符可以对应不同类型的路径。例如:在Linux***中,0对应的路径为标准输入路径,1对应的路径为标准输出路径,2对应的路径为标准错误输出路径。
可选的,不同应用程序可以使用相同或不同的文件描述符,例如:***为每个应用程序维护一个文件描述符组,或***为每个进程(一般情况下一个应用程序对应一个进程)维护一个文件描述符组。上述文件描述符组中可以包括:标准输入描述符、标准输出描述符和标准错误输出描述符中的至少一个。具体的,不同的应用程序或进程对应的文件描述符组中的相同类型描述符对应的路径可以不同。例如:第一应用程序对应的文件描述符组中标准输出描述符对应的路径为路径1,第二应用程序对应的文件描述符组中标准输出描述符对应的路径为路径2,路径1和路径2不同。
在其他实施例中,***也可以为其管理的各应用程序/进程设置相同的文件描述符组,这样,不同的应用程序或进程对应的文件描述符组中的相同类型描述符对应的路径相同。例如:第一应用程序对应的文件描述符组中标准输出描述符对应的路径为路径1,第二应用程序对应的文件描述符组中标准输出描述符对应的路径也为路径1。
可选的,本申请可以关闭与目标应用程序有关的且属于预设类型(如标准输入、标准输出、标准错误输出中的至少一个)的文件描述符。例如:在一可选实施方式中,步骤S300可以仅关闭文件描述符1,即标准输出描述符。这样,标准输出描述符对应的标准输出路径即被关闭。在另一可选实施方式中,步骤S300可以关闭文件描述符1以及关闭文件描述符2。在另一可选实施方式中,步骤S300可以关闭文件描述符0、1和2。
S400、将文件描述符对应的文件路径重定向至目标日志输出路径;
在步骤S300关闭文件描述符后,本申请可以对关闭的文件描述符对应的文件路径进行修改以进行文件路径重定向。
其中,目标日志输出路径可以为需要获得嵌入式设备中的日志的电子设备的网络路径。可选的,该电子设备可以为本地设备,也可以为远端设备。在一可选实施方式中,目标日志输出路径为调试设备的网络路径,即该电子设备为调试设备。
具体的,日志是***模拟出的一个虚拟文件,虽然日志为虚拟文件,但其仍具有路径。因此本申请将文件描述符对应的文件路径重定向至目标日志输出路径后,就可以将日志输出到上述电子设备中。
其中,目标日志输出路径可以为Telnet登陆路径或SSH登陆路径。
其中,本申请的Telnet登陆路径为网络服务程序Telnet的登陆路径。
S500、打开文件描述符;
可以理解的是,在打开之前关闭的文件描述符后,路径才能重新被使用,步骤S400重定向的文件路径才能生效。
S600、在嵌入式设备上恢复保存的上下文,解除对目标应用程序的冻结。
由于本申请已经将文件描述符对应的文件路径重定向至目标日志输出路径,因此应用程序的日志在应用程序恢复执行后会通过目标日志输出路径发送至电子设备。
当需要对嵌入式设备进行本地调试时,本申请的调试设备可以位于嵌入式设备本地。在调试设备通过网络接口与嵌入式设备通信连接后,调试设备就可以进行上述步骤S100至步骤S600的处理。当目标日志输出路径为调试设备的网络路径时,嵌入式设备中的日志就会通过网络接口输出到调试设备中。这种情况下,本申请就无需通过UART查看日志,也就避免了通过UART查看日志时带来的需要拆开设备连接物理线缆的问题。可见,本申请的方案应用在进行本地调试的过程中时,无需拆开设备连接物理线缆,方便快捷。
当需要对嵌入式设备进行远程调试时,本申请的调试设备可以位于嵌入式设备的远端。在调试设备通过网络接口与嵌入式设备通信连接后,调试设备就可以进行上述步骤S100至步骤S600的处理。当目标日志输出路径为调试设备的网络路径时,嵌入式设备中的日志就会通过网络接口输出到调试设备中。这种情况下,本申请可以实现将日志通过互联网发送至远端的调试设备,无需在嵌入式设备本地再增加一个硬件模块。本申请解决嵌入式设备在远程调试时必须部署额外的硬件模块,才能将日志转发至远端的调试设备的问题。
同时,本申请通过在嵌入式设备中部署用于设备调试的软件的方式实现了本地及远程调试,无需额外的硬件模块,节约了成本和时间,而且对正在运行的应用程序无任何负面干扰。
再者,由于本申请并未采用UART进行日志传输,因此当UART无法传输日志时,本申请可以在不影响应用程序运行的情况下,重新恢复应用程序的日志的输出,即:通过网络接口输出日志。
在一可选具体实施方式中,本申请可以基于MIPS CPU进行。其中,MIPS是世界上很流行的一种RISC(Reduced Instruction Set Computing,精简指令集计算机)处理器。如果在其他CPU平台,如:ARM、x86等,则仅仅需要将程序上下文保存及恢复部分做适配即可,十分方便。
如图3所示,其示出了根据本申请的日志输出重定向方法的另一个实施例的流程,该方法应用于调试设备(例如图1所示的调试设备001),调试设备与待调试的嵌入式设备(例如图1所示的嵌入式设备002)通信连接,且调试设备具有远程控制嵌入式设备的权限。该方法可以包括:
S001、获得目标应用程序的标识信息;
其中,目标应用程序的标识可以为目标应用程序的ID(Identity Document)。这里,ID的中文名称可以为身份标识号。需要说明的是,该标识信息可以是调试设备从其它设备、模块或装置等接收的,本实施例不对该标识信息的来源做任何限定。
S101、根据上述标识信息,冻结嵌入式设备上运行的目标应用程序。
其中,步骤S101为图2所示方法中步骤S100的一种具体执行方式。
S200、保存目标应用程序的上下文;
S300、关闭与目标应用程序有关的文件描述符;
S400、将文件描述符对应的文件路径重定向至目标日志输出路径;
S500、打开文件描述符;
S600、在嵌入式设备上恢复保存的上下文,解除对目标应用程序的冻结。
步骤S200至步骤S600已在图2所示方法中说明,不再赘述。
本实施例提供的日志输出重定向方法,通过先获取标识信息,而后针对该标识信息所指示的应用程序执行步骤S101-S600,可以实现对特定的应用程序执行日志输出重定向操作。
与图2所示方法相对应,本申请实施例还提供了一种日志输出重定向装置。
如图4所示,其示出了本申请实施例提供的一种日志输出重定向装置,该装置应用于调试设备,调试设备与待调试的嵌入式设备通信连接,且调试设备具有远程控制嵌入式设备的权限,该装置可以包括:
程序冻结单元100,用于冻结嵌入式设备上运行的目标应用程序;
上下文保存单元200,用于保存目标应用程序的上下文;
描述符关闭单元300,用于关闭与目标应用程序有关的文件描述符;
路径重定向单元400,用于将文件描述符对应的文件路径重定向至目标日志输出路径;
描述符打开单元500,用于打开文件描述符;
冻结解除单元600,用于在嵌入式设备上恢复保存的上下文,解除对目标应用程序的冻结。
在一可选实施方式中,程序冻结单元100具体用于:
使用***调用函数Linux ptrace截获***对目标应用程序的Sleep函数的调用以冻结目标应用程序。
其中,目标应用程序在嵌入式设备上运行。
在一可选实施方式中,程序冻结单元100具体用于:
使用***调用函数Linux ptrace监测***对目标应用程序的Sleep函数的调用,如果监测到,则截获***传递给目标应用程序的Sleep函数的调用参数以冻结目标应用程序。
在一可选实施方式中,图4所示装置还包括:标识获得单元,用于在程序冻结单元100冻结嵌入式设备上运行的目标应用程序之前,获得目标应用程序的标识信息;
程序冻结单元100,具体用于:根据上述标识信息,冻结嵌入式设备上运行的目标应用程序。
在一可选实施方式中,调试设备安装有用于实现远程控制的客户端应用程序,嵌入式设备安装有与客户端应用程序对应的服务端应用程序,客户端应用程序与服务端应用程序通信连接。
当需要对嵌入式设备进行本地调试时,本申请的调试设备可以位于嵌入式设备本地。在调试设备通过网络接口与嵌入式设备通信连接后,调试设备就可以进行上述处理。当目标输出路径为调试设备的网络路径时,嵌入式设备中的日志就会通过网络接口输出到调试设备中。这种情况下,本申请就无需通过UART查看日志,也就避免了通过UART查看日志时带来的需要拆开设备连接物理线缆的问题。可见,本申请的方案应用在进行本地调试的过程中时,无需拆开设备连接物理线缆,方便快捷。
当需要对嵌入式设备进行远程调试时,本申请的调试设备可以位于嵌入式设备的远端。在调试设备通过网络接口与嵌入式设备通信连接后,调试设备就可以进行上述处理。当目标输出路径为调试设备的网络路径时,嵌入式设备中的日志就会通过网络接口输出到调试设备中。这种情况下,本申请可以实现将日志通过互联网发送至远端的调试设备,无需在嵌入式设备本地再增加一个硬件模块。本申请解决嵌入式设备在远程调试时必须部署额外的硬件模块,才能将日志转发至远端的调试设备的问题。
在本实施例中,程序冻结单元100、上下文保存单元200、描述符关闭单元300、路径重定向单元400、描述符打开单元500和冻结解除单元600的具体处理及其带来的技术效果可分别参考图2对应实施例中步骤S100至步骤S600的实施例的相关说明,在此不再赘述。
需要说明的是,日志输出重定向装置可以是芯片,组件或模块,日志输出重定向装置包括处理器和存储器,程序冻结单元100、上下文保存单元200、描述符关闭单元300、路径重定向单元400、描述符打开单元500和冻结解除单元600等均作为程序单元存储在存储器中,由处理器执行存储在存储器中的上述程序单元来实现相应的功能。
处理器中可以包含内核,由内核去存储器中调取相应的程序单元。内核可以设置一个或多个,通过调整内核参数来进行日志输出重定向。
存储器可能包括计算机可读介质中的非永久性存储器,随机存取存储器(RAM)和/或非易失性内存等形式,如只读存储器(ROM)或闪存(flash RAM),存储器包括至少一个存储芯片。
如图5所示,调试设备001可以包括处理器701、存储器702、通信接口703、输入单元704、输出单元705和通信总线706。其中,处理器701和存储器702通过通信总线706彼此相连。通信接口703、输入单元704和输出单元705也连接至通信总线706。
其中,通信接口703可以为通信模块的接口,如GSM模块的接口。通信接口703可以用于获得嵌入式设备发送的日志,通信接口703还用于将命令发送至嵌入式设备。
在本申请实施例中,处理器701,可以为中央处理器、特定应用集成电路(application-specific integrated circuit,ASIC)、数字信号处理器(DSP)、专用集成电路(ASIC)、现成可编程门阵列(FPGA)或者其他可编程逻辑器件等。
在一种可能的实现方式中,存储器702可包括存储程序区和存储数据区,其中,存储程序区可存储操作***、以及至少一个功能(比如应用程序冻结功能、输出路径重定向功能等)所需的应用程序等;存储数据区可存储根据计算机的使用过程中所创建的数据,比如,日志、应用程序的标识信息等等。
此外,存储器702可以包括高速随机存取存储器,还可以包括非易失性存储器,例如至少一个磁盘存储器件或其他易失性固态存储器件。
处理器701可以调用存储器702中存储的程序,具体的,处理器701可以执行以图1至2中任一实施例所示的日志输出重定向方法。
存储器702中用于存放一个或者一个以上程序,程序可以包括程序代码,程序代码包括计算机操作指令,在本申请实施例中,存储器702中至少存储有用于实现以下功能的程序:
冻结嵌入式设备上运行的目标应用程序;
保存目标应用程序的上下文;
关闭与目标应用程序有关的文件描述符;
将文件描述符对应的文件路径重定向至目标日志输出路径;
打开文件描述符;
在嵌入式设备上恢复保存的上下文,解除对目标应用程序的冻结。
本申请还可以包括输入单元704,输入单元704可以包括感应触摸显示面板上的触摸事件的触摸感应单元、键盘、鼠标、摄像头、拾音器等设备中的至少一个。
输出单元705可以包括:显示器、扬声器、振动机构、灯等设备中的至少一个。显示器可以包括显示面板,如触摸显示面板等。在一种可能的情况中,可以采用液晶显示器(Liquid Crystal Display,LCD)、有机发光二极管(Organic Light-Emitting Diode,OLED)等形式来配置显示面板。振动机构在工作时可以使调试设备001发生位移,在一种可能的实现方式中,振动机构包括电动机和偏心振子,电动机带动偏心振子转动从而产生振动。灯的亮度和/或颜色可调,在一种可能的实现方式中,可通过灯的亮灭、亮度、颜色中的至少一个体现不同的信息,如通过灯发出红色光体现报警信息。
当然,图5所示的调试设备001的结构并不构成对本申请实施例中调试设备的限定,在实际应用中调试设备可以包括比图5所示的更多或更少的部件,或者组合某些部件。
本申请实施例提供了一种计算机可读介质,其上存储有计算机程序,其中,该程序被处理器执行时实现以上各方法实施例描述的日志输出重定向方法。
本申请实施例提供了一种处理器,该处理器用于运行程序,其中,该程序运行时实现以上各方法实施例描述的日志输出重定向方法。
本申请还提供了一种计算机程序产品,当在数据处理设备上执行时,使得数据处理设备实现以上各方法实施例描述的日志输出重定向方法。
其中,本申请的上述实施例提供的调试设备、处理器、计算机可读介质或计算机程序产品可以均用于执行上文所提供的对应的方法,因此,其所能达到的有益效果可参考上文所提供的对应的方法中的有益效果,此处不再赘述。
本申请是参照根据本申请实施例的方法、设备(***)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
在一个典型的配置中,计算设备包括一个或多个处理器(CPU)、输入/输出接口、网络接口和内存。
存储器可能包括计算机可读介质中的非永久性存储器,随机存取存储器(RAM)和/或非易失性内存等形式,如只读存储器(ROM)或闪存(flash RAM)。存储器是计算机可读介质的示例。
计算机可读介质包括永久性和非永久性、可移动和非可移动媒体,可以由任何方法或技术来实现信息存储。信息可以是计算机可读指令、数据结构、程序的模块或其他数据。计算机的存储介质的例子包括,但不限于相变内存(PRAM)、静态随机存取存储器(SRAM)、动态随机存取存储器(DRAM)、其他类型的随机存取存储器(RAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、快闪记忆体或其他内存技术、只读光盘只读存储器(CD-ROM)、数字多功能光盘(DVD)或其他光学存储、磁盒式磁带,磁带磁磁盘存储或其他磁性存储设备或任何其他非传输介质,可用于存储可以被计算设备访问的信息。按照本文中的界定,计算机可读介质不包括暂存电脑可读媒体(transitory media),如调制的数据信号和载波。
本领域技术人员应明白,本申请的实施例可提供为方法、***或计算机程序产品。因此,本申请可采用完全硬件实施例、完全软件实施例或结合软件和硬件方面的实施例的形式。而且,本申请可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
以上描述仅为本申请的较佳实施例以及对所运用技术原理的说明而已,并不用于限制本申请。对于本领域技术人员来说,本申请可以有各种更改和变化。本申请中所涉及的发明范围,并不限于上述技术特征的特定组合而成的技术方案,同时也应涵盖在不脱离上述发明构思的情况下,由上述技术特征或其等同特征进行任意组合而形成的其它技术方案。例如上述特征与本申请中公开的(但不限于)具有类似功能的技术特征进行互相替换而形成的技术方案。
Claims (10)
1.一种日志输出重定向方法,其特征在于,所述方法应用于调试设备,所述调试设备与待调试的嵌入式设备通信连接,且所述调试设备具有远程控制所述嵌入式设备的权限,所述方法包括:
冻结所述嵌入式设备上运行的目标应用程序;
保存所述目标应用程序的上下文;
关闭与所述目标应用程序有关的文件描述符;
将所述文件描述符对应的文件路径重定向至目标日志输出路径;
打开所述文件描述符;
在所述嵌入式设备上恢复保存的所述上下文,解除对所述目标应用程序的冻结。
2.根据权利要求1所述的方法,其特征在于,所述冻结所述嵌入式设备上运行的目标应用程序,包括:
使用***调用函数Linux ptrace截获***对所述目标应用程序的Sleep函数的调用以冻结所述目标应用程序。
3.根据权利要求2所述的方法,其特征在于,所述使用***调用函数Linux ptrace截获***对所述目标应用程序的Sleep函数的调用以冻结所述目标应用程序,包括:
使用***调用函数Linux ptrace监测***对所述目标应用程序的Sleep函数的调用,如果监测到,则截获***传递给所述目标应用程序的Sleep函数的调用参数以冻结所述目标应用程序。
4.根据权利要求1至3中任一项所述的方法,其特征在于,在所述冻结所述嵌入式设备上运行的目标应用程序之前,所述方法还包括:
获得所述目标应用程序的标识信息;
所述冻结所述嵌入式设备上运行的目标应用程序,包括:根据所述标识信息,冻结所述嵌入式设备上运行的所述目标应用程序。
5.根据权利要求1至3中任一项所述的方法,其特征在于,所述调试设备安装有用于实现远程控制的客户端应用程序,所述嵌入式设备安装有与所述客户端应用程序对应的服务端应用程序,所述客户端应用程序与所述服务端应用程序通信连接。
6.一种日志输出重定向装置,其特征在于,所述装置应用于调试设备,所述调试设备与待调试的嵌入式设备通信连接,且所述调试设备具有远程控制所述嵌入式设备的权限,所述装置包括:
程序冻结单元,用于冻结所述嵌入式设备上运行的目标应用程序;
上下文保存单元,用于保存所述目标应用程序的上下文;
描述符关闭单元,用于关闭与所述目标应用程序有关的文件描述符;
路径重定向单元,用于将所述文件描述符对应的文件路径重定向至目标日志输出路径;
描述符打开单元,用于打开所述文件描述符;
冻结解除单元,用于在所述嵌入式设备上恢复保存的所述上下文,解除对所述目标应用程序的冻结。
7.根据权利要求6所述的装置,其特征在于,所述程序冻结单元具体用于:
使用***调用函数Linux ptrace截获***对所述目标应用程序的Sleep函数的调用以冻结所述目标应用程序。
8.一种计算机可读介质,其上存储有计算机程序,其中,所述程序被处理器执行时实现如权利要求1至5任一项所述的日志输出重定向方法。
9.一种处理器,所述处理器用于运行程序,其中,所述程序运行时实现如权利要求1至5任一项所述的日志输出重定向方法。
10.一种调试设备,包括:
一个或多个处理器;
存储装置,其上存储有一个或多个程序;
当所述一个或多个程序被所述一个或多个处理器执行时,使得所述一个或多个处理器实现如权利要求1至5任一项所述的日志输出重定向方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201911111998.1A CN112799902A (zh) | 2019-11-14 | 2019-11-14 | 日志输出重定向方法、装置及相关设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201911111998.1A CN112799902A (zh) | 2019-11-14 | 2019-11-14 | 日志输出重定向方法、装置及相关设备 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN112799902A true CN112799902A (zh) | 2021-05-14 |
Family
ID=75803610
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201911111998.1A Pending CN112799902A (zh) | 2019-11-14 | 2019-11-14 | 日志输出重定向方法、装置及相关设备 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN112799902A (zh) |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102473089A (zh) * | 2009-08-27 | 2012-05-23 | 惠普发展公司有限责任合伙企业 | 用于双操作***的文件*** |
US20130081017A1 (en) * | 2011-09-26 | 2013-03-28 | International Business Machines Corporation | Dynamically redirecting a file descriptor |
CN105573910A (zh) * | 2015-12-11 | 2016-05-11 | 北京元心科技有限公司 | 受保护***的应用程序调试方法及智能终端 |
CN109491759A (zh) * | 2018-10-26 | 2019-03-19 | 深圳康佳电子科技有限公司 | 基于虚拟文件***的进程调试方法、装置和计算机设备 |
CN109660399A (zh) * | 2018-12-24 | 2019-04-19 | 苏州思必驰信息科技有限公司 | 一种远程调试的方法及*** |
-
2019
- 2019-11-14 CN CN201911111998.1A patent/CN112799902A/zh active Pending
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102473089A (zh) * | 2009-08-27 | 2012-05-23 | 惠普发展公司有限责任合伙企业 | 用于双操作***的文件*** |
US20130081017A1 (en) * | 2011-09-26 | 2013-03-28 | International Business Machines Corporation | Dynamically redirecting a file descriptor |
CN105573910A (zh) * | 2015-12-11 | 2016-05-11 | 北京元心科技有限公司 | 受保护***的应用程序调试方法及智能终端 |
CN109491759A (zh) * | 2018-10-26 | 2019-03-19 | 深圳康佳电子科技有限公司 | 基于虚拟文件***的进程调试方法、装置和计算机设备 |
CN109660399A (zh) * | 2018-12-24 | 2019-04-19 | 苏州思必驰信息科技有限公司 | 一种远程调试的方法及*** |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US9129108B2 (en) | Systems, methods and computer programs providing impact mitigation of cyber-security failures | |
US10776144B2 (en) | Address space management with respect to a coherent accelerator processor interface architecture | |
US11055192B2 (en) | Logging implementation in micro-service applications | |
CN105573955A (zh) | 多协议***管理方法与***以及计算机可读媒体 | |
CN103530167A (zh) | 一种虚拟机内存数据的迁移方法及相关装置和集群*** | |
US20180239611A1 (en) | Running a kernel-dependent application in a container | |
US8938712B2 (en) | Cross-platform virtual machine and method | |
US20230021216A1 (en) | Systems and methods for deploying secure edge platforms | |
US20170131923A1 (en) | Checkpoint mechanism in a compute embedded object storage infrastructure | |
US10169193B2 (en) | Common debug scripting framework for driving hybrid applications consisting of compiled languages and interpreted languages | |
US20180150365A1 (en) | Disaster Recover of Managed Systems | |
US10467078B2 (en) | Crash dump extraction of guest failure | |
US9755922B2 (en) | Minimized installation of point of presence software agents by use of pre-installed browser | |
Kewate et al. | A review on AWS-cloud computing technology | |
US10091294B2 (en) | Networking component management in host computing systems in a virtual computing environment | |
CN108920379A (zh) | 捕获lua代码异常的方法和装置 | |
US20180268290A1 (en) | Model training by discarding relatively less relevant parameters | |
US20140089946A1 (en) | Application management of a processor performance monitor | |
US11656888B2 (en) | Performing an application snapshot using process virtual machine resources | |
CN112799902A (zh) | 日志输出重定向方法、装置及相关设备 | |
US9384120B2 (en) | Testing of transaction tracking software | |
CN110673898A (zh) | 一种设备管理方法、第一设备及交互*** | |
US11487776B2 (en) | Managing extract-transform-load operations | |
JP7465045B2 (ja) | 異常イベントに対する仮想マシンの処理能力の増加 | |
US11237825B2 (en) | Refining a software system using live documentation mapping |
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 |