Linux系统中strace操作实例汇总

2016-02-19 10:51 5 1 收藏

下面是个简单易学的Linux系统中strace操作实例汇总教程,图老师小编详细图解介绍包你轻松学会,喜欢的朋友赶紧get起来吧!

【 tulaoshi.com - Linux教程 】

Linux系统中,strace命令可用来追踪调试程序,能够与其他命令搭配使用,下面图老师小编将针对strace命令给大家做个详细介绍,一起来了解下strace命令的操作实例吧。

命令用法

让我们看看strace命令如何追踪一个程序的执行情况。

最简单的形式,strace后面可以跟任何命令。它将列出许许多多的系统调用。一开始,我们并不能理解所有的输出,但是如果你正在寻找一些特殊的东西,那么你应该能从输出中发现它。

让我们来看看简单命令ls的系统调用跟踪情况。

raghu@raghu-Linoxide~ $ strace ls

 Linux系统中strace操作实例汇总

这是strace命令输出的前几行。其他输出被截去了。

 Linux系统中strace操作实例汇总

上面的输出部分展示了write系统调用,它把当前目录的列表输出到标准输出。

下面的图片展示了使用ls命令列出的目录内容(没有使用strace)。

raghu@raghu-Linoxide~ $ ls

 Linux系统中strace操作实例汇总

选项1 寻找被程序读取的配置文件

Strace 的用法之一(除了调试某些问题以外)是你能找到被一个程序读取的配置文件。例如,

raghu@raghu-Linoxide~ $ strace php 2》&1| grep php.ini

 Linux系统中strace操作实例汇总

选项2 跟踪指定的系统调用

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com)

strace命令的-e选项仅仅被用来展示特定的系统调用(例如,open,write等等)

让我们跟踪一下cat命令的‘open’系统调用。

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com)

raghu@raghu-Linoxide~ $ strace -e open cat dead.letter

 Linux系统中strace操作实例汇总

选项3 跟踪进程

strace不但能用在命令上,而且通过使用-p选项能用在运行的进程上。

raghu@raghu-Linoxide~ $ sudo strace -p 1846

 Linux系统中strace操作实例汇总

选项4 strace的统计概要

它包括系统调用的概要,执行时间,错误等等。使用-c选项能够以一种整洁的方式展示:

raghu@raghu-Linoxide~ $ strace -c ls

 Linux系统中strace操作实例汇总

选项5 保存输出结果

通过使用-o选项可以把strace命令的输出结果保存到一个文件中。

raghu@raghu-Linoxide~ $ sudo strace -o process_strace -p 3229

 Linux系统中strace操作实例汇总

之所以以sudo来运行上面的命令,是为了防止用户ID与所查看进程的所有者ID不匹配的情况。

选项6 显示时间戳

使用-t选项,可以在每行的输出之前添加时间戳。

raghu@raghu-Linoxide~ $ strace -t ls

 Linux系统中strace操作实例汇总

选项7 更精细的时间戳

-tt选项可以展示微秒级别的时间戳。

raghu@raghu-Linoxide~ $ strace -tt ls

 Linux系统中strace操作实例汇总

-ttt也可以向上面那样展示微秒级的时间戳,但是它并不是打印当前时间,而是显示自从epoch(译注:1970年1月1日00:00:00 UTC)以来的所经过的秒数。

raghu@raghu-Linoxide~ $ strace -ttt ls

 Linux系统中strace操作实例汇总

选项8 相对时间

-r选项展示系统调用之间的相对时间戳。

raghu@raghu-Linoxide~ $ strace -r ls

 Linux系统中strace操作实例汇总

上面就是Linux中strace的操作实例的介绍了,通过这些实例,我们可以知道strace命令不仅能够跟踪程序,还能够调试程序,是个非常使用的命令。

来源:http://www.tulaoshi.com/n/20160219/1595923.html

延伸阅读
标签: 电脑入门
在Linux系统操作中,GDB是一款程序调试工具,且拥有多种功能,下面图老师小编将针对GDB的功能给大家做个详细介绍,以便你对GDB有个详细的了解。 或许,各位比较喜欢那种图形界面方式的,像VC、BCB等IDE的调试,但如果你是在 UNIX平台下做软件,你会发现GDB这个调试工具有比VC、BCB的图形化调试器更强大的功能。所谓寸有所长,尺有所短就是这个...
标签: 电脑入门
Linux众多操作中,lftp可用于ftp文件的下载上传,登陆ftp等,拥有多种使用方法,下面图老师小编就针对lftp给大家做个详细介绍,感兴趣的朋友不妨来了解下吧。 1、登陆: lftp ftp://yourname@site pwd:***** 或 open ftp://yourname@site 2、基本操作(转) lftp使用介绍 lftp 是一个功能强大的下载工具,它支持访问文件的协议...
Linux系统操作中,Logrotate是一款日志管理工具,可对Linux日志进行处理,在使用前,需要对Logrotate工具进行配置,下面图老师小编就给大家介绍下Linux中Logrotate工具的用法,一起来了解下吧。 1运行原理 Logrotate是基于CRON来运行的,其脚本是/etc/cron.daily/logrotate #!/bin/sh /usr/sbin/logrotate /etc/logrotate.conf EXIT...
标签: 服务器
Linux系统中df命令的一些使用实例整理汇总   df 即可用磁盘disk free,用于显示文件系统的磁盘使用情况。默认情况下 df 命令将以每块 1K 的单位进行显示所有当前已挂载的文件系统,如果你想以人类易读的格式显示 df 命令的输出,像这样df -h使用 -h 选项。 在这篇文章中,我们将讨论 df 命令在 Linux 下11种不同的实例。 ...
标签: 电脑入门
当我们需要查看文件的头部的时候,就要用到head命令,head命令主要用来查看文件前几行或多少字节的内容,下面随图老师小编一起来了解下Linux下head命令的用法吧。 1.命令格式: head [参数]。。. [文件]。。. 2.命令功能: head 用来显示档案的开头至标准输出中,默认head命令打印其相应文件的开头10行。 3.命令参数: -...

经验教程

249

收藏

42
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部