Linux 性能工具 pidstat 命令详解
nanshan 2024-10-24 11:42 29 浏览 0 评论
Linux 性能工具 pidstat 命令详解
安装完成 Zabbix 之后,我们就可以安装 Maxserver 来实现数据大屏展示了。
Maxserver 是一个免费的系统,感兴趣的,可以添加微信,获取安装包下载地址和安装手册。
完成 Maxserver 安装之后,Zabbix 里面的主机将自动同步到 Maxserver,将会看到如下的面
板。
全部主机的运行状态大屏
每台主机的详细运行大屏
pidstat 概述
pidstat是 sysstat工具的一个命令,用于监控全部或指定进程的 cpu、内存、
线程、设备 IO等系统资源的占用情况。pidstat 首次运行时显示自系统启动开
始的各项统计信息,之后运行 pidstat将显示自上次运行该命令以后的统计信
息。用户可以通过指定统计的次数和时间来获得所需的统计信息。
pidstat 安装
pidstat 是 sysstat软件套件的一部分,sysstat 包含很多监控 linux系统状
态的工具,它能够从大多数 linux发行版的软件源中获得。
? 在 Debian/Ubuntu 系统中可以使用下面的命令来安装:
apt-get install sysstat
? CentOS/Fedora/RHEL 版本的 linux 中则使用下面的命令:
yum install sysstat
pidstat 示例
pidstat 的用法:
pidstat [ 选项 ] [ <时间间隔> ] [ <次数> ]
常用的参数:
? -u:默认的参数,显示各个进程的 cpu 使用统计
? -r:显示各个进程的内存使用统计
? -d:显示各个进程的 IO 使用情况
? -p:指定进程号
? -w:显示每个进程的上下文切换情况
? -t:显示选择任务的线程的统计信息外的额外信息
? -T { TASK | CHILD | ALL }
这个选项指定了 pidstat 监控的。TASK 表示报告独立的 task,CHILD 关键字表示报告
进程下所有线程统计信息。ALL 表示报告独立的 task 和 task 下面的所有线程。
注意:task 和子线程的全局的统计信息和 pidstat 选项无关。这些统计信息不会对
应到当前的统计间隔,这些统计信息只有在子线程 kill 或者完成的时候才会被收
集。
? -V:版本号
? -h:在一行上显示了所有活动,这样其他程序可以容易解析。
? -I:在 SMP 环境,表示任务的 CPU 使用率/内核数量
? -l:显示命令名和所有参数
示例一:查看所有进程的 CPU 使用情况( -u -p ALL)
pidstat
pidstat -u -p ALL
pidstat 和 pidstat -u -p ALL 是等效的。
pidstat 默认显示了所有进程的 cpu使用率。
详细说明
? PID:进程 ID
? %usr:进程在用户空间占用 cpu 的百分比
? %system:进程在内核空间占用 cpu 的百分比
? %guest:进程在虚拟机占用 cpu 的百分比
? %CPU:进程占用 cpu 的百分比
? CPU:处理进程的 cpu 编号
? Command:当前进程对应的命令
示例二: cpu 使用情况统计(-u)
pidstat -u
使用-u 选项,pidstat 将显示各活动进程的 cpu 使用统计,执行"pidstat -
u"与单独执行"pidstat"的效果一样。
示例三: 内存使用情况统计(-r)
pidstat -r
使用-r 选项,pidstat 将显示各活动进程的内存使用统计:
? PID:进程标识符
? Minflt/s:任务每秒发生的次要错误,不需要从磁盘中加载页
? Majflt/s:任务每秒发生的主要错误,需要从磁盘中加载页
? VSZ:虚拟地址大小,虚拟内存的使用 KB
? RSS:常驻集合大小,非交换区五里内存使用 KB
? Command:task 命令名
示例四:显示各个进程的 IO 使用情况(-d)
pidstat -d
报告 IO 统计显示以下信息:
? PID:进程 id
? kB_rd/s:每秒从磁盘读取的 KB
? kB_wr/s:每秒写入磁盘 KB
? kB_ccwr/s:任务取消的写入磁盘的 KB。当任务截断脏的 pagecache 的时候会发
生。
? COMMAND:task 的命令名
示例五:显示每个进程的上下文切换情况(-w)
pidstat -w -p PID
PID:进程 id
? Cswch/s:每秒主动任务上下文切换数量
? Nvcswch/s:每秒被动任务上下文切换数量
? Command:命令名
示例六:显示选择任务的线程的统计信息外的额外信息 (-t)
pidstat -t -p PID
TGID:主线程的表示
? TID:线程 id
? %usr:进程在用户空间占用 cpu 的百分比
? %system:进程在内核空间占用 cpu 的百分比
? %guest:进程在虚拟机占用 cpu 的百分比
? %CPU:进程占用 cpu 的百分比
? CPU:处理进程的 cpu 编号
? Command:当前进程对应的命令
示例七:pidstat -T
pidstat -T TASK
pidstat -T CHILD
pidstat -T ALL
TASK表示报告独立的 task。
CHILD关键字表示报告进程下所有线程统计信息。
ALL表示报告独立的 task 和 task下面的所有线程。
注意:task 和子线程的全局的统计信息和 pidstat 选项无关。这些统计信息不
会对应到当前的统计间隔,这些统计信息只有在子线程 kill或者完成的时候才
会被收集。
PID:进程 id
? Usr-ms:任务和子线程在用户级别使用的毫秒数。
? System-ms:任务和子线程在系统级别使用的毫秒数。
? Guest-ms:任务和子线程在虚拟机(running a virtual processor)使用的毫秒数。
? Command:命令名
相关推荐
- 删库之后不要着急跑路,教你神不知鬼不觉找回数据
-
在工作中,我们误删数据或者数据库,我们一定需要跑路吗?我看未必,程序员一定要学会自救,神不知鬼不觉的将数据找回。在mysql数据库中,我们知道binlog日志记录了我们对数据库的所有操作,所以...
- 数据库告警不可用,增删改受阻(数据库限制删除)
-
前言:昨晚,突然出现服务不可用告警,查看日志上线报文入库到数据库很慢并受阻,出现数据不同步问题。排查问题查看发现服务都是在执行update、insert这些DML命令的时候,报的数据库执行超时。经过一...
- Binlog实现MySQL复制,5个关键步骤,务必掌握!
-
复制是MySQL最重要的功能之一,MySQL集群的高可用、负载均衡和读写分离都是基于复制来实现的。Binlog就是实现主从复制的关键,主数据库将修改操作记录到Binlog中,从数据库通过解...
- MySQL数据实时增量同步到Elasticsearch
-
Mysql到Elasticsearch的数据同步,一般用ETL来实现,但性能并不理想,目前大部分的ETL是定时查询Mysql数据库有没有新增数据或者修改数据,如果数据量小影响不大,但如果几百万上千万的...
- MySQL 数据库恢复:如何执行时间点恢复(PITR)以挽救受损数据?
-
天津鸿萌科贸发展有限公司从事数据安全服务二十余年,致力于为各领域客户提供专业的数据恢复、数据备份、数据取证、数据迁移、网络安全、数据清除等解决方案,并针对企业面临的数据安全风险,提供专业的相关数据安全...
- 阿里面试:MySQL Binlog有哪些格式?底层原理?优缺点?
-
binlog的格式也有三种:STATEMENT、ROW、MIXED,下面我详解binlog三种模式@mikechenStatement模式Statement模式:是基于SQL语句的复制(statem...
- 快速带你读懂MySQL的binlog写入机制
-
深入讲解MySQL中的重要日志binlog的写入机制以及影响IO性能的关键配置,并且介绍了如何利用binlog去恢复数据,保证MySQL的可靠性。Q:binlog写入时机binlog的写入逻辑并...
- MySQL 误删除数据恢复全攻略:基于 Binlog 的实战指南
-
在MySQL的世界里,二进制日志(Binlog)就是我们的"时光机"。它默默记录着数据库的每一个重要变更,就像一位忠实的史官,为我们在数据灾难中提供最后的救命稻草。本文将带您深入掌握如...
- 一文了解MySQL Binlog(一文了解肝脏有益和有害的食物)
-
MySQL的Binlog日志是一种二进制格式的日志,Binlog记录所有的DDL和DML语句(除了数据查询语句SELECT、SHOW等),以Event的形式记录,同时记录语句执行时...
- 数据丢失?别慌!MySQL备份恢复攻略
-
想象一下,某个晴朗的午后,你正享受着咖啡,突然接到紧急电话:你的网站或APP彻底挂了!系统崩溃,界面全白。虽然心头一紧,但你或许还能安慰自己:系统崩溃只是暂停服务,数据还在,修复修复就好了。然而,如果...
- Mysql中的bin log、redo log、undo log的区别
-
最近在整理面试题,在看mvcc的时候看到了undolog,今天索性把这三个log都记录一遍。MySQL的逻辑架构说之前先说一下MySQL的基本架构,MySQL主要分为两层:Server层和存储引...
- binlog日志定时清理(binlog清理规则)
-
binlog日志binlog是MySQL数据库的一种日志文件,用于记录所有对数据的修改操作。binlog全称为binarylog,它以二进制格式记录MySQL服务器上所有的修改操作,包括对哪个数据库...
- 茶水间炸锅了!菜鸟误删用户表,运维老张的MySQL救命三招!
-
(公司茶水间,运维老张、开发小王和新人小李围着咖啡机)小李:(紧张兮兮)张哥!我...我好像把测试库的用户表删了!下午演示咋办啊?老张:(淡定喝咖啡)慌啥?昨晚的备份是吃干饭的?走,教你恢复!一、基础...
- 解决运维痛点,提高运维安全性-雷池 SafeLine WAF新功能身份认证
-
雷池介绍使用雷池SafeLineWAF已经两年多了,在1.5.x版本时就已经开始测试使用,并在推出LTS版本后转入LTS分支。近期雷池SafeLineWAF重点更新了身份认证功能,并提供了SS...
- 【Docker 新手入门指南】第十五章:常见故障排除
-
一、前期准备:收集关键信息在排查问题前,建议先获取以下系统数据,便于精准定位故障:1.系统基础信息#查看Docker版本(确认是否为最新稳定版)dockerversion#查看...
你 发表评论:
欢迎- 一周热门
-
-
极空间如何无损移机,新Z4 Pro又有哪些升级?极空间Z4 Pro深度体验
-
UOS服务器操作系统防火墙设置(uos20关闭防火墙)
-
如何修复用户配置文件服务在 WINDOWS 上登录失败的问题
-
手机如何设置与显示准确时间的详细指南
-
如何在安装前及安装后修改黑群晖的Mac地址和Sn系列号
-
日本海上自卫队的军衔制度(日本海上自卫队的军衔制度是什么)
-
爱折腾的特斯拉车主必看!手把手教你TESLAMATE的备份和恢复
-
10个免费文件中转服务站,分享文件简单方便,你知道几个?
-
NAS:DS video/DS file/DS photo等群晖移动端APP远程访问的教程
-
FANUC 0i-TF数据备份方法(fanuc系统备份教程)
-
- 最近发表
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)