【工具】tsar 监控Linux系统状态的利器

简介: 一 简介 tsar(Taobao System Activity Reporter)可将收集到的数据存储在磁盘上,另外可以支持将数据存储到MySQL中,也可将数据发送到Nagios报警服务器。
一 简介
tsar(Taobao System Activity Reporter)可将收集到的数据存储在磁盘上,另外可以支持将数据存储到MySQL中,也可将数据发送到Nagios报警服务器。在展示数据层面,可以指定模块,并且支持对多条信息的数据进行Merge输出,如果带--live参数,还可以输出秒级的实时信息。tsar 可以监控CPU、IO、内存、TCP等系统状态,也可监控Apache、Nginx/Tengine、Squid等服务器状态。
二 如何使用
本文主要介绍tsar 如何监控linux 服务器,有兴趣的朋友可以尝试对 nginx 和apache 服务做监控。
1 tsar -L/--list 查看可用的模块列表
  --modname 查看指定模块的运行状况,模块是指 tsar -L 列出来的名称 比如:tsar --cpu
$tsar -L
tsar enable follow modules:
    cpu
    mem
    swap
    tcp
    udp
    traffic
    io
    pcsw
    partition
    tcpx
    load

2 -s/--spec 指定字段,tsar --cpu -s sys,util
          查看多个模块的不同指定字段
$tsar --load --cpu -s runq,util
Time ---cpu-- ---load-
Time util runq
17/09/14-21:20 21.00 32.00
17/09/14-21:25 14.51 9.00
17/09/14-21:30 3.25 9.00
17/09/14-21:35 3.16 7.00
17/09/14-21:40 0.57 12.00
17/09/14-21:45 0.76 9.00
17/09/14-21:50 0.16 8.00
17/09/14-21:55 0.15 7.00
17/09/14-22:00 0.15 11.00

3 -l/--live 查看实时数据
$tsar -l
Time ---cpu-- ---mem-- ---tcp-- -----traffic---- --sda--- --sdb--- ---load-
Time util util retran bytin bytout util util load1
18/09/14-21:27:18 0.27 30.66 0.00 4.0K 4.2K 0.00 0.00 0.13
18/09/14-21:27:23 0.06 30.66 0.00 438.00 1.2K 0.00 0.00 0.12
18/09/14-21:27:28 0.01 30.66 0.00 338.00 335.00 0.00 0.00 0.11
18/09/14-21:27:33 0.05 30.66 0.00 176.00 377.00 0.00 0.00 0.10
18/09/14-21:27:38 0.36 30.67 0.00 4.4K 5.1K 0.00 0.00 0.10
18/09/14-21:27:43 0.13 30.67 0.00 242.00 1.1K 0.00 0.00 0.09
18/09/14-21:27:48 0.42 30.66 0.00 4.0K 4.7K 0.00 0.00 0.08
18/09/14-21:27:53 0.04 30.66 0.00 418.00 962.00 0.00 0.00 0.08
18/09/14-21:27:58 0.09 30.66 0.00 1.0K 2.0K 0.00 0.02 0.07
18/09/14-21:28:03 0.29 30.66 0.00 358.00 4.1K 0.00 0.00 0.06
18/09/14-21:28:08 0.02 30.66 0.00 92.00 154.00 0.00 0.00 0.06
18/09/14-21:28:13 0.11 30.66 0.00 117.00 803.00 0.00 0.00 0.05

查看 指定模块的实时信息
4 $tsar -l --cpu
Time -----------------------cpu----------------------
Time user sys wait hirq sirq util
18/09/14-21:29:25 0.03 0.07 0.00 0.00 0.00 0.10
18/09/14-21:29:30 0.01 0.02 0.00 0.00 0.00 0.02
18/09/14-21:29:35 0.03 0.05 0.00 0.00 0.00 0.08
18/09/14-21:29:40 0.01 0.01 0.00 0.00 0.00 0.02
18/09/14-21:29:45 0.04 0.09 0.00 0.00 0.00 0.13
18/09/14-21:29:50 0.01 0.01 0.00 0.00 0.00 0.02
18/09/14-21:29:55 0.10 0.19 0.00 0.00 0.01 0.30
18/09/14-21:30:00 0.01 0.02 0.00 0.00 0.00 0.02

