优化命令之Sar命令

2023-05-16

文章目录

  • 引言
  • 一、sar简介
    • 1、sar命令常用格式
    • 2、常用选项
    • 3、常用参数
  • 二、Sar常用性能数据
  • 三、CPU资源监控
    • 1、整体CPU使用统计(-u)
    • 2、各个CPU使用统计(-P)
    • 3、将CPU使用情况保存到文件中
  • 四、内存监控
    • 1、内存和交换空间监控
    • 2、内存分页监控
  • 五、I/O监控
    • 1、整体I/O情况(-b)
    • 2、各个I/O设备情况(-d)
  • 六、进程队列长度和平均负载状态监控
  • 七、系统交换活动信息监控
  • 八、设备使用情况监控
  • 九、判断系统故障问题,选用什么命令
  • 十、压力测试实验
    • 1、测试cpu占用率
    • 2、测试内存占用率
    • 3、测试I/O与传输速率与磁盘使用情况
    • 4、检测网络流量
  • 十一、总结

引言

sar(System Activity Reporter, 系统活动情况报告): 是用于监控Linux系统各个性能的优秀工具,包括:文件的读写情况、系统调用的使用情况、磁盘I/O、CPU效率、内存使用状况、进程活动及IPC有关的活动等。

一、sar简介

1、sar命令常用格式

sar [ options ] [ <interval> [ <count> ] ]

options:命令行选项
interval: 采样周期,单位是秒
count:采样次数,默认值是连续采样

例如:
在这里插入图片描述

  1. 选项,也就是我们要获取的是哪个类型的指标数据,这里的-n,代表的是监控一些网络信息
  2. 类型参数,有的类型带有参数,有的没有。这里的DEV,代表的是监控网卡信息
  3. 时间间隔,表示多少秒采样一次数据,这里的1就是1秒
  4. 次数,表示采样的次数。比如时间间隔是3,采样次数是4,那么sar命令将会阻塞12秒钟

2、常用选项

选项说明
-A所有报告的总和
-u输出整体CPU使用情况的统计信息
-v输出inode、文件和其他内核表的统计信息
-d输出每一个块设备的活动信息
-r输出内存和交换空间的统计信息
-b显示I/O和传送速率的统计信息
-a文件读写情况
-c输出进程统计信息,每秒创建的进程数
-R输出内存页面的统计信息
-y终端设备活动情况
-w输出系统交换活动信息

3、常用参数

默认监控: sar 1 1     //  CPU和IOWAIT统计状态 
(1) sar -b 1 1        // IO传送速率
(2) sar -B 1 1        // 页交换速率
(3) sar -c 1 1        // 进程创建的速率
(4) sar -d 1 1        // 块设备的活跃信息
(5) sar -n DEV 1 1    // 网路设备的状态信息
(6) sar -n SOCK 1 1   // SOCK的使用情况
(7) sar -n ALL 1 1    // 所有的网络状态信息
(8) sar -P ALL 1 1    // 每颗CPU的使用状态信息和IOWAIT统计状态 
(9) sar -q 1 1        // 队列的长度(等待运行的进程数)和负载的状态
(10) sar -r 1 1      // 内存和swap空间使用情况
(11) sar -R 1 1       // 内存的统计信息(内存页的分配和释放、系统每秒作为BUFFER使用内存页、每秒被cache到的内存页)
(12) sar -u 1 1       // CPU的使用情况和IOWAIT信息(同默认监控)
(13) sar -v 1 1       // inode, file and other kernel tablesd的状态信息
(14) sar -w 1 1       // 每秒上下文交换的数目
(15) sar -W 1 1       // SWAP交换的统计信息(监控状态同iostat 的si so)
(16) sar -x 2906 1 1  // 显示指定进程(2906)的统计信息,信息包括:进程造成的错误、用户级和系统级用户CPU的占用情况、运行在哪颗CPU上
(17) sar -y 1 1       // TTY设备的活动状态

二、Sar常用性能数据

  • 整体CPU使用统计
  • 各个CPU使用统计
  • 内存使用情况统计
  • 整体I/O情况
  • 各个I/O设备情况
  • 网络统计

三、CPU资源监控

1、整体CPU使用统计(-u)

