zl程序教程

您现在的位置是:首页 >  系统

当前栏目

linux下性能分析命令[总结]

Linux性能命令 分析 总结
2023-09-14 08:59:45 时间

1、前言

在linux下开发程序,为了追求高性能,经常需要测试程序的性能,包括cpu、内存、io、网络等等使用情况。liunx下提供了众多命令方便查看各种资源的使用情况。经常用的有ps、top、free、mpstat、iostat、vmstat、netstat。

2、ps、top、free命令

ps用于查看系统中进程的情况,top能够实时显示系统中各个进程的资源占用状况,free命令可以显示Linux系统中空闲的、已用的物理内存及swap内存,及被内核使用的buffer。

 

3、mpstat命令

用于获取 CPU 相关统计信息,命令执行结果如下图所示:

 

%user         表示处理用户进程所使用 CPU 的百分比。

%nice         表示使用 nice 命令对进程进行降级时 CPU 的百分比。nice 命令更改进程的优先级。 

%system    表示内核进程使用的 CPU 百分比  

%iowait      表示等待进行 I/O 所使用的 CPU 时间百分比  

%irq          表示用于处理系统中断的 CPU 百分比  

%soft        表示用于软件中断的 CPU 百分比  

%idle         显示 CPU 的空闲时间  

4、iostat命令

性能评估的一个主要部分就是磁盘性能,iostat 命令提供了存储接口的性能指标。执行结果下图所示:

 

tps 每秒的传输数量,例如,每秒的 I/O 操作数。注:这只是 I/O 操作的数量;每个操作可能非常大,也可能非常小。

Blk_read/s 每秒从该设备读取的块数。通常,块的大小为 512 字节。这是一个磁盘利用率较好的值。

Blk_wrtn/s 每秒写入该设备的块数

Blk_read 到目前为止从该设备读取的块数。注意,这并不是正在发生的情况。很多块已经从该设备读取。可能现在什么也没有读取。观察一段时间,看是否有变化。

Blk_wrtn 写入该设备的块数。

5、vmstat命令

显示所有与内存和进程相关信息的命令,执行结果如下所示:

procs 显示进程数

r 等待运行的进程。系统上的负载越多,等待运行 CPU 周期的进程数量越多。

b 不可中断睡眠的进程,也称为“被阻塞”的进程。这些进程最有可能等待 I/O,但也可能等待其他事情。

wpd,free,buff,cache显示了内存值班

wpd 虚拟内存或交换内存的数量(以 KB 为单位)

free 可用物理内存的数量(以 KB 为单位)

buff 用作缓冲区的内存数量(以 KB 为单位)

cache 用作缓存的物理内存数量(以 KB 为单位)

si so 显示了交换活动:

si 将内存从磁盘交换回物理 RAM 的速率(以 KB/秒为单位)

so 将内存从物理 RAM 交换到磁盘的速率(以 KB/秒为单位)

bi,bo显示了 I/O 活动:

bi 系统向块设备发送数据的速率(以块/秒为单位)

bo 系统从块设备中读取数据的速率(以块/秒为单位)

in,cs 显示了系统相关活动:

in 系统每秒接收到的中断数

cs 在进程空间中切换上下文的速率(以数量/秒为单位)


us,sy,id,wa 显示了 CPU 负载的信息:

us 显示花费在用户进程中的 CPU 百分比。Oracle 进程属于这一类。

sy 系统进程(如所有根进程)使用的 CPU 百分比

id 可用 CPU 百分比

wa 花费在“等待 I/O”上的百分比

6、netstat命令

用于显示各种网络相关信息,如网络连接,路由表,接口状态 (Interface Statistics),masquerade 连接,多播成员 (Multicast Memberships) 等等。


Linux程序性能分析和火焰图 Linux程序性能分析和火焰图Linux程序的性能分析工具数量比较多,涉及到整个操作系统的方方面面,可能是开源的原因吧,相对于Windows来说丰富太多。其中应用分析性能方面Dtrace, SystemTap, Perf_events应该算是这方面的集大成者。
一文掌握 Linux 性能分析之网络篇(续) 一文掌握 Linux 性能分析之网络篇(续) 本文首发于我的公众号 CloudDeveloper(ID: cloud_dev),专注于干货分享,号内有大量书籍和视频资源,后台回复「1024」即可领取,欢迎大家关注,二维码文末可以扫。
一文掌握 Linux 性能分析之网络篇 一文掌握 Linux 性能分析之网络篇 比较宽泛地讲,网络方向的性能分析既包括主机测的网络配置查看、监控,又包括网络链路上的包转发时延、吞吐量、带宽等指标分析。包括但不限于以下分析工具: ping:测试网络连通性 ifconfig:接口配置 ip:网络接口统计信息 netsat:多种网络栈和接口.
一文掌握 Linux 性能分析之 I/O 篇 一文掌握 Linux 性能分析之 I/O 篇 这是 Linux 性能分析系列的第三篇,前两篇分别讲了 CPU 和 内存,本篇来看 IO。 IO 和 存储密切相关,存储可以概括为磁盘,内存,缓存,三者读写的性能差距非常大,磁盘读写是毫秒级的(一般 0.1-10ms),内存读写是微妙级的(一般 0.1-10us),cache 是纳秒级的(一般 1-10ns)。
一文掌握 Linux 性能分析之 CPU 篇 平常工作会涉及到一些 Linux 性能分析的问题,因此决定总结一下常用的一些性能分析手段,仅供参考。说到性能分析,基本上就是 CPU、内存、磁盘 IO 以及网络这几个部分,本文先来看 CPU 这个部分。