我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Linux如何安装使用系统监控工具Collectl

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Linux如何安装使用系统监控工具Collectl

本篇文章为大家展示了Linux如何安装使用系统监控工具Collectl,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

  系统资源监控

  Collectl作为一个轻量级的监控工具,在同类工具中是功能最全的。用户可监测不同的复杂系统矩阵值,并可保留数据以做之后的分析。不同于其他只用来监测特定系统参数的工具,Collectl可以同时监测不同的变量,并以合适的方式记录它们。

  不同于或聚焦于一小组统计数据、采用唯一输出方式,或采用迭代、作为守护进程运行的大部分监测工具,collectl可以同时全部实现。用户可选择各种子系统中的任一系统来监测包括内存,CPU,磁盘,索引节点,无线带宽,lustre,内存,网络,网络文件系统,进程,二次型,slabs,套接口及TCP等信息。

  深入学习前让我们先看以下命令。

  $ collectl

  waiting for1 second sample.。。

  #《--------CPU--------》《----------Disks-----------》《----------Network----------》

  #cpu sys inter ctxsw KBRead Reads KBWrit Writes KBIn PktIn KBOut PktOut

  00864177200000100

  521338273400820001

  1012222647009230201

  107631722008030102

  CPU使用率,磁盘输入输出和网络活动以每秒为单位来加载。对可以理解这些数据的人来说这些信息很容易读懂。这项列表在给定的时间间隔里会持续增加,并可直接形成一项文件跟踪日志。collectl工具提供了各种命令来对这些数据进行记录,查找及做其他处理。

  安装collectl工具

  对Ubuntu/Debian用户来说Collectl是默认资源,所以使用apt命令便可获取。

  $ sudo apt-get install collectl

  Fedora/CentOS用户使用yum命令便可获取。

  $ yum install collectl

  使用

  必要的了解 - Collectl子系统

  子系统是可检测到的不同系统资源类型。像CPU,内存,带宽等等都可构成一个子系统。只运行collectl命令将以批处理模式输出CPU,磁盘和网络子系统信息,我们在上文已看到相关内容。

  从操作说明可以看到,Collectl可以识别以下子系统。

  总计子系统

  b - buddy info (内存片段)

  c - CPU

  d -Disk

  f - NFS V3 Data

  i -InodeandFileSystem

  j -Interrupts

  l -Lustre

  m -Memory

  n -Networks

  s -Sockets

  t - TCP

  x -Interconnect

  y -Slabs(system object caches)

  细节子系统

  这是一系列的详细信息,大部分情况下都会由相应的总计数据衍生出来。目前“环境变量”和“进程”2类没有相应的总计数据。如果有3个磁盘,选择-sd,将只会看到3个磁盘组合出的单一信息。如果选择-sD,将会分别显示各磁盘信息。

  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

  M -Memory node data, which is also known as numa data

  N -Networks

  T -65 TCP counters only available in plot format

  X -Interconnect

  Y -Slabs(system object caches)

  Z -Processes

  使用“-s”来监测特定的子系统并向其添加子系统的识别项。现在让我们举几个例子。

  1. 监测cpu使用率

  用“-sc”实现CPU总使用率的监测

  $ collectl -sc

  waiting for1 second sample.。。

  #《--------CPU--------》

  #cpu sys inter ctxsw

  3018003729

  3017673599

  使用“-C”观察各个单独的CPU使用情况。结果将会输出多行,分别对应一个CPU。

  $ collectl -sC

  waiting for1 second sample.。。

  # SINGLE CPU STATISTICS

  # Cpu User Nice Sys Wait IRQ Soft Steal Idle

  0300000096

  1300000096

  2200000097

  3100000098

  0200000097

  1202000095

  2100000098

  3401000095

  如果需要,可以同时使用C和c来获取单项CPU监测数据和汇总数据。

  2. 内存监测

  使用m子系统查看内存。

  $ collectl -sm

  waiting for1 second sample.。。

  #《-----------Memory-----------》

  #Free Buff Cach Inac Slab Map

  2G220M1G1G210M3G

  2G220M1G1G210M3G

  2G220M1G1G210M3G

  不难解释。 M用来查看更多内存的详细信息。

  $ collectl -sM

  waiting for1 second sample.。。

  # MEMORY STATISTICS

  # Node Total Used Free Slab Mapped Anon Locked Inact Hit%

  07975M5939M2036M215720K372184K06652K1434M0

  07975M5939M2036M215720K372072K06652K1433M0

  3. 查看磁盘使用情况

  d和D可以查看磁盘使用的概况和详细情况。

  $ collectl -sd

  waiting for1 second sample.。。

  #《----------Disks-----------》

  #KBRead Reads KBWrit Writes

  4113624

  008013

  $ collectl -sD

  waiting for1 second sample.。。

  # DISK STATISTICS (/sec)

  # 《---------reads---------》《---------writes---------》《--------averages--------》 Pct

  #Name KBytes Merged IOs Size KBytes Merged IOs Size RWSize QLen Wait SvcTim Util

  sda 0000000000000

  sda 0000000000000

  sda 10211715322621

  sda 0000921151818112125

  “--verbose”命令可以用来查看附加信息。和D命令不同,它将概况扩展,包含了更多信息。

  $ collectl -sd --verbose

  4. 同时报告多系统情况

  如果想要同时得到CPU,内存和磁盘报告,那么同时使用子命令组合来实现。

  $ collectl -scmd

  waiting for1 second sample.。。

  #《--------CPU--------》《-----------Memory-----------》《----------Disks-----------》

  #cpu sys inter ctxsw Free Buff Cach Inac Slab Map KBRead Reads KBWrit Writes

  40218743341G221M1G1G210M3G0000

  30189640651G221M1G1G210M3G00205

  5. 显示统计时间

  若要将每行的监测信息和时间一同显示,使用T选项。通过在“-o”参数来指定。

  $ collectl -scmd -oT

  waiting for1 second sample.。。

  # 《--------CPU--------》《-----------Memory-----------》《----------Disks-----------》

  #Time cpu sys inter ctxsw Free Buff Cach Inac Slab Map KBRead Reads KBWrit Writes

  12:03:0530196140131G225M1G1G212M3G0000

  12:03:0630188438101G225M1G1G212M3G0000

  12:03:0730201140601G225M1G1G212M3G0000

  使用“-oTm”可将时间换成毫秒显示。

  6. 改变样本计数

  collectl报告的每行都是一份快照或样本,它通常设定定期间隔如1秒来取样。i可用来设置时间间隔,c用来设置样本计数。

  $ collectl -c1 -sm

  waiting for1 second sample.。。

  #《-----------Memory-----------》

  #Free Buff Cach Inac Slab Map

  1G261M1G1G228M3G

  使用i命令可改变更新时间间隔。

  $ collectl -sm -i2

  waiting for2 second sample.。。

  #《-----------Memory-----------》

  #Free Buff Cach Inac Slab Map

  1G261M1G1G229M3G

  上面的命令设定每2秒收集一次内存信息。

  7. 像iotop一样使用collectl

  top命令将collectl像iostat/top工具一样进行智能统计。列表会持续更新,且可以使用不同字段实现排序。

  $ collectl --top iokb

  输出如下

  # TOP PROCESSES sorted by iokb (counters are /sec) 09:44:57

  # PID User PR PPID THRD S VSZ RSS CP SysT UsrT Pct AccuTime RKB WKB MajF MinF Command

  3104 enlighte 2026833 S 938M33M00.000.00000:09.160400/usr/bin/ktorrent

  1 root 2000 S 26M3M20.000.00000:01.300000/sbin/init

  2 root 2000 S 0030.000.00000:00.000000 kthreadd

  3 root 2020 S 0000.000.00000:00.020000 ksoftirqd/0

  4 root 2020 S 0000.000.00000:00.000000 kworker/0:0

  5 root 020 S 0000.000.00000:00.000000 kworker/0:0H

  7 root RT 20 S 0000.000.00000:00.080000 migration/0

  8 root 2020 S 0020.000.00000:00.000000 rcu_bh

  9 root 2020 S 0000.000.00000:00.000000 rcuob/0

  上面的输出很像top命令,并且它以磁盘数量降序排列进程。

  若只想显示上面的5项进程,可用以下命令实现

  $ collectl --top iokb,5

  若想学习上面的列表里哪些字段可以排序,使用如下命令

  $ collectl --showtopopts

  下面是应用于进程或数据的最高排序类型列表。某些情况下你可能会使用某一字段进行排序,但它并非显示的一部分。

  TOP PROCESS SORT FIELDS

  进程排序字段

  Memory

  vsz virtual memory

  rss resident (physical) memory

  Time

  syst system time

  usrt user time

  time total time

  accum accumulated time

  I/O

  rkb KB read

  wkb KB written

  iokb total I/O KB

  rkbc KB read from pagecache

  wkbc KB written to pagecache

  iokbc total pagecacge I/O

  ioall total I/O KB (iokb+iokbc)

  rsys read system calls

  wsys write system calls

  iosys total system calls

  iocncl Cancelled write bytes

  PageFaults

  majf major page faults

  minf minor page faults

  flt total page faults

  ContextSwitches

  vctx volunary context switches

  nctx non-voluntary context switches

  Miscellaneous(best when used with--procfilt)

  cpu cpu number

  pid process pid

  thread total process threads (not counting main)

  TOP SLAB SORT FIELDS

  numobj total number of slab objects

  actobj active slab objects

  objsize sizes of slab objects

  numslab number of slabs

  objslab number of objects in a slab

  totsize total memory sizes taken by slabs

  totchg change in memory sizes

  totpct percent change in memory sizes

  name slab names

  8. 像top一样使用collectl

  为使collectl像top,我们只需以CPU使用率排序输出进程。

  $ collectl --top

  输出如下

  # TOP PROCESSES sorted by time (counters are /sec) 14:08:46

  # PID User PR PPID THRD S VSZ RSS CP SysT UsrT Pct AccuTime RKB WKB MajF MinF Command

  9471 enlighte 2091020 R 63M22M30.030.101300:00.810003/usr/bin/perl

  3076 enlighte 2026832 S 521M40M20.000.03300:55.140002/usr/bin/yakuake

  3877 enlighte 20335641 S 1G218M10.000.03310:10.500000/opt/google/chrome/chrome

  4625 enlighte 20289536 S 1G241M20.000.02208:24.3900012/usr/lib/firefox/firefox

  5638 enlighte 2033563 S 1G265M10.000.02209:55.040002/opt/google/chrome/chrome

  1186 root 2011524 S 502M76M00.000.01103:02.960000/usr/bin/X

  1334 www-data 2013290 S 87M1M20.000.01100:00.850000 nginx:

  上面的命令也可用于显示子系统信息。

  $ collectl --top -scm

  9. 像ps一样列出进程

  为像ps命令一样列出所有进程且没有后续更新,用“c”命令让其计数至1. $ collectl -c1 -sZ -i:1

  上面的命令将会列出类似“ps -e”命令的所有进程。“procfilt”用于从所有进程中过滤出特定的进程信息。“procopts”用于指定另一组微调进程列表显示的命令。

  10. 像vmstat一样使用collectl

  Collectl有内置命令来完成像vmstat一样的功能。

  $ collectl --vmstat

  waiting for1 second sample.。。

  #procs ---------------memory (KB)--------------- --swaps-- -----io---- --system-- ----cpu-----

  # r b swpd free buff cache inact active si so bi bo in cs us sy id wa

  1001733M242M1922M1137M710M0001081982391820951

  1001733M242M1922M1137M710M00001906388610980

  1001733M242M1922M1137M710M00001739348030960

  11. 子系统的详细信息

  下面的命令以一秒为间隔,统计5次CPU信息并和时间一起显示出详细信息(冗长)。

  $ collectl -sc -c5 -i1 --verbose -oT

  waiting for1 second sample.。。

  # CPU SUMMARY (INTR, CTXSW & PROC /sec)

  #Time User Nice Sys Wait IRQ Soft Steal Idle CPUs Intr Ctxsw Proc RunQ Run Avg1 Avg5 Avg15 RunT BlkT

  14:22:101100000087413122691086610.780.860.7810

  14:22:111500000084412832496086610.780.860.7810

  14:22:121700000082413422658086600.780.860.7800

  14:22:131500000084412412429086610.780.860.7810

  14:22:141100000088412702488086600.800.870.7800

  改变“-s”变量查看不同的子系统。

