当前位置:首页 > 科技  > 软件

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

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

Linux被广泛用于服务器系统,很多线上服务在上线前要做压力测试,对发现的性能问题要进一步排查和开发优化性能。xuI28资讯网——每日最新资讯28at.com

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

xuI28资讯网——每日最新资讯28at.com

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

统计异常系统调用耗时、系统调用次数过多的情况:使用strace跟踪vs code 这个代码编辑器的运行(软件文件路径为 /usr/bin/code )为例:xuI28资讯网——每日最新资讯28at.com

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启动过程中涉及到多少系统调用、每个系统调用的时间百分比、时间总计、调用次数、错误次数、系统调用的函数名。xuI28资讯网——每日最新资讯28at.com

xuI28资讯网——每日最新资讯28at.com

并在最后一行列出汇总值。xuI28资讯网——每日最新资讯28at.com

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

  • 加载的动态库是否正确

xuI28资讯网——每日最新资讯28at.com

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

xuI28资讯网——每日最新资讯28at.com

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

xuI28资讯网——每日最新资讯28at.com

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

xuI28资讯网——每日最新资讯28at.com

最后总结下:xuI28资讯网——每日最新资讯28at.com

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

这个示例命令中参数的意思:xuI28资讯网——每日最新资讯28at.com

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

本文链接:http://www.28at.com/showinfo-26-51230-0.html如何快速分析软件运行瓶颈在哪里?推荐Linux下的一个强大命令工具

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 老后端被借调去写Java了,含泪总结的Java多线程编程基础

下一篇: C语言中的柔性数组解析

标签:
  • 热门焦点
  • K60至尊版刚预热 一加Ace2 Pro正面硬刚

    Redmi这边刚如火如荼的宣传了K60 Ultra的各种技术和硬件配置,作为竞品的一加也坐不住了。一加中国区总裁李杰发布了两条微博,表示在自家的一加Ace2上早就已经采用了和PixelWo
  • 线程通讯的三种方法!通俗易懂

    线程通信是指多个线程之间通过某种机制进行协调和交互,例如,线程等待和通知机制就是线程通讯的主要手段之一。 在 Java 中,线程等待和通知的实现手段有以下几种方式:Object 类下
  • 一文掌握 Golang 模糊测试(Fuzz Testing)

    模糊测试(Fuzz Testing)模糊测试(Fuzz Testing)是通过向目标系统提供非预期的输入并监视异常结果来发现软件漏洞的方法。可以用来发现应用程序、操作系统和网络协议等中的漏洞或
  • 从零到英雄:高并发与性能优化的神奇之旅

    作者 | 波哥审校 | 重楼作为公司的架构师或者程序员,你是否曾经为公司的系统在面对高并发和性能瓶颈时感到手足无措或者焦头烂额呢?笔者在出道那会为此是吃尽了苦头的,不过也得
  • 猿辅导与新东方的两种“归途”

    作者|卓心月 出品|零态LT(ID:LingTai_LT)如何成为一家伟大企业?答案一定是对“势”的把握,这其中最关键的当属对企业战略的制定,且能够站在未来看现在,即使这其中的
  • 阿里大调整

    来源:产品刘有媒体报道称,近期淘宝天猫集团启动了近年来最大的人力制度改革,涉及员工绩效、层级体系等多个核心事项,目前已形成一个初步的“征求意见版”:1、取消P序列
  • 小米公益基金会捐赠2500万元驰援北京、河北暴雨救灾

    8月2日消息,今日小米科技创始人雷军在其微博上发布消息称,小米公益基金会宣布捐赠2500万元驰援北京、河北暴雨救灾。携手抗灾,京冀安康!以下为公告原文
  • 2299元起!iQOO Pad明晚首销:性能最强天玑平板

    5月23日,iQOO如期举行了新品发布会,除了首发安卓最强旗舰处理器的iQOO Neo8系列新机外,还在发布会上推出了旗下首款平板电脑——iQOO Pad,其最大的卖点
  • 三翼鸟智能家居亮相电博会,让用户体验更真实

    2021电博会在青岛国际会展中心开幕中,三翼鸟直接把“家”搬到了现场,成为了展会的一大看点。这也是三翼鸟继9月9日发布了行业首个一站式定制智慧家平台后的
Top