Python 监控linux之dstat

Python 监控linux之dstat        Python编写的监控工具——dstat          1.多功能系统资源统计

大家好,又见面了,我是你们的朋友全栈君。

        Python编写的监控工具——dstat


    

    1.多功能系统资源统计工具dstat

    根据官方文档的介绍,dstat是一个用Python语言实现的多功能系统资源统计工具,用来取代Linux下的vmstat、iostat、netstat和ifstat等命令。并且,dstat克服了这些命令的限制,增加了额外的功能,以及更多的计数器与更好的灵活性。dstat可以在一个界面上展示非常全面的监控信息,因此,在系统监控、基准测试和故障排查等应用场景下特别有用。

            我们可以使用dstat监控所有系统资源的使用情况,并且用不同的颜色尽心输出,以可读性较强的单位展示监控数值。例如,对于字节数值,dstat自动根据数值的大小,以K、M、G等单位进行显示,避免了开发者使用其他命令时因为数值太大造成 的困惑和错误。此外,使用dstat还可以非常方便地编写插件用来收集默认情况下没有收集的监控信息、dstat是专门为人们实时查看监控信息设计的,因此,默认将监控结果输出到屏幕终端。我们也可以将监控信息以CSV格式输出到文件中,以便后续进行处理。

作为一个多功能的系统资源统计工具,dstat具有以下特性:

※综合了vmstat、iostat、ifstat、netstat等监控工具的功能,并且提供了更多的监控信息;
※实时显示监控数据;
※在问题分析和故障排查时,可以监视嘴重要的计数器,也可以对计数器进行排序;
※模块化设计;
※使用Python语言编写,更方便扩展现有的工作任务;
※容易扩展,便于添加自定义的计数器;
※包含许多扩展插件;
※可以分组统计块设备/网络设备,并给出汇总信息;
※可以显示每台设备中断信息;
※非常精确的时间精度,即便是系统负荷较高也不会延迟显示;
※准确显示单位,限制转换误差范围;
※用不同的颜色显示不同的单位,增加可读性;
※支持CSV格式输出,便于将监控信息导入Gnumeric和Excel以生成图形。

如果操作系统没有默认安装dstat,那么,需要我们手动进行安装。(Ubuntu)

sudo apt-get install dstat #Ubuntu系统使用

Linux中,本人使用CentOS7.5版本,应使用yum命令。

sudo yum install dstat #linux系统使用

安装完成之后,在当前系统中存在一个名为dstat的命令,我们可以在终端中查看命令的帮助信息和支持的选项。

dstat --help

与其他工具不同的是,dstat命令的–version选项,除了显示dstat的版本外,还会显示操作系统的版本、Python语言的版本、cpu的个数,以及dstat支持的插件列表等详细信息。

Dstat 0.7.2
Written by Dag Wieers <dag@wieers.com>
Homepage at http://dag.wieers.com/home- made/dstat/

Platform posix/linux2
Kernel 3.10.0-862.el7.x86_64
Python 2.7.5(default.Apr 11 2018. 07:36:10)
[GCC 4.8.5 20150623 (Red Hat 4.8.5-28)]

Terminal type: xterm- 256color (color support)
Terminal size: 24 lines, 80 columns

Processors: 1
Pagesize: 4096
Clock tick per secs: 100

除了使用dstat命令的–version选项查看dstat的详细信息获取可支持的插件以外,还可以使用dstat命令的–list选项获取dstat的插件列表。

dstat --list

直接在终端输入dstat命令,dstat将以默认参数运行。默认情况下,dstat会收集cpu、磁盘、网络、换页和系统信息,并以一秒钟一次的频率进行输出,直到我们按Ctrl+C结束。

    2.dstat常用选项

直接输入dstat,从图中可以看到,dstat会提示我们没有指定任何参数,因此使用-cdngy参数运行。

Python 监控linux之dstat

※-c:显示CPU的使用情况。这些列显示了cpu花费在各类操作的百分比,包括执行用户代码(usr)、执行系统代码(sys)、空闲(idl)和等待IO(wai)。如果usr的执行较高,说明当前系统中CPU负载较大;如果wai长期处于比较大的值,说明系统IO等待比较严重;

※-d:显示磁盘的读写情况,在进行性能测试时可以使用该字段观察当前的磁盘负载;

※-n:网络设备发送和接收的数据,在这一栏显示网络收发数据的总数;

※-g:表示换页活动。大多数情况下你都希望看到in(换入)和out(换出)的值是0.如果不为0,则说明当前系统内存不够用,会严重影响应用程序的性能;

※-y:系统设计。这一项显示的是中断(int)和上下文切换(csw)。

除了前面介绍的默认参数以外,也可以使用dstat --help获取dstat的其他选项,dstat会根据选项的顺序显示监控信息。例如,在图中演示了dstat的部分选项以及选项外的顺序。