上述内容就是Linux如何安装使用系统监控工具Collectl,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Linux如何安装使用系统监控工具Collectl

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Linux如何安装使用系统监控工具Collectl

本篇文章为大家展示了Linux如何安装使用系统监控工具Collectl,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。  系统资源监控  Collectl作为一个轻量级的监控工具,在同类工具中是功能最
2023-06-13

Linux系统监控工具Collectl怎么用

这篇文章跟大家分析一下“Linux系统监控工具Collectl怎么用”。内容详细易懂,对“Linux系统监控工具Collectl怎么用”感兴趣的朋友可以跟着小编的思路慢慢深入来阅读一下,希望阅读后能够对大家有所帮助。下面跟着小编一起深入学习
2023-06-28

Linux如何安装和使用dstat监控工具

这篇文章主要讲解了“Linux如何安装和使用dstat监控工具”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Linux如何安装和使用dstat监控工具”吧!  dstat可以让你实时地看到所
2023-06-13

如何使用多功能Linux 系统监控工具Glances

如何使用多功能Linux 系统监控工具Glances,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Linux 上最常用的命令行进程监控工具是 top 和它那色彩斑斓、功能丰
2023-06-15

如何使用linux系统性能监控工具KSysguard监控远端主机

小编给大家分享一下如何使用linux系统性能监控工具KSysguard监控远端主机,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!KDE System Guard默
2023-06-13

