【工具】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




目录
相关文章
|
4天前
|
Linux
在 Linux 系统中,“cd”命令用于切换当前工作目录
在 Linux 系统中,“cd”命令用于切换当前工作目录。本文详细介绍了“cd”命令的基本用法和常见技巧,包括使用“.”、“..”、“~”、绝对路径和相对路径,以及快速切换到上一次工作目录等。此外,还探讨了高级技巧,如使用通配符、结合其他命令、在脚本中使用,以及实际应用案例,帮助读者提高工作效率。
22 3
|
4天前
|
监控 安全 Linux
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景,包括 ping(测试连通性)、traceroute(跟踪路由路径)、netstat(显示网络连接信息)、nmap(网络扫描)、ifconfig 和 ip(网络接口配置)。掌握这些命令有助于高效诊断和解决网络问题,保障网络稳定运行。
17 2
|
12天前
|
缓存 监控 Linux
|
15天前
|
Linux Shell 数据安全/隐私保护
|
16天前
|
域名解析 网络协议 安全
|
22天前
|
运维 监控 网络协议
|
23天前
|
监控 Linux Shell
|
4天前
|
安全 网络协议 Linux
本文详细介绍了 Linux 系统中 ping 命令的使用方法和技巧,涵盖基本用法、高级用法、实际应用案例及注意事项。
本文详细介绍了 Linux 系统中 ping 命令的使用方法和技巧,涵盖基本用法、高级用法、实际应用案例及注意事项。通过掌握 ping 命令,读者可以轻松测试网络连通性、诊断网络问题并提升网络管理能力。
21 3
|
7天前
|
Linux
在 Linux 系统中,`find` 命令是一个强大的文件查找工具
在 Linux 系统中,`find` 命令是一个强大的文件查找工具。本文详细介绍了 `find` 命令的基本语法、常用选项和具体应用示例,帮助用户快速掌握如何根据文件名、类型、大小、修改时间等条件查找文件,并展示了如何结合逻辑运算符、正则表达式和排除特定目录等高级用法。
33 6
|
8天前
|
监控 Linux 开发者
如何在 Linux 中优雅的使用 head 命令,用来看日志简直溜的不行
`head` 命令是 Linux 系统中一个非常实用的工具,用于快速查看文件的开头部分内容。本文介绍了 `head` 命令的基本用法、高级用法、实际应用案例及注意事项,帮助用户高效处理文件和日志,提升工作效率。
21 7