5 -i/--interval 指定间隔,历史,tsar -i 1 --cpu
$tsar --io -I sdb -l
Time ------------------------------------------sdb-------------------------------------------
Time rrqms wrqms rs ws rsecs wsecs rqsize qusize await svctm util
18/09/14-21:59:01 0.00 0.00 0.00 2.8K 0.00 75.3K 26.77 0.00 0.05 0.02 7.00
18/09/14-21:59:06 0.00 0.00 0.20 2.8K 0.80 75.7K 26.82 0.00 0.05 0.02 7.10
18/09/14-21:59:11 0.00 0.00 0.00 2.8K 0.00 74.9K 26.83 0.00 0.05 0.02 6.84
18/09/14-21:59:16 0.00 0.00 0.00 1.4K 0.00 37.9K 26.29 0.00 0.05 0.02 3.66

6 -d/--date 指定日期,YYYYMMDD或者n代表n天前
以下两个命令式一个意思
$tsar --load -d 20140917
$tsar --load -d 1
Time -------------------load-----------------
Time load1 load5 load15 runq plit
17/09/14-00:05 0.00 0.02 0.05 6.00 918.00
17/09/14-00:10 0.08 0.05 0.05 6.00 920.00
17/09/14-00:15 0.22 0.12 0.07 6.00 919.00
17/09/14-00:20 0.04 0.11 0.08 8.00 934.00
17/09/14-00:25 0.05 0.07 0.06 6.00 921.00
17/09/14-00:30 0.12 0.10 0.07 8.00 921.00
17/09/14-00:35 0.11 0.09 0.06 6.00 913.00
17/09/14-00:40 0.02 0.10 0.08 12.00 929.00
17/09/14-00:45 0.07 0.05 0.05 6.00 919.00
17/09/14-00:50 0.01 0.04 0.05 9.00 932.00
17/09/14-00:55 0.01 0.05 0.05 8.00 920.00
17/09/14-01:00 0.00 0.02 0.05 11.00 931.00
17/09/14-01:05 0.00 0.01 0.05 7.00 920.00
17/09/14-01:10 0.00 0.01 0.05 6.00 928.00
17/09/14-01:15 0.08 0.03 0.05 7.00 920.00
17/09/14-01:20 0.01 0.04 0.05 8.00 939.00
17/09/14-01:25 0.12 0.07 0.05 6.00 924.00

7 -D/--detail 能够指定查看主要字段还是模块的所有字段
命令行加上-D 与不加上D的区别
$tsar --mem -D
Time -----------------------mem----------------------
Time free used buff cach total util
17/09/14-21:50 9325842432.00 86052364288.00 261754880.00 175354589184.00 270994550784.00 31.75
17/09/14-21:55 9324318720.00 86052917248.00 262361088.00 175354953728.00 270994550784.00 31.75
17/09/14-22:00 9352749056.00 86023622656.00 262938624.00 175355240448.00 270994550784.00 31.74
17/09/14-22:05 9323311104.00 86051930112.00 263589888.00 175355719680.00 270994550784.00 31.75
17/09/14-22:10 9320034304.00 86054137856.00 264204288.00 175356174336.00 270994550784.00 31.75
17/09/14-22:15 9321422848.00 86051889152.00 264806400.00 175356432384.00 270994550784.00 31.75
17/09/14-22:20 9316368384.00 86056013824.00 265383936.00 175356784640.00 270994550784.00 31.76
$tsar --mem
Time -----------------------mem----------------------
Time free used buff cach total util
17/09/14-21:50 8.7G 80.1G 249.6M 163.3G 252.4G 31.75
17/09/14-21:55 8.7G 80.1G 250.2M 163.3G 252.4G 31.75
17/09/14-22:00 8.7G 80.1G 250.8M 163.3G 252.4G 31.74
17/09/14-22:05 8.7G 80.1G 251.4M 163.3G 252.4G 31.75
17/09/14-22:10 8.7G 80.1G 252.0M 163.3G 252.4G 31.75

8 --partition 查看fstab指定挂在的系统目录的使用情况 ,-I 指定查看某个目录
$tsar --partition -I /u01
Time --------------/u01--------------
Time bfree bused btotl util
19/09/14-15:20 1.9T 1.7T 3.8T 47.29
19/09/14-15:25 1.9T 1.7T 3.8T 47.29
19/09/14-15:30 1.9T 1.7T 3.8T 47.29
19/09/14-15:35 1.9T 1.7T 3.8T 47.29
19/09/14-15:40 1.9T 1.7T 3.8T 47.29
19/09/14-15:45 1.9T 1.7T 3.8T 47.29
19/09/14-15:50 1.9T 1.7T 3.8T 47.29
19/09/14-15:55 1.9T 1.7T 3.8T 47.29
19/09/14-16:00 1.9T 1.7T 3.8T 47.29
19/09/14-16:05 1.9T 1.7T 3.8T 47.29
19/09/14-16:10 1.9T 1.7T 3.8T 47.29
19/09/14-16:15 1.9T 1.7T 3.8T 47.29
19/09/14-16:20 1.9T 1.7T 3.8T 47.29
19/09/14-16:25 1.9T 1.7T 3.8T 47.29
19/09/14-16:30 1.9T 1.7T 3.8T 47.29
19/09/14-16:35 1.9T 1.7T 3.8T 47.29
19/09/14-16:40 1.9T 1.7T 3.8T 47.29
19/09/14-16:45 1.9T 1.7T 3.8T 47.29
19/09/14-16:50 1.9T 1.7T 3.8T 47.29

