感谢支持
我们一直在努力

Collectl: 全能Linux 性能监控工具

对于一个 Linux 系统管理员来说确保自己管理的系统处于一个良好的状态是其首要责任。Linux 系统管理员可以找到有很多工具来帮助自己监控和显示系统中的进程,例如 top 和 htop ,但是这些工具都不能与 collectl 相媲美。

Collectl: Linux Performance Monitoring

在 Linux/UNIX 终端下使用 nload 实时监控网络流量和带宽使用 http://www.linuxidc.com/Linux/2014-04/100374.htm

Linux 系统实时监控的瑞士军刀 —— Glances  http://www.linuxidc.com/Linux/2014-04/99265.htm

Linux性能优化和监控系列(一)——top工具 http://www.linuxidc.com/Linux/2014-03/98973.htm

Linux流量监控工具 – iftop http://www.linuxidc.com/Linux/2013-08/89102.htm 

collectl是一款非常优秀并且有着丰富的命令行功能的实用程序,你可以用它来采集描述当前系统状态的性能数据。不同于大多数其它的系统监控工具,collectl 并非仅局限于有限的系统度量,相反,它可以收集许多不同类型系统资源的相关信息,如 cpu 、disk、memory 、network 、sockets 、 tcp 、inodes 、infiniband 、 lustre 、memory、nfs、processes、quadrics、slabs和buddyinfo等。

使用 collectl 的另一个好处就是它可以替代那些特定用途的工具如: top、ps、iotop 等等其它工具。那么 collectl 有什么特性而使其成为一个有用的工具呢?

经过许多研究后,我总结了 collectl 的命令行功能的一些非常重要的特性。

Collectl 特性

  • 可以交互式地运行或作为一个守护进程,或同时二者兼备地运行。

  • 可以以多种格式显示输出。

  • 可以监控几乎所有的子系统。

  • 可以替代许多工具如 ps、top、iotop、vmstat。

  • 可以记录并回放捕获的数据。

  • 可以将数据导出成多种数据格式。(这在你想用外部工具分析数据时非常有用)

  • 可以作为一个服务来监控远程机或者整个服务器集群。

  • 可以在终端显示数据,写入数据到文件或者一个套接字。

如何在Linux上安装collectl

collectl可以在所有的 Linux 发行版上运行,唯一需要的就是 perl 语言,所以在安装 collectl 之前,一定要确保你的电脑上已经安装了Perl

对于Debian/Ubuntu/Linux Mint

下面的命令可以用来在以 Debian 为基础的设备如 Ubuntu 上安装 collectl。

  1. $ sudo aptget install collectl

对于RHEL/CentOS/Fedora

如果你正在使用基于红帽的发行版,你可以用 yum 命令轻松获取它。

  1. # yum install collectl

一些关于collectl的实例

collectl 工具安装完成之后,你可以轻松地在终端运行它,你甚至不需要指定任何选项。下面的命令将会以简短易读的格式显示cpu、硬盘和网络信息。

  1. # collectl
  2. waiting for1 second sample
  3. #
  4. #cpu sys inter ctxsw KBRead Reads KBWrit Writes KBIn PktIn KBOut PktOut
  5. 13579013220092741305
  6. 102719118600003904
  7. 1207531188005232506
  8. 132733106300001101
  9. 252834137500001101
  10. 2828701424003671101
  11. 1939492271004431101
  12. 172809138400001606
  13. 162732134800001101
  14. 2249931615005631203

正如上面终端上所显示的,我们很容易观察该命令输出的系统度量值,因为它每次以一行显示。

不加任何参数执行 collectl 会显示下面子系统的信息

  • cpu
  • 磁盘
  • 网络

提示:在这里,一个子系统就是每一种可以测量的系统资源。

