服务器之家:专注于服务器技术及软件下载分享
分类导航

Linux|Centos|Ubuntu|系统进程|Fedora|注册表|Bios|Solaris|Windows7|Windows10|Windows11|windows server|

服务器之家 - 服务器系统 - Linux - 如何快速分析软件运行瓶颈在哪里?推荐Linux下的一个强大命令工具

如何快速分析软件运行瓶颈在哪里?推荐Linux下的一个强大命令工具

2023-12-21 17:05未知服务器之家 Linux

Linux被广泛用于服务器系统,很多线上服务在上线前要做压力测试,对发现的性能问题要进一步排查和开发优化性能。 比如通过top、iostat等命令找到了引起资源异常的进程后,就要进一步对该进程/线程的内存占用、文件系统IO系统

Linux被广泛用于服务器系统,很多线上服务在上线前要做压力测试,对发现的性能问题要进一步排查和开发优化性能。

比如通过top、iostat等命令找到了引起资源异常的进程后,就要进一步对该进程/线程的内存占用、文件系统IO系统调用次数、Socket和网络通讯阻塞问题等做跟踪分析。由于此时往往更希望接近真实场景的运行方式,所以除了采用代码断点调试的方式外,最保真、最快速跟踪到实际环境问题根源的就是用Linux系统自带的strace软件启动问题软件,获得直接的数据实现,故障分析、性能分析。

如何快速分析软件运行瓶颈在哪里?推荐Linux下的一个强大命令工具

这是一款Linux下瑞士军刀级别的工具,开发者、运维人员如果不熟悉,那么非常有必要继续往下看。学会后可以事半功倍地解决工作中遇到的各类软件开发和软件运维问题。

统计异常系统调用耗时、系统调用次数过多的情况:使用strace跟踪vs code 这个代码编辑器的运行(软件文件路径为 /usr/bin/code )为例:

sudo strace -o strace.log -T -S time -k -O1ns  -C -v  /usr/bin/code --no-sandbox  --user-data-dir /root/data

除了输出启动过程从哪些目录,加载了什么动态库,用到了什么系统调用(系统接口函数),函数调用返回值,入参值等都有打印。由于上面参数中使用了-C也就是要求打印汇总报告,所以在最后会列出vs code启动过程中涉及到多少系统调用、每个系统调用的时间百分比、时间总计、调用次数、错误次数、系统调用的函数名。

如何快速分析软件运行瓶颈在哪里?推荐Linux下的一个强大命令工具

并在最后一行列出汇总值。

假如我们的业务代码中有个功能存在bug,过多调用了系统调用(次数维度),或者传入的参数不科学导致系统调用执行时间过长(时间维度),那么,通过strace 的报告我们可以马上观察到线索。再翻看 strace 的-o strace.log逐个系统调用跟踪的日志记录文件,就可以具体排查以下多方面:

  • 加载的动态库是否正确

如何快速分析软件运行瓶颈在哪里?推荐Linux下的一个强大命令工具

  • 运行时的环境变量是否正确

如何快速分析软件运行瓶颈在哪里?推荐Linux下的一个强大命令工具

  • 调用的系统调用接口是否符合业务代码逻辑顺序
  • 系统调用入参、返回值是否符合预期
  • 系统调用发生的次数是否正常

如何快速分析软件运行瓶颈在哪里?推荐Linux下的一个强大命令工具

  • 每个系统调用的持续时间是否合理
  • 打开的文件是否正常?是否使用了缺失的路径?

如何快速分析软件运行瓶颈在哪里?推荐Linux下的一个强大命令工具

最后总结下:

sudo strace -o strace.log -T -S time -k -O1ns  -C -v  /usr/bin/code --no-sandbox  --user-data-dir /root/data

这个示例命令中参数的意思:

  • -o strace.log将跟踪记录保存到文件 strace.log
  • -T统计时间
  • -S按时间排序
  • -k打印调用栈
  • -O1ns以1纳秒为单位统计时间(实际由于CPU和系统支持程度的差别,可能无法统计到纳秒精度)
  • -v尽量详细输出信息
  • /usr/bin/code --no-sandbox --user-data-dir /root/data为vscode 的root用户模式启动命令+参数

延伸 · 阅读

精彩推荐
  • Linuxssh 登录很慢该如何解决

    ssh 登录很慢该如何解决

    这篇文章主要介绍了ssh 登录很慢该如何解决的相关资料,这里提供了两种方法,DNS反向解析及关闭ssh的gssapi认证的解决办法,需要的朋友可以参考下...

    linuxeye9922021-12-16
  • Linuxlinux设置tomcat自启动的方法

    linux设置tomcat自启动的方法

    这篇文章主要介绍了linux设置tomcat自启动的方法,需要的朋友可以参考下...

    Linux教程网8512021-10-10
  • Linuxlinux驱动程序开发详细介绍

    linux驱动程序开发详细介绍

    前提,一般来说内核代码的错误可能会引起一个用户进程的死亡,或者整个系统的瘫痪,更严重的后果,可能导致磁盘损伤~因此建议最好有一台实验机进行...

    Linux教程网5392019-12-17
  • Linux将 Linux 终端与 Nautilus 文件管理器结合起来

    将 Linux 终端与 Nautilus 文件管理器结合起来

    Nautilus 是 GNOME 桌面环境中的图形化文件浏览器。你可以使用它来访问和管理系统中的文件和文件夹。 尽管并非所有人都喜欢使用终端来管理文件和目录,...

    未知812023-08-08
  • Linux在Linux系统中创建新的亚马逊AWS访问密钥的方法

    在Linux系统中创建新的亚马逊AWS访问密钥的方法

    如何在Linux系统中创建新的亚马逊AWS访问密钥?我在配置一个需要访问我的亚马逊AWS帐号的应用时被要求提供AWS访问密钥ID和秘密访问密钥,我怎样创建一个...

    Linux教程网6182019-10-30
  • LinuxLinux系统下无法卸载挂载的目录怎么办?

    Linux系统下无法卸载挂载的目录怎么办?

    我们在日常运维中经常性会遇到需要进行磁盘的扩容、卸载、挂载等操作,但是有时候这个系统上跑的应用并没有停止或者有其他的运维同事在操作这个目...

    今日头条10302020-12-30
  • Linux理解 Linux/Unix 登录脚本的技巧

    理解 Linux/Unix 登录脚本的技巧

    有一些常见的情况,例如从Debian的包管理程序到Iaas的管理中,很多任务需要设置环境变量才能正常运行。 有时,程序通常只需要在 登陆时运行一次,例如...

    未知1042023-05-12
  • Linuxlinux top命令详解

    linux top命令详解

    这篇文章主要介绍了linux top命令详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    sparkdev5622022-03-01