Linux:系统性能监控工具-tsar安装和使用

简介: Linux:系统性能监控工具-tsar安装和使用

前言

做性能验证往往需要去监控系统的各项性能指标,Linux系统监控工具有很多,但对于命令行操作,安装便捷,监控项较全面等方面,个人比较推荐tsar

tsar

介绍

TSAR(Taobao System Activity Reporter))是淘宝自己开发的采集工具。

主要用来收集服务器的系统信息(如cpu,io,mem,tcp等),以及应用数据(如squid haproxy nginx等)。收集到的数据存储在磁盘上,可以随时查询历史信息,输出方式灵活多样,另外支持将数据存储到mysql中,也可以将数据发送到nagios报警服务器。Tsar在展示数据时,可以指定模块,并且可以对多条信息的数据进行merge输出,带–live参数可以输出秒级的实时信息。Tsar能够比较方便的增加模块,只需要按照tsar的要求编写数据的采集函数和展现函数,就可以把自定义的模块加入到Tsar中。

总体架构

Tsar是基于模块化设计的程序,程序有两部分组成:框架和模块。

  • 框架程序源代码主要在src目录,而模块源代码主要在modules目录中。
  • 框架提供对配置文件的解析,模块的加载,命令行参数的解析,应用模块的接口对模块原始数据的解析与输出。 模块提供接口给框架调用。

Tsar依赖与cron每分钟执行采集数据,因此它需要系统安装并启用crond,安装后,tsar每分钟会执行tsar --cron来定时采集信息,并且记录到原始日志文件。

安装tasr

有两种安装方式

  1. clone代码
git clone git://github.com/alibaba/tsar.git
cd tsar
make
make install
  1. 下载源码-我是采用的这个方法
#依次执行以下命令即可
1.wget -O tsar.zip https://github.com/alibaba/tsar/archive/master.zip --no-check-certificate
2.unzip tsar.zip
3.cd tsar-master
4.make
5.make install

执行命令

wget -O tsar.zip https://github.com/alibaba/tsar/archive/master.zip --no-check-certificate

d2c78a3268374c5c98b49ea55b033012.png


解压:unzip tsar.zip


3a69141073bb4bfb9516537c499cb846.png


执行命令:

cd tsar-master

make


362157653ed248429a6ba4587234d0e5.png

执行命令:make install

7d933b463cd74ab79a0ac59591abffb2.png


tsar配置介绍

安装完tsar后会生成如下的文件


Tsar配置文件路径:/etc/tsar/tsar.conf,tsar的采集模块和输出的具体配置;

定时任务配置:/etc/cron.d/tsar,负责每分钟调用tsar执行采集任务;

日志文件轮转配置:/etc/logrotate.d/tsar,每个月会把tsar的本地存储进行轮转;

模块路径:/usr/local/tsar/modules,各个模块的动态库so文件;


配置文件

负责tsar的采集模块和输出的具体配置;在这里配置启用哪些模块,输出等内容。

cd /etc/tsar/tsar.conf



937403dd0cf34f79953d46893392355c.png

常用参数说明

可结合下文参数,来对应查看/etc/tsar/tsar.conf文件

debug_level 指定tsar的运行级别,主要用来调试使用

mod_xxx on/off 开启指定模块

out_interface 设置输出类型,支持file,nagios,db

out_stdio_mod 设置用户终端默认显示的模块

output_db_mod设置哪些模块输出到数据库

output_db_addr 数据库的ip和端口

output_nagios_mod设置哪些模块输出到nagios

include 支持include配置,主要用来加载用户的自定义模块

cycle_time指定上报的间隔时间,由于tsar每一分钟采集一次,上报时会判断是否符合时间间隔,如设置300的话,则在0,5等整点分钟会上报nagios

threshold 设置某个要报警项的阀值,前面是模块和要监控的具体名称,后面的四个数据代表报警的范围,warn和critical的范围

定时任务配置

每分钟以root用户的角色调用tsar命令来执行数据采集。

cat  /etc/cron.d/tsar


1939b408028a4d66ad5a2f0afb41d2f7.png


日志文件

每个月会把tsar的本地存储进行轮转,此外这里也设定了数据在/var/log/tsar.data下

cd /etc/logrotate.d/tsar

6fc2490332f444cc999ca963d052abb2.png


tsar使用

在Tsar的使用中,如下是可以参考的帮助信息,但实际使用可可能不会涉及如此多,可以直接参考下一个实际使用

b04309ad0f114d7db702e81be44a4cff.png

Usage: tsar [options]
Options:
    -check         查看最后一次的采集数据
    --check/-C     查看最后一次tsar的提醒信息,如:tsar --check / tsar --check --cpu --io
    --watch/-w     显示最后多少分钟的记录. 如:tsar --watch 30 / tsar --watch 30 --cpu --io
    --cron/-c      使用crond模式来进行tsar监控
    --interval/-i  指明tsar的间隔时间,默认单位分钟,默认显示间隔5分钟;带上--live参数则单位是秒,默认是5秒。 
    --list/-L      列出启用的模块
    --live/-l      启用实时模式,类似iostat等,可以配合-i参数和模块参数使用。
    --file/-f      指定输入文件
    --ndays/-n     控制显示多长时间的历史数据,默认1天
    --date/-d      指定日期,YYYYMMDD或者n代表n天前
    --merge/-m     对有多个数据的展示,进行汇总,如机器上跑了3个squid,可以用 tsar –squid -m的放式进行展示汇总。
    --detail/-D    能够指定查看主要字段还是模块的所有字段
    --spec/-s      指定字段,tsar –cpu -s sys,util
    --item/-I      显示指定项目数据, 如:tsar --io -I sda
    -–help/-h      显示提示信息和模块信息