你也可以显示除slabs以外各个子系统的统计数据,这要结合下面的 -all 选项来实现。

  1. # collectl –all
  2. waiting for1 second sample
  3. #
  4. #cpu sys inter ctxsw Cpu0 Cpu1 Free Buff Cach Inac Slab Map Fragments KBRead Reads KBWrit Writes KBIn PktIn KBOut PktOut IP Tcp Udp Icmp Tcp Udp Raw Frag Handle Inodes Reads Writes Meta Comm
  5. 16381715424303901G175M1G683M193M1G nsslkjjebbk 002431101000062300081602408290000
  6. 11174513243164261G175M1G683M193M1G nsslkjjebbk 00000302000062200081602408280000
  7. 15279316833714241G175M1G683M193M1G ssslkjjebbk 00001101000062200081602408290000
  8. 16287218754274461G175M1G683M193M1G ssslkjjebbk 002431101000062200081602408280000
  9. 24284213834733681G175M1G683M193M1G ssslkjjebbk 0016861101000062200081602408280000
  10. 27384410994783651G175M1G683M193M1G nsslkjjebbk 00001619000062200081602408280000
  11. 26582312383964281G175M1G683M193M1G ssslkjjebbk 000021139000062200081602408280000
  12. 15175312763613911G175M1G683M193M1G ssslkjjebbk 004031203000062300081602408290000

但是,你如何用它来监控 cpu 的使用情况呢? ‘-s’ 选项可以用来控制哪个子系统的数据需要收集和回放。

例如下面的命令可以用来对cpu使用情况进行一个总结。

  1. # collectl -sc
  2. waiting for1 second sample
  3. #
  4. #cpu sys inter ctxsw
  5. 1527491155
  6. 1637721445
  7. 1427931247
  8. 2748871292
  9. 2417961258
  10. 1617431113
  11. 1517431179
  12. 1417061078
  13. 1517641268

当你将这个命令与“scdn”结合时会发生什么呢?学习命令行工具最好的方式就是多加练习,所以在终端运行下面的命令看看会发生什么吧。

  1. # collectl -scdn
  2. waiting for1 second sample
  3. #
  4. #cpu sys inter ctxsw KBRead Reads KBWrit Writes KBIn PktIn KBOut PktOut
  5. 254943333300001102
  6. 273825291000001101
  7. 275886253100000001
  8. 204872240600001101
  9. 2618542091002021101
  10. 3941004339800002836
  11. 4169552464004031203
  12. 257890160900001101
  13. 162814116500796432202
  14. 1417791383004861101
  15. 11279512850000214114

 

更多详情见请继续阅读下一页的精彩内容: http://www.linuxidc.com/Linux/2014-06/102805p2.htm

你可以很容易就明白默认选项是“cdn”,它代表cpu、硬盘和网络数据。运行带这个选项的 collectl 命令的输出和“collectl -scn”的输出一样。

如果你想采集内存的数据,用下面的命令。

  1. # collectl -sm
  2. waiting for1 second sample
  3. #
  4. #Free Buff Cach Inac Slab Map
  5. 1G177M1G684M193M1G
  6. 1G177M1G684M193M1G
  7. 1G177M1G684M193M1G
  8. 1G177M1G684M193M1G
  9. 1G177M1G684M193M1G
  10. 1G177M1G684M193M1G
  11. 1G177M1G684M193M1G
  12. 1G177M1G684M193M1G

当你想要进一步了解内存使用信息、空闲的内存或者与你系统性能有关的重要资料时,上面的输出将是非常有用的。

如果想搜集一点儿 tcp 的数据呢?使用下面的命令来实现吧。

  1. # collectl -st
  2. waiting for1 second sample
  3. #
  4. # IP Tcp Udp Icmp
  5. 0000
  6. 0000
  7. 0000
  8. 0000
  9. 0000
  10. 0000
  11. 0000
  12. 0000
  13. 0000
  14. 0000
  15. 0000

