linux性能监控:CPU监控命令之dstat命令

简介: linux性能监控:CPU监控命令之dstat命令

640.jpg


CPU监控命令之dstat命令


1概述:


dstat是可以替代vmstat,iostat,netstat,ifstat的综合型替代品。同时去掉了他们的一些限制并加入了一些额外的特性,更多的组件和灵活性

dstat允许你实时查看系统资源的概要。例如,你能与IDE控制器的中断组合来对比磁盘利用率,或通过磁盘吞吐量来对比网络的带宽数量


2安装方法:


Ubuntu/Mint和Debin系统:

本地软件库中有相关安装包,你可以用下面命令安装:

# sudo apt-get install dstat

RHEL/Centos和Fedora系统:  

你可以在romforge软件库中添加有相关安装包,参照指导,使用如下命令很简单就能进行安装:

# yum install dstat


3常用命令格式:

dstat [-afv] [options..] [delay [count]]


4命令参数:

-c cpu是也,显示CPU系统占用,用户占用,空闲,等待,中断,软件中断等信息  -C 当有多个CPU时候,此参数可按需分别显示cpu状态 -d disk是也,显示磁盘读写数据大小  -D hda and total  -n net 显示网络状态  -N net 有多块网卡时,指定要显示的网卡  -l load average 显示系统负载情况  -m memory 显示内存使用情况  -g page 显示页面使用情况  -p process 显示进程状态  -s swap 显示交换分区使用情况  -S 类似D/N  -r I/O请求情况  -y system status  --ipc 显示ipc消息队列,信号等信息  --socket 用来显示tcp udp端口状态  -a all 此为默认选项 等同于 -cdngy  -v vmstat 等同于 -pmgdsc -D total  --output 文件 此选项也比较有用,可以把状态信息以csv的格式重定向到指定的文件中,以便日后查看。

5使用实例:


01

实例1:


命令:查看cpu使用情况:

dstat -c

输出:

640.png


说明:

usr: 用户进程消耗的CPU时间百分比

usr的值比较高时,说明用户进程消耗的CPU时间多,若长期超过50%的使用,需要考虑优化程序算法或 者进行加速。 

sys: 内核进程消耗的CPU时间百分比。sys的值高时,说明系统内核消耗的CPU资源多,这并不是良性的表现,需要检查原因。 

idl: CPU处在空闲状态时间百分比

wai: IO等待消耗的CPU时间百分比。wa的值高时,说明IO等待比较严重,这可能是由于磁盘大量作随机访问造成,也有可能是磁盘的带宽出现瓶颈(块操作)。 

hiq: 硬中断次数。 

siq: 软中断次数。


02

实例2:


命令:查看全部内存使用情况:

dstat -m

输出:


640.png

说明:

used: 使用的物理内存值。

buff: buffer cache的内存,对块设备的读写进行缓冲。

cache: page cache的内存, 文件系统的cache。若cache的值大说明cache住的文件数多,若频繁访问到的文件都能被cache住,那么磁盘的读IO bi 会非常小。

free: 空闲的物理内存。


03

实例3:


命令:查看系统的网络状态

dstat -n

输出:

640.png

04

实例4:


命令:查看系统的负载情况

dstat -l

输出:


640.png

05

实例5:


命令:查看系统的进程信息

dstat -p

输出:


640.png

06

实例6:


命令:查看系统的I/O请求情况

dstat -r

输出:

640.png

dstat的功能非常强大,除了上述常用用法外,更多功能大家自己研究


6特性: 


  • 结合了vmstat,iostat,ifstat,netstat以及更多的信息
  • 实时显示统计情况
  • 在分析和排障时可以通过启用监控项并排序
  • 模块化设计
  • 使用python编写的,更方便扩展现有的工作任务
  • 容易扩展和添加你的计数器(请为此做出贡献)
  • 包含的许多扩展插件充分说明了增加新的监控项目是很方便的
  • 可以分组统计块设备/网络设备,并给出总数
  • 可以显示每台设备的当前状态
  • 极准确的时间精度,即便是系统负荷较高也不会延迟显示
  • 显示准确地单位和和限制转换误差范围
  • 用不同的颜色显示不同的单位
  • 显示中间结果延时小于1秒
  • 支持输出CSV格式报表,并能导入到Gnumeric和Excel以生成图形


相关文章
|
14天前
|
缓存 监控 Linux
|
3月前
|
监控 安全 Linux
在Linux中,zabbix如何监控脑裂?
在Linux中,zabbix如何监控脑裂?
|
1月前
|
监控 安全 Linux
使用NRPE和Nagios监控Linux系统资源的方法
通过遵循以上步骤,可以有效地使用NRPE和Nagios监控Linux系统资源,确保系统运行稳定,并及时响应任何潜在的问题。这种方法提供了高度的可定制性和灵活性,适用于从小型环境到大型分布式系统的各种监控需求。
44 2
|
2月前
|
存储 监控 Linux
监控Linux服务器
详细介绍了如何监控Linux服务器,包括监控CPU、内存、磁盘存储和带宽的使用情况,以及使用各种系统监控工具如vmstat、iostat、sar、top和dstat来分析系统性能,并推荐了一些开源监控系统。
51 0
监控Linux服务器
|
3月前
|
存储 Prometheus 监控
在Linux中,如何进行系统资源的监控?
在Linux中,如何进行系统资源的监控?
|
3月前
|
存储 监控 Ubuntu
在Linux中,如何进行用户行为监控?
在Linux中,如何进行用户行为监控?
|
3月前
|
运维 监控 网络协议
在Linux中,如何进行网络服务的监控?
在Linux中,如何进行网络服务的监控?
|
3月前
|
Prometheus 监控 Kubernetes
在Linux中,如何进行系统性能的持续监控?
在Linux中,如何进行系统性能的持续监控?
|
6月前
|
SQL 运维 监控
关系型数据库性能监控工具
【5月更文挑战第21天】
118 2
|
3月前
|
监控 Java 开发者
揭秘Struts 2性能监控:选对工具与方法,让你的应用跑得更快,赢在起跑线上!
【8月更文挑战第31天】在企业级应用开发中,性能监控对系统的稳定运行至关重要。针对流行的Java EE框架Struts 2,本文探讨了性能监控的工具与方法,包括商用的JProfiler、免费的VisualVM以及Struts 2自带的性能监控插件。通过示例代码展示了如何在实际项目中实施这些监控手段,帮助开发者发现和解决性能瓶颈,确保应用在高并发、高负载环境下稳定运行。选择合适的监控工具需综合考虑项目需求、成本、易用性和可扩展性等因素。
44 0