参考文章
[1] http://www.infoq.com/cn/news/2013/04/taobao-open-tsar
[2] http://blog.csdn.net/manzhe/article/details/23748513




目录
相关文章
|
3月前
|
Linux 网络安全 数据安全/隐私保护
Linux 超级强大的十六进制 dump 工具:XXD 命令,我教你应该如何使用!
在 Linux 系统中,xxd 命令是一个强大的十六进制 dump 工具,可以将文件或数据以十六进制和 ASCII 字符形式显示,帮助用户深入了解和分析数据。本文详细介绍了 xxd 命令的基本用法、高级功能及实际应用案例,包括查看文件内容、指定输出格式、写入文件、数据比较、数据提取、数据转换和数据加密解密等。通过掌握这些技巧,用户可以更高效地处理各种数据问题。
287 8
|
3月前
|
监控 Linux
如何检查 Linux 内存使用量是否耗尽?这 5 个命令堪称绝了!
本文介绍了在Linux系统中检查内存使用情况的5个常用命令:`free`、`top`、`vmstat`、`pidstat` 和 `/proc/meminfo` 文件,帮助用户准确监控内存状态,确保系统稳定运行。
1026 6
|
3月前
|
Linux
在 Linux 系统中,“cd”命令用于切换当前工作目录
在 Linux 系统中,“cd”命令用于切换当前工作目录。本文详细介绍了“cd”命令的基本用法和常见技巧,包括使用“.”、“..”、“~”、绝对路径和相对路径,以及快速切换到上一次工作目录等。此外,还探讨了高级技巧,如使用通配符、结合其他命令、在脚本中使用,以及实际应用案例,帮助读者提高工作效率。
160 3
|
3月前
|
监控 安全 Linux
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景,包括 ping(测试连通性)、traceroute(跟踪路由路径)、netstat(显示网络连接信息)、nmap(网络扫描)、ifconfig 和 ip(网络接口配置)。掌握这些命令有助于高效诊断和解决网络问题,保障网络稳定运行。
132 2
|
5天前
|
网络协议 Unix Linux
深入解析:Linux网络配置工具ifconfig与ip命令的全面对比
虽然 `ifconfig`作为一个经典的网络配置工具,简单易用,但其功能已经不能满足现代网络配置的需求。相比之下,`ip`命令不仅功能全面,而且提供了一致且简洁的语法,适用于各种网络配置场景。因此,在实际使用中,推荐逐步过渡到 `ip`命令,以更好地适应现代网络管理需求。
21 11
|
2月前
|
Linux Shell
Linux 10 个“who”命令示例
Linux 10 个“who”命令示例
92 14
Linux 10 个“who”命令示例
|
2月前
|
Ubuntu Linux
Linux 各发行版安装 ping 命令指南
如何在不同 Linux 发行版(Ubuntu/Debian、CentOS/RHEL/Fedora、Arch Linux、openSUSE、Alpine Linux)上安装 `ping` 命令,详细列出各发行版的安装步骤和验证方法,帮助系统管理员和网络工程师快速排查网络问题。
179 20
|
2月前
|
Linux
linux查看目录下的文件夹命令,find查找某个目录,但是不包括这个目录本身?
通过本文的介绍,您应该对如何在 Linux 系统中查看目录下的文件夹以及使用 `find` 命令查找特定目录内容并排除该目录本身有了清晰的理解。掌握这些命令和技巧,可以大大提高日常文件管理和查找操作的效率。 在实际应用中,灵活使用这些命令和参数,可以帮助您快速定位和管理文件和目录,满足各种复杂的文件系统操作需求。
99 8
|
2月前
|
网络协议 Linux 应用服务中间件
kali的常用命令汇总Linux
kali的常用命令汇总linux
91 7
|
3月前
|
Linux 数据库
Linux中第一次使用locate命令报错?????
在Linux CentOS7系统中,使用`locate`命令时出现“command not found”错误,原因是缺少`mlocate`包。解决方法是通过`yum install mlocate -y`或`apt-get install mlocate`安装该包,并执行`updatedb`更新数据库以解决后续的“can not stat”错误。
55 9