【工具】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 应用服务中间件 Shell
二、Linux文本处理与文件操作核心命令
熟悉了Linux的基本“行走”后,就该拿起真正的“工具”干活了。用grep这个“放大镜”在文件里搜索内容,用find这个“探测器”在系统中寻找文件,再用tar把东西打包带走。最关键的是要学会使用管道符|,它像一条流水线,能把这些命令串联起来,让简单工具组合出强大的功能,比如 ps -ef | grep 'nginx' 就能快速找出nginx进程。
二、Linux文本处理与文件操作核心命令
|
3月前
|
Linux
linux命令—stat
`stat` 是 Linux 系统中用于查看文件或文件系统详细状态信息的命令。相比 `ls -l`,它提供更全面的信息,包括文件大小、权限、所有者、时间戳(最后访问、修改、状态变更时间)、inode 号、设备信息等。其常用选项包括 `-f` 查看文件系统状态、`-t` 以简洁格式输出、`-L` 跟踪符号链接,以及 `-c` 或 `--format` 自定义输出格式。通过这些选项,用户可以灵活获取所需信息,适用于系统调试、权限检查、磁盘管理等场景。
321 137
|
3月前
|
安全 Ubuntu Unix
一、初识 Linux 与基本命令
玩转Linux命令行,就像探索一座新城市。首先要熟悉它的“地图”,也就是/根目录下/etc(放配置)、/home(住家)这些核心区域。然后掌握几个“生存口令”:用ls看周围,cd去别处,mkdir建新房,cp/mv搬东西,再用cat或tail看文件内容。最后,别忘了随时按Tab键,它能帮你自动补全命令和路径,是提高效率的第一神器。
731 57
|
6月前
|
JSON 自然语言处理 Linux
linux命令—tree
tree是一款强大的Linux命令行工具,用于以树状结构递归展示目录和文件,直观呈现层级关系。支持多种功能,如过滤、排序、权限显示及格式化输出等。安装方法因系统而异常用场景包括:基础用法(显示当前或指定目录结构)、核心参数应用(如层级控制-L、隐藏文件显示-a、完整路径输出-f)以及进阶操作(如磁盘空间分析--du、结合grep过滤内容、生成JSON格式列表-J等)。此外,还可生成网站目录结构图并导出为HTML文件。注意事项:使用Tab键补全路径避免错误;超大目录建议限制遍历层数;脚本中推荐禁用统计信息以优化性能。更多详情可查阅手册mantree。
567 143
linux命令—tree
|
2月前
|
存储 安全 Linux
Linux卡在emergency mode怎么办?xfs_repair 命令轻松解决
Linux虚拟机遇紧急模式?别慌!多因磁盘挂载失败。本文教你通过日志定位问题,用`xfs_repair`等工具修复文件系统,三步快速恢复。掌握查日志、修磁盘、验重启,轻松应对紧急模式,保障系统稳定运行。
511 2
|
3月前
|
缓存 监控 Linux
Linux内存问题排查命令详解
Linux服务器卡顿?可能是内存问题。掌握free、vmstat、sar三大命令,快速排查内存使用情况。free查看实时内存,vmstat诊断系统整体性能瓶颈,sar实现长期监控,三者结合,高效定位并解决内存问题。
331 0
Linux内存问题排查命令详解
|
3月前
|
Unix Linux 程序员
Linux文本搜索工具grep命令使用指南
以上就是对Linux环境下强大工具 `grep` 的基础到进阶功能介绍。它不仅能够执行简单文字查询任务还能够处理复杂文字处理任务,并且支持强大而灵活地正则表达规范来增加查询精度与效率。无论您是程序员、数据分析师还是系统管理员,在日常工作中熟练运用该命令都将极大提升您处理和分析数据效率。
313 16
|
5月前
|
监控 Linux 网络安全
Linux命令大全:从入门到精通
日常使用的linux命令整理
884 13
|
6月前
|
Linux 网络安全 数据安全/隐私保护
使用Linux系统的mount命令挂载远程服务器的文件夹。
如此一来,你就完成了一次从你的Linux发车站到远程服务器文件夹的有趣旅行。在这个技术之旅中,你既探索了新地方,也学到了如何桥接不同系统之间的距离。
1095 21
|
6月前
|
监控 Linux
Linux系统中使用df命令详解磁盘使用情况。
`df`命令是Linux系统管理员和用户监控和管理磁盘空间使用的重要工具。掌握它的基本使用方法和选项可以帮助在必要时分析和解决空间相关问题。简洁但功能丰富,`df`命令确保了用户可以快速有效地识别和管理文件系统的空间使用情况。
473 13