当你熟练到一定程度时,你就可以很轻松地得到你想要的结果了。例如你可以将关于 tcp 的“t”选项和关于 cpu 的“c”选项组合到一起。下面的命令就是如此。

  1. # collectl -stc
  2. waiting for1 second sample
  3. #
  4. #cpu sys inter ctxsw IP Tcp Udp Icmp
  5. 23896131360000
  6. 24591636620000
  7. 21884824080000
  8. 301091626740000
  9. 38382617520000
  10. 31382014080000
  11. 15578113350000
  12. 17380213140000
  13. 17375512180000
  14. 14278813210000

对于我们普通大众来说记住这些选项很困难,所以在这里,我整理出了一个列表来总结这个工具支持的选项。

  • b – buddy info (内存碎片)
  • c – CPU
  • d – Disk
  • f – NFS V3 Data
  • i – Inode and File System
  • j – Interrupts
  • l – Lustre
  • m – Memory
  • n – Networks
  • s – Sockets
  • t – TCP
  • x – Interconnect
  • y – Slabs (系统对象缓存)

对于一个系统管理员或者一个 Linux 用户来说很重要的一种数据就是硬盘的使用情况。下面的命令可以帮你监控硬盘使用情况。

  1. # collectl -sd
  2. waiting for1 second sample
  3. #
  4. #KBRead Reads KBWrit Writes
  5. 0000
  6. 0000
  7. 00927
  8. 0000
  9. 00363
  10. 0000
  11. 0000
  12. 001007
  13. 0000

你也可以使用“-sD”选项来采集单个硬盘的数据,不过你必须知道这就不会显示全部硬盘的信息。

  1. # collectl -sD
  2. waiting for1 second sample
  3. # DISK STATISTICS (/sec)
  4. # Pct
  5. #Name KBytes Merged IOs Size KBytes Merged IOs Size RWSize QLen Wait SvcTim Util
  6. sda 00005211226261881
  7. sda 0000000000000
  8. sda 0000240212120000
  9. sda 00001520438380000
  10. sda 00001924536464120205
  11. sda 0000204021021020000
  12. sda 0000000000000
  13. sda 00001162633938116164
  14. sda 0000000000000
  15. sda 0000000000000
  16. sda 000032531110116164
  17. sda 0000000000000

你也可以使用其它详细的子系统来采集详细的数据。下面是详细子系统的一个列表。

  • C – CPU
  • D – Disk
  • E – Environmental data (fan, power, temp), via ipmitool
  • F – NFS Data
  • J – Interrupts
  • L – Lustre OST detail OR client Filesystem detail
  • N – Networks
  • T – 65 TCP counters only available in plot format
  • X – Interconnect
  • Y – Slabs (system object caches)
  • Z – Processes

collectl 工具中有许多选项,但是仅用一篇文章来介绍肯定是介绍不过来的。然而如果将它当作 topps 工具来使用还是值得一提的。

很容易将 collectl 当作 top 来使用,只要在 Linux 系统的终端运行下面的命令你就会看到和 top 工具类似的输出。

  1. # collectl –top
  2. # TOP PROCESSES sorted by time (counters are /sec) 13:11:02
  3. # PID User PR PPID THRD S VSZ RSS CP SysT UsrT Pct AccuTime RKB WKB MajF MinF Command
  4. ^COuch!tecmint 20140 R 1G626M00.010.141528:48.24000109/usr/lib/firefox/firefox
  5. 3403 tecmint 20140 R 1G626M10.000.202028:48.44000600/usr/lib/firefox/firefox
  6. 5851 tecmint 2046660 R 17M13M00.020.06800:01.280000/usr/bin/perl
  7. 1682 root 2016662 R 211M55M10.020.01303:10.2400095/usr/bin/X
  8. 3454 tecmint 2034038 S 216M45M10.010.02301:23.320000/usr/lib/firefox/plugincontainer
  9. 4658 tecmint 2046573 S 207M17M10.000.02200:08.23000142 gnometerminal
  10. 2890 tecmint 2025713 S 340M68M00.000.01101:19.950000 compiz
  11. 3521 tecmint 20124 S 710M148M10.010.00101:47.840000 skype
  12. 1 root 2000 S 3M2M00.000.00000:02.570000/sbin/init
  13. 2 root 2000 S 0010.000.00000:00.000000 kthreadd
  14. 3 root 2020 S 0000.000.00000:00.600000 ksoftirqd/0
  15. 5 root 020 S 0000.000.00000:00.000000 kworker/0:0H
  16. 7 root 020 S 0000.000.00000:00.000000 kworker/u:0H
  17. 8 root RT 20 S 0000.000.00000:04.420000 migration/0
  18. 9 root 2020 S 0000.000.00000:00.000000 rcu_bh
  19. 10 root 2020 R 0000.000.00000:02.220000 rcu_sched
  20. 11 root RT 20 S 0000.000.00000:00.050000 watchdog/0
  21. 12 root RT 20 S 0010.000.00000:00.070000 watchdog/1
  22. 13 root 2020 S 0010.000.00000:00.730000 ksoftirqd/1
  23. 14 root RT 20 S 0010.000.00000:01.960000 migration/1
  24. 16 root 020 S 0010.000.00000:00.000000 kworker/1:0H
  25. 17 root 020 S 0010.000.00000:00.000000 cpuset