使用-u选项,sar输出整体CPU的使用情况,不加选项时,默认使用的就是-u选项。以下命令显示采样时间为3s,采样次数为2次,整体CPU的使用情况:
sar 3 2 (或者 sar -u 3 2)
在这里插入图片描述
输出项说明:

选项说明
CPUall表示统计信息为所有CPU的平均值。
%usrCPU在用户态执行进程的时间百分比。
%niceCPU在用户态模式下,用于nice操作,所占用CPU总时间的百分比。
%systemCPU处在内核态执行进程的时间百分比。
%iowaitCPU用于等待I/O操作占用CPU总时间的百分比。
%steal管理程序(hypervisor)为另一个虚拟进程提供服务而等待虚拟CPU的百分比。
%idleCPU空闲时间百分比。

注:

  1. 若 %iowait 的值过高,表示硬盘存在I/O瓶颈
  2. 若 %idle 的值高但系统响应慢时,有可能是 CPU 等待分配内存,此时应加大内存容量
  3. 若 %idle 的值持续低于1,则系统的 CPU 处理能力相对较低,表明系统中最需要解决的资源是 CPU

2、各个CPU使用统计(-P)

-P ALL”选项指示对每个内核输出统计信息:
在这里插入图片描述
其中”CPU”列输出0,1指示对应的cpu核。也可针对单独一个内核显示,“-P 0”指示显示第一个内核的统计信息,“-P 1”指示显示第二个内核的统计信息。
在这里插入图片描述

3、将CPU使用情况保存到文件中

例如,每4秒采样一次,连续采样3次,观察CPU 的使用情况,并将采样结果以二进制形式存入当前目录下的文件test中,需键入如下命令:

sar -u -o test 4 3

在这里插入图片描述

四、内存监控

1、内存和交换空间监控

使用-r选项可显示内存统计信息,以下命令显示以1秒为采样时间,显示2次内存信息:

sar -r 1 2

在这里插入图片描述

参数意义
kbmemfree这个值和free命令中的free值基本一致,所以它不包括buffer和cache的空间
kbmemused这个值和free命令中的used值基本一致,所以它包括buffer和cache的空间
%memused这个值是kbmemused和内存总量(不包括swap)的一个百分比
kbbuffers这个值就是free命令中的buffer
kbcached这个值就是free命令中的cache
kbcommit保证当前系统所需要的内存,即为了确保不溢出而需要的内存(RAM+swap)
%commit这个值是kbcommit与内存总量(包括swap)的一个百分比

2、内存分页监控

例如,每10秒采样一次,连续采样3次,监控内存分页

sar -B 10 3

在这里插入图片描述
输出项说明:

选项说明
pgpgin/s表示每秒从磁盘或SWAP置换到内存的字节数(KB)
pgpgout/s表示每秒从内存置换到磁盘或SWAP的字节数(KB)
fault/s每秒钟系统产生的缺页数,即主缺页与次缺页之和(major + minor)
majflt/s每秒钟产生的主缺页数
pgfree/s每秒被放入空闲队列中的页个数
pgscank/s每秒被kswapd扫描的页个数
pgscand/s每秒直接被扫描的页个数
pgsteal/s每秒钟从cache中被清除来满足内存需要的页个数
%vmeff每秒清除的页(pgsteal)占总扫描页(pgscank+pgscand)的百分比

五、I/O监控

1、整体I/O情况(-b)

使用-b选项,可以显示磁盘I/O的使用情况:Report I/O and transfer rate statistics.

sar -b 3 2

在这里插入图片描述
输出项说明:

选项说明
tps每秒钟物理设备的 I/O 传输总量
rtps每秒钟从物理设备读入的数据总量
wtps每秒钟向物理设备写入的数据总量
bread/s每秒钟从物理设备读入的数据量,单位为 块/s
bwrtn/s每秒钟向物理设备写入的数据量,单位为 块/s

2、各个I/O设备情况(-d)

使用-d选项可以显示各个磁盘的统计信息,再增加-p选项可以以sdX的形式显示设备名称

sar -d -p 3 2

在这里插入图片描述
输出项说明:

选项说明
rd_sec/s每秒从设备读取的扇区数
wr_sec/s每秒往设备写入的扇区数
avgrq-sz发送给设备的请求的平均大小(以扇区为单位)
await服务等待I/O请求的平均时间,包括请求队列等待时间 (单位毫秒)
svctm设备处理I/O请求的平均时间,不包括请求队列等待时间 (单位毫秒)
%util一秒中有百分之多少的时间用于 I/O 操作,即被io消耗的cpu百分比。

注:

  • 如果 %util 接近 100%,说明产生的I/O请求太多,I/O系统已经满负荷,该磁盘可能存在瓶颈。
  • 如果 svctm 比较接近 await,说明 I/O 几乎没有等待时间;如果 await 远大于 svctm,说明I/O
    队列太长,io响应太慢,则需要进行必要优化。
  • 如果avgqu-sz比较大,也表示有大量io在等待。

六、进程队列长度和平均负载状态监控

例如,每3秒采样一次,连续采样3次,监控进程队列长度和平均负载状态

sar -q 3 3

在这里插入图片描述
输出项说明:

选项说明
runq-sz运行队列的长度(等待运行的进程数)
plist-sz进程列表中进程(processes)和线程(threads)的数量
ldavg-1最后1分钟的系统平均负载(System load average)
ldavg-5过去5分钟的系统平均负载
ldavg-15过去15分钟的系统平均负载

七、系统交换活动信息监控

例如,每5秒采样一次,连续采样3次,监控系统交换活动信息

sar - W 5 3

在这里插入图片描述
输出项说明:

选项说明
pswpin/s每秒系统换入的交换页面(swap page)数量
pswpout/s每秒系统换出的交换页面(swap page)数量

八、设备使用情况监控

例如,每2秒采样一次,连续采样1次,报告设备使用情况,需键入如下命令:

sar -d -p 2 1  #-d表示输出每一块设备的信息,参数-p可以打印出sda,hdc等磁盘设备名称,如果不用参数-p,设备节点则有可能是dev8-0,dev22-0

在这里插入图片描述

选项说明
tps每秒从物理磁盘I/O的次数.多个逻辑请求会被合并为一个I/O磁盘请求,一次传输的大小是不确定的
rd_sec/s每秒读扇区的次数
wr_sec/s每秒写扇区的次数
avgrq-sz平均每次设备I/O操作的数据大小(扇区)
avgqu-sz磁盘请求队列的平均长度
await从请求磁盘操作到系统完成处理,每次请求的平均消耗时间,包括请求队列等待时间,单位是毫秒(1秒=1000毫秒)
svctm系统处理每次请求的平均时间,不包括在请求队列中消耗的时间
%utilI/O请求占CPU的百分比,比率越大,说明越饱和

注:

  1. avgqu-sz 的值较低时,设备的利用率较高。
  2. 当%util的值接近 1% 时,表示设备带宽已经占满。

九、判断系统故障问题,选用什么命令

  • 怀疑CPU存在瓶颈,可用 sar -u 和 sar -q 等来查看
  • 怀疑内存存在瓶颈,可用 sar -B、sar -r 和 sar -W 等来查看
  • 怀疑I/O存在瓶颈,可用 sar -b、sar -u 和 sar -d 等来查看

十、压力测试实验

1、测试cpu占用率

在这里插入图片描述

2、测试内存占用率

stress --vm 2 --vm-bytes 1G --vm-hang 100 --timeout 100
开启2个进程分配内存,每次分配1GB内存,保持100秒后释放,100秒后退出。

在这里插入图片描述

3、测试I/O与传输速率与磁盘使用情况

在这里插入图片描述
-d表示输出每一块设备的信息,参数-p可以打印出sda,hdc等磁盘设备名称
在这里插入图片描述
在这里插入图片描述

4、检测网络流量

用ab命令来测试网络流量
在这里插入图片描述
在这里插入图片描述

十一、总结

sar功能全面,可以统计很多系统数据。

  1. 整体CPU使用统计
  2. 各个CPU使用统计
  3. 内存使用情况统计
  4. 整体I/O情况
  5. 各个I/O设备情况
  6. 网络统计
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