RedisLive监控工具如何安装

这篇文章给大家分享的是有关RedisLive监控工具如何安装的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 1.安装python2.7.5 和piphttp://blog.itpub.net/30089851/v
2023-06-03

Linux监控工具glances如何使用

本篇文章为大家展示了Linux监控工具glances如何使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Linux下如何使用glances?glances是一个基于python语言开发,可以为li
2023-06-28

如何在Linux中安装部署模块化系统监控工具Hegemon

如何在Linux中安装部署模块化系统监控工具Hegemon,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Linux系统中有top,htop,atop等命令用来监控系统,它们提供
2023-06-28

Linux中如何安装流量监控工具iftop

本文小编为大家详细介绍“Linux中如何安装流量监控工具iftop”,内容详细,步骤清晰,细节处理妥当,希望这篇“Linux中如何安装流量监控工具iftop”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。iftop
2023-06-27

Linux下如何安装网络监控工具ntopng

这篇文章将为大家详细讲解有关Linux下如何安装网络监控工具ntopng,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。ntopng是原始ntop的下一代版本,ntop是监视网络使用情况的网络流量探测器。n
2023-06-27

如何进行Linux性能监控工具nmon安装及使用

这篇文章主要为大家分析了如何进行Linux性能监控工具nmon安装及使用的相关知识点,内容详细易懂,操作细节合理,具有一定参考价值。如果感兴趣的话,不妨跟着跟随小编一起来看看,下面跟着小编一起深入学习“如何进行Linux性能监控工具nmon
2023-06-28