※-t:显示统计系统的当前时间:

※-l、--load:统计系统负载情况,包括1分钟、5分钟、15分钟平均值;

※-p、--proc:统计进程信息,包括runnable,blocked和new的进程数量;

※--tcp:显示常用的TCP统计;

※--fs:统计文件打开数和inodes数。

Python 监控linux之dstat

如图,dstat监控系统信息

除了前面介绍的与监控项相关的参数以外,dstat还可以像vmstst和iostat一样使用参数控制报告的时间间隔,或者同时指定时间间隔与报告次数。

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

例如,下面的命令代表以默认的选项运行dstat,每两秒输出一条监控信息,并在的输出10条监控信息以后推出dstat

dstat 2 10

    3.dstat高级用法

dstat的强大之处不仅仅是因为它聚合了多种工具的监控结果,还因为它能通过附带的插件实现一些高级功能,如找出占用资源最高的进程和用户。dstat的–top-(io|bio|cpu|cputime|cputime-avg|mem)这几个选项可以看到具体是哪个用户和哪个进程占用了相关系统资源,对系统调优非常有效。如查看当前占用I/O、cpu、内存等最高的进程信息可以使用–top-mem –top-io –top-cpu选项。如图给出了一个例子,演示了如何找出占用资源最多的进程。

Python 监控linux之dstat

dstat的插件保存在/usr/share/dstat目录下,读者可以参考的它们的实现,编写自己的插件。

    4.将结果输出到CSV文件

前面说过,dstat还可以将监控信息保存到文件中,以便后续进行处理。通过–output选项指定监控数据输出的文件。如下所示:

dstat -a --ouput dstat_utput.csv



版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/148689.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月28日 下午9:00
下一篇 2022年6月28日 下午9:00


相关推荐

  • 计算机网络复习题

    计算机网络复习题1.计算机网络从逻辑功能上可分成(通信子网)和(资源子网)。2.网络的低层模块向高层提供功能性的支持称之为(服务)。3.TCP/1P标准模型从高到低分别是(应用层)、(运输层)、(网络层)、(链路层)和(物理层)。4.在一个物理信道内可以传输频率的范围称为(带宽)。5.计算机网络依据网络传输技术来分类,主要有(广播式)和(点对点式)两类。6.通信双方在进行通信之前,需要事先建立一个可以彼此沟通的的通道,这种通信方式称为(面向连接)的通信。7.因特网上提供的主要信息服务有(电子邮件)、(WWW

    2025年11月29日
    8
  • vscode关闭flake8格式检查

    vscode关闭flake8格式检查用vscode写python时,安装了flake8检查格式,结果一片红且用yapf格式化后还有一堆红色的格式问题提示,如下图:尝试在preference的extension中关闭插件,发现找不到对应插件,最后在settings.json中更改以下两个值:”python.linting.pylintEnabled”:true,”python.linting.flake8Enabled”:false,一片红消失,快乐ps:一键格式化使用alt+shift+F(yapf)即可…

    2025年11月4日
    3
  • Spring的两种动态代理Jdk与Cglib

    Spring的两种动态代理Jdk与CglibSpring的两种动态代理Jdk与Cglib

    2022年4月23日
    40
  • mysql 乐观锁 时间戳_MySQL乐观锁

    mysql 乐观锁 时间戳_MySQL乐观锁乐观锁 大多是基于数据版本 Version 记录机制实现 何谓数据版本 即为数据增加一个版本标识 在基于数据库表的版本解决方案中 一般是通过为数据库表增加一个 version 字段来实现 版本号读取出数据时 将此版本号一同读出 之后更新时 对此版本号加一 此时 将提交数据的版本数据与数据库表对应记录的当前版本信息进行比对 如果提交的数据版本号大于数据库表当前版本号 则予以更新 否则认为是过期数

    2026年3月26日
    2
  • java开发面试 自我介绍!!!!!

    java开发面试 自我介绍!!!!!先做一个自我介绍吧面试官 你好 我叫 ZYLDLP 今天来公司面试 JAVA 开发工程师 之前在 反正钱没你这里多公司 任职 从事这一行已经有 几 个年头了 这几年开发 主要涉及的行业项目包括 你干过的项目 等 在开发过程中 也用过好些框架 比如 dubbo zookeeper springboot springmvc spring Mybatis 等框架 熟练掌握框架之间的整合技术 有时候因为项目需求或是为了开发的高效性 自己也会研究一些技术 使用一些常用的主流 java 技术 例如 吹 用没用过不重要

    2026年3月19日
    1
  • LeetCode – Permutation Sequnce 题解

    LeetCode – Permutation Sequnce 题解Theset nbsp 1 2 3 n nbsp containsatot nbsp n uniquepermut Bylistingand Wegetthefoll ie for nbsp n nbsp 3 123 132 213 231 3

    2026年3月16日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号