Modules Enabled:
    --cpu          列出cpu相关的监控计数
    --mem          物理内存的使用情况
    --swap         虚拟内存的使用情况
    --tcp          TCP协议IPV4的使用情况
    --udp          UDP协议IPV4的使用情况
    --traffic      网络传出的使用情况
    --io           Linux IO的情况
    --pcsw         进程和上下文切换
    --partition    磁盘使用情况
    --tcpx         TCP连接相关的数据参数
    --load         系统负载情况

tsar实际使用参考

查看可用的监控模块列表

tsar -L

可在配置文件中调整:/etc/tsar/tsar.conf

4a882b66a5824e1f96ed8a5a6d5073d8.png

查看CPU情况

tsar --cpu

user表示用户空间cpu使用情况

sys表示内核空间cpu使用情况

wait表示IO对应的cpu使用情况

hirq,sirq分别是硬件中断,软件中断的使用情况

util是系统使用cpu的总计情况


b6626809b1594c4ab8295f03e2522708.png


依次类推:

可针对的查看下面具体某项或某几项的情况

cpu
mem
swap
tcp
udp
traffic
io
pcsw
partition
tcpx
load

tsar常用命令

显示1天内的历史汇总(summury)信息,以默认5分钟为间隔

tsar

查看所有监控项实时数据

tsar -l   

查看所有监控项,历史或实时数据,以每次1秒钟作为采集显示

tsar -d 1 --cpu --load --mem -i 1
#-d 1: 查看一天前的数据;去掉-d 1则表示查询截止目前24小时内的数据
#-i 1 : 表示以每次1分钟作为采集显示;

查看所有监控项历史或实时数据,以每次1秒钟作为采集显示

tsar -i 1 -l
#-l: 实时数据;不加-l就是所有历史数据了

查出指定监控项实时数据,以每次1秒钟作为采集显示

tsar --cpu --load --mem -i 1 -l

查出指定监控项实时数据,以每次5秒钟作为采集显示

tsar --cpu --load --mem -l 5

追溯历史日期的数据

tsar --load --cpu -d "20230111" -f /var/log/tsar.data
tsar --load --cpu -d "20230111"
#-d : 指定历史日期;
#-f : 指定tsar的数据文件;
目录
相关文章
|
1月前
|
存储 缓存 监控
Linux缓存管理:如何安全地清理系统缓存
在Linux系统中,内存管理至关重要。本文详细介绍了如何安全地清理系统缓存,特别是通过使用`/proc/sys/vm/drop_caches`接口。内容包括清理缓存的原因、步骤、注意事项和最佳实践,帮助你在必要时优化系统性能。
193 78
|
4天前
|
缓存 安全 Linux
Linux系统查看操作系统版本信息、CPU信息、模块信息
在Linux系统中,常用命令可帮助用户查看操作系统版本、CPU信息和模块信息
48 23
|
10天前
|
Oracle 关系型数据库 Linux
linux8安装oracle 11g遇到的问题记录
Oracle 11g在Linux 8上安装时会遇到link编译环节的问题。官方建议忽略安装中的链接错误,安装完成后应用DBPSU 11.2.0.4.240716补丁及一次性补丁33991024,再重新编译二进制文件,并配置监听器和数据库。但因11g已退出服务期,这些补丁需付费获取。网上信息显示22年1月的PSU补丁也可解决问题,找到该补丁后按常规方式打补丁即可。如有需求或疑问可咨询我。
50 20
|
2天前
|
弹性计算 运维 Ubuntu
os-copilot在Alibaba Cloud Linux镜像下的安装与功能测试
我顺利使用了OS Copilot的 -t -f 功能,我的疑惑是在换行的时候就直接进行提问了,每次只能写一个问题,没法连续换行更有逻辑的输入问题。 我认为 -t 管道 功能有用 ,能解决环境问题的连续性操作。 我认为 -f 管道 功能有用 ,可以单独创建可连续性提问的task问题。 我认为 | 对文件直接理解在新的服务器理解有很大的帮助。 此外,我还有建议 可以在非 co 的环境下也能进行连续性的提问。
28 7
|
30天前
|
Linux Python
Linux 安装python3.7.6
本教程介绍在Linux系统上安装Python 3.7.6的步骤。首先使用`yum`安装依赖环境,包括zlib、openssl等开发库。接着通过`wget`下载Python 3.7.6源码包并解压。创建目标文件夹`/usr/local/python3`后,进入解压目录执行配置、编译和安装命令。最后设置软链接,使`python3`和`pip3`命令生效。
|
1月前
|
Ubuntu Linux
Linux 各发行版安装 ping 命令指南
如何在不同 Linux 发行版(Ubuntu/Debian、CentOS/RHEL/Fedora、Arch Linux、openSUSE、Alpine Linux)上安装 `ping` 命令,详细列出各发行版的安装步骤和验证方法,帮助系统管理员和网络工程师快速排查网络问题。
142 20
|
26天前
|
NoSQL 关系型数据库 MySQL
Linux安装jdk、mysql、redis
Linux安装jdk、mysql、redis
172 7
|
1月前
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
105 13
|
1月前
|
Unix Linux 编译器
UNIX/Linux 上的安装
UNIX/Linux 上的安装。
50 2
|
1月前
|
Ubuntu Linux C++
Win10系统上直接使用linux子系统教程(仅需五步!超简单,快速上手)
本文介绍了如何在Windows 10上安装并使用Linux子系统。首先,通过应用商店安装Windows Terminal和Linux系统(如Ubuntu)。接着,在控制面板中启用“适用于Linux的Windows子系统”并重启电脑。最后,在Windows Terminal中选择安装的Linux系统即可开始使用。文中还提供了注意事项和进一步配置的链接。
47 0