优化命令之Sar命令 的相关文章

  • 思科交换机和路由器的配置

    思科交换机和路由器的配置 交换机的配置交换机端口的隔离跨交换机实现VLAN 路由器的配置静态路由RIP Version 1协议 xff08 动态路由 xff09 上一篇 xff1a 思科的安装与汉化 下一篇 xff1a 思科综合实例 接下来
  • c++实现单链表头插法、尾插法、删除、遍历

    最近复习数据结构与算法 xff0c 先从单链表开始 首先明确链表参数为 head xff08 即二级指针 xff09 的原因 xff1a 只要是要修改head指针必须传递head的地址 xff08 用 head xff09 xff0c 否则
  • 选择结构编程练习题

    1 3求任意一个整数的十位上的数字 1 4 输入三个实数 xff0c 判断能否构成三角形 xff1b 若能 xff0c 再说明是何种类型的三角形 1 5输入任意的a b c求一元二次方程ax x 43 bx 43 c 61 0的根 1 6
  • VScode搭建Opencv(C++开发环境)

    VScode配置Opencv 一 准备软件二 下载软件1 MinGw下载2 Cmake下载3 Opencv下载 三 编译1 cmake gui2 make3 install 四 VScode配置1 launch json2 c cpp pr
  • 树莓派 | 解决VNC Viewer无法连接显示问题

    如果觉得本篇文章对您的学习起到帮助作用 xff0c 请 点赞 43 关注 43 评论 xff0c 留下您的足迹 x1f4aa x1f4aa x1f4aa VNC Viewer是一个很不错的远程桌面应用 xff0c 但是我们在树莓派中使用时
  • CV应用领域-目标跟踪

    目标跟踪 啥是目标跟踪 xff1a 夏天的你走在大街上 xff0c 看见道路对面走过来一个漂亮的小姐姐 xff0c 你目不转睛的欣赏夏天美丽的风景 xff0c 这个过程就是目标跟踪 开个玩笑哈哈哈哈哈 通常 xff0c 我们所说的目标跟踪任
  • 面试1:MYSQL数据库语法

    关于MYSQL数据库一些语法 数据库基本语法 增加 xff1a insert into 数据表 字段1 字段2 字段3 values 值1 值2 值3 删除 xff1a delete from 数据表 where id 61 你要删除的数据
  • MAC 下解决端口占用的问题

    查看端口号 终端输入 xff1a sudo lsof i tcp port 将port换成被占用的端口 如 xff1a 8086 9998 将会出现占用端口的进程信息 杀死占用端口的PID进程 找到进程的PID 使用kill命令 xff1a

