首页
学习
活动
专区
圈层
工具
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux 命令(137)—— strace 命令

如果希望跟踪多线程进程,因此需要 -f,但不希望跟踪其(可能非常复杂的)子进程,则此选项非常有用 -e EXPR 指定一个表达式,用来控制如何跟踪。格式如下: [qualifier=][!]...strace -o strace.out ./a.out 输入 4 然后回车生成 strace 的输出文件 strace.out,其内容如下: execve("./a.out", ["....这是因为这里的 exit 函数不是系统调用,而是 glibc 库提供的一个函数,exit 函数的调用最终会转化为 exit_group 系统调用,它会退出当前进程的所有线程。...实际上,有一个叫做 _exit() 的系统调用(注意 exit 前面的下划线)线程退出时最终会调用它。 (3)系统调用统计。...具体用法如下: strace -p PID ---- 参考文献 [1] strace(1) manual [2] Linux 命令大全.strace [3] 马昌伟.strace命令详解

8.8K31
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    pstack 与 strace

    strace   strace是可以记录程序系统调用的一个工具,它可以记录该程序系统调用的各个延时情况。 -c 统计每一系统调用的所执行的时间,次数和出错的次数等....-d 输出strace关于标准错误的调试信息. -f 跟踪由fork调用所产生的子进程....-V 输出strace的版本信息. -x 以十六进制形式输出非标准字符串 -xx 所有字符串以十六进制形式输出. -a column 设置返回值的输出位置.默认 为40....-e strace=signal 跟踪所有与系统信号有关的 系统调用 -e trace=ipc 跟踪所有与进程通讯有关的系统调用 -e abbrev=set 设定 strace输出的系统调用的结果集....-u username 以username 的UID和GID执行被跟踪的命令 strace 实用选项 strace -T -r -c -p pid 打印出该pid进程的系统调用耗时 pstack   它是一个打印进程的所有线程栈的一个工具

    1.2K20

    strace命令解析

    strace常用于跟踪和分析进程执行时中系统调用和耗时以及占用cpu的比例,常用的格式如下: 1.sudo /usr/bin/strace -Ttt -p pid 2>pid.log 跟进pid进程,显示每个系统调用耗时...下面列出man手册中strace的详细参数。 调用: strace [ -dffhiqrtttTvxx ] [ -acolumn ] [ -eexpr ] ......strace的每一行输出包括系统调用名称,然后是参数和返回值.这个例子: strace cat /dev/null 他的输出会有: open(/"/dev/null/",O_RDONLY) = 3...-d 输出strace关于标准错误的调试信息. -f 跟踪由fork调用所产生的子进程....-e strace=signal 跟踪所有与系统信号有关的系统调用 -e trace=ipc 跟踪所有与进程通讯有关的系统调用 -e abbrev=set 设定strace输出的系统调用的结果集

    1.5K10

    Strace命令手册

    strace简介 strace常用来跟踪进程执行时的系统调用和所接收的信号。...在Linux世界,进程不能直接访问硬件设备,当进程需要访问硬件设备(比如读取磁盘文件,接收网络数据等等)时,必须由用户态模式切换至内核态模式,通 过系统调用访问硬件设备。...strace可以跟踪到一个进程产生的系统调用,包括参数,返回值,执行消耗的时间。 strace参数 -c 统计每一系统调用的所执行的时间,次数和出错的次数等....-e strace=signal 跟踪所有与系统信号有关的 系统调用 -e trace=ipc 跟踪所有与进程通讯有关的系统调用 -e abbrev=set 设定 strace输出的系统调用的结果集...(strace -a open php) 3、跟踪进程(strace -p 1008) 4、系统调用概要,执行时间,错误等信息(strace -c php) 案例: 1、保存输出结构strace

    1.7K80

    strace(1) command

    如果希望跟踪多线程进程,因此需要 -f,但不希望跟踪其(可能非常复杂的)子进程,则此选项非常有用 -e EXPR 指定一个表达式,用来控制如何跟踪。格式如下: [qualifier=][!]...strace -o strace.out ./a.out 输入 4 然后回车生成 strace 的输出文件 strace.out,其内容如下: execve("./a.out", ["....这是因为这里的 exit 函数不是系统调用,而是 glibc 库提供的一个函数,exit 函数的调用最终会转化为 exit_group 系统调用,它会退出当前进程的所有线程。...实际上,有一个叫做 _exit() 的系统调用(注意 exit 前面的下划线)线程退出时最终会调用它。 (3)系统调用统计。...具体用法如下: strace -p PID ---- 参考文献 strace(1) - Linux manual page - man7.org Linux 命令大全.strace 马昌伟.strace

    25920

    strace详解及实战

    命令,就很牛了,而现在大家基本都知道 strace 了,如果你遇到性能问题求助别人,十有八九会建议你用 strace 挂上去看看,不过当你挂上去了,看着满屏翻滚的字符,却十有八九看不出个所以然。...Linux 操作系统有很多用来跟踪程序行为的工具,内核态的函数调用跟踪用「strace」,用户态的函数调用跟踪用「ltrace」,所以这里我们应该用「strace」: shell> strace -p... 不过如果直接用 strace 跟踪某个进程的话,那么等待你的往往是满屏翻滚的字符,想从这里看出问题的症结并不是一件容易的事情,好在 strace 可以按操作汇总时间: shell> strace...strace 跟踪一个进程,输出结果很少,是不是说明进程很空闲?...我常用的: 用来观察性能、error log: strace -T -vvvv -d -Ff -s 128 -o strace.log -p PID 查找瓶颈调用: strace -v -T -d

    1.8K30

    linux下 debug 工具 strace 应用之【查找命令依赖库文件】

    Strace 是linux系统中一个用来跟踪系统调用的简易工具,它最简单的用途就是跟踪一个程序整个生命周期里所有的系统调用,并把调用参数和返回值以文本的方式输出 当然它还可以做更多的事情: strace...strace 可以记录系统调用的次数,时间,成功和失败的次数。 strace 可以跟踪发给进程的信号。...strace 可以通过pid附加到任何正在运行的进程上 问题背景: centos下执行rpm命令时提示缺失 libplds4.so 的库文件,这导致系统命令执行失败 root@BJ-CentOS7 ~...通过 strace 命令追踪 rpm 命令执行过程,发现这里调用的文件绝对路径是 /lib64/libplds4.so ,原因是 /lib64 目录是 /usr/lib64 软链过来的,find 命令默认不查找软链目录...使用 strace 命令追踪系统命令执行调用的系统文件路径(参数 -e open 用于观察目前进程正引用哪些文件) root@BJ-CentOS7 ~ # strace -e open rpm -qa

    2.3K20

    通过Strace定位故障原因

    闲言碎语不要讲,轮到Strace出场了,统计一下各个系统调用的耗时情况: shell> strace -c -p $(pgrep -n php-cgi) % time seconds usecs...100.00 0.077145 13066 118 total 看上去「brk」非常可疑,它竟然耗费了三成的时间,保险起见,单独确认一下: shell> strace...0x1f98000 brk(0x1fd8000) = 0x1fd8000 brk(0x2018000) = 0x2018000 说明:在Strace...shell> strace -T -p $(pgrep -n php-cgi) 2>&1 | grep -B 10 brk stat("/path/to/script.php", {...}) = 0...直接把它们都禁用了,看看服务器是否能缓过来,或许大家觉得这太鲁蒙了,但是特殊情况必须做出特殊的决定,不能像个娘们儿似的优柔寡断,没过多久,服务器负载恢复正常,接着再统计一下系统调用的耗时: shell> strace

    65420

    【Linux】线程

    线程(Thread) 1. 什么是线程? 线程是进程中的一个执行单元,它是 CPU 调度的基本单位。线程依赖于进程存在,一个进程可以包含多个线程,这些线程可以并发执行,提高程序的运行效率。...进程是承担系统分配系统资源的实体 线程是操作系统调度的基本单位 用一张图简要说明一下什么是线程: 首先我们要知道,在Linux中是没有实际的线程的,线程是被模拟出来的,Linux实际上使用LWP...LWP(Light Weight Process,轻量级进程)是 Linux 线程实现的一种机制,它与传统进程共享大部分资源,但仍有自己的调度信息。...创建线程 pthread_create是用于创建线程的函数,这个函数不是系统调用,因为Linux实际上是没有实体的线程,这个创建线程的函数是在pthread.h中封装的函数。...ps -aL 可以看见确实有两个线程,两个线程的pid是相同的,那哪一个是主线程,哪一个是新线程呢?pid和lwp相同的是主线程,pid和lwp不同的是新线程。

    39300

    【Linux】多线程——线程概念|Linux下进程与线程|线程控制

    所以在Linux中,可以把进程和线程做一个统一,CPU看到的task_struct称为轻量级进程 在Linux中,什么是线程:CPU调度的基本单位!...所以Linux中,没有给Linux"线程"去专门设计对应的数据结构!而是直接复用PCB!用PCB来表示Linux内部的“线程”!...也就是说,Linux内核中有没有真正意义的线程,严格上来说是没有的,Linux是用进程PCB来模拟线程的,是一种完全属于自己的一套线程方案。...3.Linux线程是CPU调度的基本单位,而进程是承担分配系统资源的基本单位 4.进程用来整体申请资源,线程用来伸手向进程要资源 5.Linux中没有真正意义的线程。通过进程模拟。...,在Linux中,如果要实现多线程,必定要使用pthread库,如何看待C++11中的多线程:C++11的多线程,在Linux环境中本质就是对pthread库的封装。

    93330

    Linux多线程【线程池】

    ✨个人主页: 北 海 所属专栏: Linux学习之旅 操作环境: CentOS 7.6 腾讯云远程服务器 前言 线程池是一种管理线程的机制,它可以在需要时自动创建和销毁线程,以及分配和回收线程资源...总之多线程算是正式结束了,下一篇将会打开网络的大门 相关文章推荐 Linux多线程 =====:> 【初始多线程】、【线程控制】、【线程互斥与同步】、【生产者消费者模型】 Linux...进程信号 ===== :> 【信号产生】、【信号保存】、【信号处理】 Linux进程间通信 ===== :> 【消息队列、信号量】、【共享内存】、【命名管道】、【匿名管道】 Linux基础IO...】、【创建、终止、等待】 Linux进程学习 ===== :> 【进程地址】、【环境变量】、【进程状态】、【基本认知】 Linux基础 ===== :> 【gdb】、【git】、【gcc/g++...】、【vim】、Linux 权限理解和学习、听说Linux基础指令很多?

    98640

    【Linux】线程的奥秘:Linux线程入门指南

    那么线程是什么,它和进程又有什么区别呢? 1. 什么是线程 线程(Thread)是操作系统中的一个重要的执行单元,是程序执行的最小调度单元。...线程存在于进程内部,一个进程可以包含一个或者多个线程,线程共享进程的资源并独立运行。 同时我们还要知道进程是承担系统资源分配的基本实体,而线程是CPU运行的基本单位。 2....开销 创建和切换开销较小 创建和切换开销较大 通信 同进程线程通信简单 需要使用 IPC(管道、共享内存等) 崩溃影响 一个线程崩溃会影响进程 一个进程崩溃对其他进程无直接影响 3.1 Linux与...Windows不同的线程设计 在Linux中,由于PCB和TCB的共同点太多了,于是直接复用了PCB的设计和调度策略,这样大大减少了系统的调度时的开销,因此Linux中实际没有真正的线程概念,有的只是复用了...在这种设计思想下,线程注定不会过于庞大,因此Linux中的线程又可以称为轻量级进程LWP,轻量级进程足够简单,且易于维护,效率更高、安全性强,可以使得Linux系统不间断的运行,不容易崩溃。

    34710
    领券