CentOS中怎么安装Monitorix系统监控工具

今天就跟大家聊聊有关CentOS中怎么安装Monitorix系统监控工具,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。安装:  1、在CentOS下设置一个安装源,便于yum命令的使
2023-06-10

Linux系统常用监控工具有哪些

这篇文章主要介绍了Linux系统常用监控工具有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。top 命令top 命令我想大家都挺熟悉吧!Linux 下的 top 命令有点
2023-06-16

Linux系统如何安装HotShots截图工具

小编给大家分享一下Linux系统如何安装HotShots截图工具,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!安装步骤 sudo apt-get-repository ppa:dhor/myway sudo apt-get
2023-06-28

Redis监控工具RedisInsight怎么安装与使用

这篇“Redis监控工具RedisInsight怎么安装与使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Redis监控工
2023-06-29

如何在Linux系统中安装和使用Axel下载工具

本篇内容介绍了“如何在Linux系统中安装和使用Axel下载工具”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Axel 是 Linux 下一
2023-06-12

Linux性能监控工具nmon安装及使用教程解析

一、nmon简介 Nmon (Nigel's Monitor)是由IBM 提供、免费监控 AIX 系统与 Linux 系统资源的工具。该工具可将服务器系统资源耗用情况收集起来并输出一个特定的文件,并可利用 excel 分析工具(nmon a
2022-06-03

Linux系统如何安装及配置ClusterShell工具

这篇文章主要介绍“Linux系统如何安装及配置ClusterShell工具”,在日常操作中,相信很多人在Linux系统如何安装及配置ClusterShell工具问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”L
2023-06-13

编程热搜

目录