随机推荐

  • 树莓派配置watchdog

    0x00 安装watchdog apt span class hljs keyword install span watchdog 编辑 etc modules xff0c 添加bcm2708 wdog 编辑 etc watchdog co
  • 2023编程必会的100个代码大全,建议立刻收藏

    前言 我记得刚开始接触编程的时候 xff0c 觉得太难了 也很好奇 xff0c 写代码的那些人也太厉害了吧 xff1f 全是英文的 xff0c 他们的英文水平一定很好吧 xff1f 他们是怎么记住这么多代码格式的 xff1f 而且错了一个标
  • 第一篇博客

    第一篇博客 为了方便以后写博客的练习 以下内容基本都是来自写博客的帮助文档 xff0c 为了以后查找相关内容的时候不需要在在站内打开 xff0c 并且自己做一些实例 xff0c 熟练一下写博客的内容为了以后更方便 快捷键 撤销 xff1a
  • JavaEE入门第一课——配置项目并连接数据库

    JavaEE环境搭建 本地安装Java本地安装Tomcat本地安装Mysql本地创建IDEA JavaEE项目本地使用JDBC连接Mysql xff0c 并且读取数据库中的数据 1 本地安装Java 参考 xff1a https blog
  • 基于Mysql、Servlet、JSP的简单作业管理系统

    文章目录 基于Mysql Servlet JSP的简单作业管理系统内容Servlet简单介绍JSP简单介绍mysql数据库设计代码实现运行结果 基于Mysql Servlet JSP的简单作业管理系统 代码地址 xff1a https gi
  • JavaEE_FinalProject

    基于Springboot xff0c jsp和mybatis的作业管理系统 系统需求 可登陆 xff0c 分为学生和老师两端 xff0c 根据账号进行不同分类 老师可以查看作业 xff0c 添加学生并且添加作业 学生可以查看作业 xff0c
  • Debian10搭建dhcp服务

    文章目录 1 安装dhcp服务2 设置网卡监听3 配置dhcp参数4 重启dhcp服务5 测试6 易错总结 1 安装dhcp服务 apt install y isc dhcp server 等待安装完成即可 xff08 这里有一个报错 xf
  • Debian10搭建ntp服务

    文章目录 1 所需设备2 任务描述3 安装ntp服务4 配置ntp服务器4 安装ntpdate客服端5 Debian10Client设置计划任务6 易错总结 1 所需设备 两台Debian10Debian10Server 网卡信息 xff1
  • win11安装的Ubuntu20.04子系统出现System has not been booted with systemd as init system (PID 1)问题的解决流程

    目录 一 前言 二 具体解决方法 第一步 xff1a 切换root用户至自己账号 第二步 xff1a 重新安装xrdp 第三步 xff1a 重新配置端口并启动xrdp 第四步 xff1a 打开远程连接窗口 第五步 xff1a 点击连接 xf
  • 方面级情感分析综述论文&论文+讲解+复现(ABSA)

    2022最新方面级别情感分析论文综述 A Survey on Aspect Based Sentiment Analysis Tasks Methods and Challenges 其中关于ASTE Data V2数据集的论文 1 论文地
  • 使用Go语言开发Qt界面

    Go 的 UI 库 Go 语言本身是没有 UI 库的 xff0c 不过有许多第三方的库支持将 Go 语言绑定到其他 UI 库 xff0c 比如 Qt GTK 参考地址 环境搭建 非 windows 或者需要参数说明的可以参考官方的wiki
  • GitHub AI 编程工具自动写代码神器Copilot插件体验

    简介 copilot 是一个基于 AI 的编程辅助工具 目前已经集成在了 vscode 中 xff0c 后续可能集成到更多平台和工具 xff0c 目前还是测试阶段 官网地址 https copilot github com 支持所有语言 c
  • WebStorm NodeJS

    按 Create New Project 選擇 Empty Project 選擇自己的Directory 作為Location Location 最尾是代表Project Name 改為Hello World 創建一個Javascript
  • wsl ubuntu22.04 conda环境安装labelImg解决xcb缺失问题

    labelImg 安装 pip install PyQt5 i https pypi tuna tsinghua edu cn simple pip install pyqt5 tools i https pypi tuna tsinghu
  • 7个大一C语言必学的程序 / C语言经典代码大全

    嗨 大家好 xff0c 这里是可莉 xff01 今天给大家带来的是7个C语言的经典基础代码 那一起往下看下去把 程序一 打印100到200之间的素数 include lt stdio h gt int main int i for i 61
  • 字符串转化为枚举类型

    需求 xff1a 通过配置文件中自定义传入枚举类型的值 span class token annotation punctuation 64 value span span class token punctuation span span
  • NAT和PAT的原理及配置

    文章目录 一 NAT1 NAT概述2 私有地址3 NAT工作原理4 NAT功能5 NAT包含4类地址6 NAT的实现方式 二 静态转换 xff08 Static Translation xff09 三 动态转换 xff08 Dynamic
  • Linux系统安装教程(手把手教学)

    文章目录 1 首先 xff0c 打开虚拟机 xff0c 点击新建虚拟机2 点击下一步 xff0c 再点击稍后安装3 操作系统选择Linux xff0c 版本选择CentOS7 64位4 命名虚拟机5 设置磁盘大小为100GB6 设置内存为4
  • NFS共享存储服务

    文章目录 引言一 NFS概述二 安装 nfs utils rpcbind 软件包三 NFS的特点四 实验步骤1 安装nfs和rpcbind软件2 设置共享目录3 启动 NFS服务并验证结果4 客户机中访问 NFS 共享资源4 1 手动挂载
  • 优化命令之Sar命令

    文章目录 引言一 sar简介1 sar命令常用格式2 常用选项3 常用参数 二 Sar常用性能数据三 CPU资源监控1 整体CPU使用统计 xff08 u xff09 2 各个CPU使用统计 P 3 将CPU使用情况保存到文件中 四 内存监