最后,当然不是说这不重要,我们在终端运行下面的命令就可以将 collectl 用作 ps 工具了。 你可以得到关于你系统进程的信息,这和在终端运行“ps”命令是一样的。

  1. # collectl -c1 -sZ -i:1
  2. waiting for1 second sample
  3. ### RECORD 1 >>> tecmint-vgn-z13gn <<< (1397979716.001) (Sun Apr 20 13:11:56 2014) ###
  4. # PROCESS SUMMARY (counters are /sec)
  5. # PID User PR PPID THRD S VSZ RSS CP SysT UsrT Pct AccuTime RKB WKB MajF MinF Command
  6. 1 root 2000 S 3M2M00.000.00000:02.570000/sbin/init
  7. 2 root 2000 S 0010.000.00000:00.000000 kthreadd
  8. 3 root 2020 S 0000.000.00000:00.600000 ksoftirqd/0
  9. 5 root 020 S 0000.000.00000:00.000000 kworker/0:0H
  10. 7 root 020 S 0000.000.00000:00.000000 kworker/u:0H
  11. 8 root RT 20 S 0000.000.00000:04.420000 migration/0
  12. 9 root 2020 S 0000.000.00000:00.000000 rcu_bh
  13. 10 root 2020 S 0000.000.00000:02.240000 rcu_sched
  14. 11 root RT 20 S 0000.000.00000:00.050000 watchdog/0
  15. 12 root RT 20 S 0010.000.00000:00.070000 watchdog/1
  16. 13 root 2020 S 0010.000.00000:00.730000 ksoftirqd/1
  17. 14 root RT 20 S 0010.000.00000:01.960000 migration/1
  18. 16 root 020 S 0010.000.00000:00.000000 kworker/1:0H
  19. 17 root 020 S 0010.000.00000:00.000000 cpuset
  20. 18 root 020 S 0010.000.00000:00.000000 khelper
  21. 19 root 2020 S 0000.000.00000:00.000000 kdevtmpfs
  22. 20 root 020 S 0000.000.00000:00.000000 netns
  23. 21 root 2020 S 0000.000.00000:00.000000 bdidefault
  24. 22 root 020 S 0000.000.00000:00.000000 kintegrityd

我确信许多系统管理员将会喜欢这个工具并且在充分使用它后会感受到它的强大。如果你想增进你对 collectl 的了解,从而达到新的层面,你可以去参阅 collectl 的 man 手册并勤加练习。

在你的终端键入下面的命令开始阅读吧。

  1. # man collectl

参考链接

  • collectl Homepage

本文永久更新链接地址:http://www.linuxidc.com/Linux/2014-06/102805.htm

赞(0) 打赏
转载请注明出处:服务器评测 » Collectl: 全能Linux 性能监控工具
分享到: 更多 (0)

听说打赏我的人,都进福布斯排行榜啦!

支付宝扫一扫打赏

微信扫一扫打赏