Linux性能查看与分析--命令行工具介绍
本文介绍工作中常用的几个linux性能查看命令:top,sar,vmstat,iostat,pidstat等。
1.top
top是最常用的linux性能分析工具,它能够实时的显示系统中各个进程的资源占用情况。top命令的部分输出如下:
top的交互命令有以下几个:
(1)f 选择显示的列
(2)o或O 改变列的显示顺序
(3)l 切换显示平均负载和启动时间信息
(4)m 切换显示内存信息
(5)t 切换显示进程和CPU状态信息
(6)c 切换显示命令名称和完整命令行
(7)M 根据驻留内存大小进行排序k
(8)P 根据CPU使用百分比大小进行排序
(9)T 根据时间/累计时间进行排序
(10)h 显示帮助信息
(11)q 退出
(12)数字1 显示所有cpu的负载情况
top命令参数:
top [-] [d] [p] [q] [c] [C] [S] [s] [n]
d 指定每两次屏幕信息刷新之间的时间间隔。当然用户可以使用s交互命令来改变之。
p 通过指定监控进程ID来仅仅监控某个进程的状态。
q该选项将使top没有任何延迟的进行刷新。如果调用程序有超级用户权限,那么top将以尽可能高的优先级运行。
S 指定累计模式
s 使top命令在安全模式中运行。这将去除交互命令所带来的潜在危险。
i 使top不显示任何闲置或者僵死进程。
c 显示整个命令行而不只是显示命令名
2.sar
sar周期性的对内存和CPU的使用情况进行采样。基本语法如下:
sar [option] [<interval> [<count>]]
-A:所有报告的总和
-u:输出CPU使用情况的统计信息
-v:输出inode、文件和其他内核表的统计信息
-d:输出每一个块设备的活动信息
-r:输出内存和交换空间的统计信息
-b:显示I/O和传送速率的统计信息
-a:文件读写情况
-c:输出进程统计信息,每秒创建的进程数
-R:输出内存页面的统计信息
-y:终端设备活动情况
-w:输出系统交换活动信息
-n:网络的统计信息
-o:采样结果输出到文件
例如:
每10秒采样一次,连续采样3次,观察CPU 的使用情况,并将采样结果以二进制形式存入当前目录下的文件test中 :sar -u -o test 10 3
查看二进制文件test中的内容:sar -u -f test
每10秒采样一次,连续采样3次,观察核心表的状态:sar -v 10 3
每10秒采样一次,连续采样3次,监控内存分页:sar -r 10 3
每10秒采样一次,连续采样3次,监控内存分页:sar -B 10 3
每10秒采样一次,连续采样3次,报告缓冲区的使用情况:sar -b 10 3
每10秒采样一次,连续采样3次,监控进程队列长度和平均负载状态:sar -q 10 3
每10秒采样一次,连续采样3次,监控系统交换活动信息:sar -W 10 3
每10秒采样一次,连续采样3次,报告设备使用情况:sar -d 10 3 –p
要判断系统瓶颈问题,有时需几个 sar 命令选项结合起来
怀疑CPU存在瓶颈,可用 sar -u 和 sar -q 等来查看
怀疑内存存在瓶颈,可用 sar -B、sar -r 和 sar -W 等来查看
怀疑I/O存在瓶颈,可用 sar -b、sar -u 和 sar -d 等来查看
淘宝有一个改进版的sar叫tsar,可以收集和报告性能和应用的数据,并保持到mysql里。
3.vmstat
vmstat可以统计CPU、内存使用情况、swap使用情况、I/O操作、上下文切换、时钟中断等信息。
使用如:vmstat 1 3
4.iostat
iostat主要查看磁盘io信息。
tps: 每秒钟发送到的I/O请求数.
Blk_read /s: 每秒从设备读取的block数.
Blk_wrtn/s: 每秒向设备写入的block数.
Blk_read: 读入的block总数.
Blk_wrtn: 写入的block总数
使用:iostat -d 1 2
iostat -x 1 2
5.pidstat
是sysstat的组件之一,可以检测进程和线程的性能情况。
6.ps
进程查看工具。
ps表示进程的5种状态码:
D 不可中断 uninterruptible sleep (usually IO)
R 运行 runnable (on run queue)
S 中断 sleeping
T 停止 traced or stopped
Z 僵死 a defunct (”zombie”) process
ps参数:
a 显示所有进程
-a 显示同一终端下的所有程序
-A 显示所有进程
c 显示进程的真实名称
-N 反向选择
-e 等于“-A”
e 显示环境变量
f 显示程序间的关系
-H 显示树状结构
r 显示当前终端的进程
T 显示当前终端的所有程序
u 指定用户的所有进程
-au 显示较详细的资讯
-aux 显示所有包含其他使用者的行程
-C<命令> 列出指定命令的状况
--lines<行数> 每页显示的行数
--width<字符数> 每页显示的字符数
--help 显示帮助信息
--version 显示版本显示
更多内容ps --help
示例:
1.显示所有进程信息
ps -A
2.显示指定用户信息
ps -u root
3.显示所有进程信息,包括命令行
ps -ef
4.将目前属于您自己这次登入的 PID 与相关信息列示出来
ps -l
5.列出目前所有的正在内存当中的程序
ps -aux
6.列出类似程序树的程序显示
ps -axjf
7.netstat
网络连接状态查看工具。
8.lsof
文件描述符查看工具。
lsof -n|awk '{print $2}'|sort|uniq -c |sort -nr|more
lsof -n |awk '{print $2} " " $3'|sort|uniq -c |sort -nr|more
Linux性能查看与分析--命令行工具介绍的更多相关文章
- 监控Linux性能的18个命令行工具
监控 Linux 性能的 18 个命令行工具 对于系统和网络管理员来说每天监控和调试Linux系统的性能问题是一项繁重的工作.在IT领域作为一名Linux系统的管理员工作5年后,我逐渐 认识到监控和保 ...
- 监控 Linux 性能的 18 个命令行工具
http://www.oschina.net/translate/command-line-tools-to-monitor-linux-performance 1.Top-Linux进程监控 Lin ...
- [转载]监控 Linux 性能的 18 个命令行工具
转自:http://www.kuqin.com/shuoit/20140219/338066.html 对于系统和网络管理员来说每天监控和调试Linux系统的性能问题是一项繁重的工作.在IT领域作为一 ...
- 监控 Linux 性能的 18 个命令行工具[转]
对于系统和网络管理员来说每天监控和调试Linux系统的性能问题是一项繁重的工作.在IT领域作为一名Linux系统的管理员工作5年后,我逐渐认识到监控和保持系统启动并运行是多么的不容易.基于此原因,我们 ...
- 监控 Linux 性能的 18 个命令行工具(转)
http://www.oschina.net/translate/command-line-tools-to-monitor-linux-performance?cmp&p=1# 1.Top- ...
- 监控 Linux 系统的 7 个命令行工具
监控 Linux 系统的 7 个命令行工具: " 深入 关于Linux最棒的一件事之一是你能深入操作系统,来探索它是如何工作的,并寻找机会来微调性能或诊断问题.这里有一些基本的命令行工具,让 ...
- JVM性能监控与故障处理命令行工具
JDK命令行工具 Sun公司作为”礼物“赠送给JDK使用者的工具: 这些命令行工具大多是jdk/lib/tools.jar类库的一层薄包装,主要功能代码是在tools类库(不属于java的标准API) ...
- Linux常用的日志分析命令与工具
>>基础命令 操作 命令 说明 查看文件的内容 cat -n access.log -n显示行号 分页显示文件 more access.log Enter下一行,空格下一页,F下一屏,B上 ...
- Linux下处理JSON的命令行工具:jq---安装
转自:https://blog.csdn.net/Sunny_much/article/details/50668871 JSON是前端编程经常用到的格式.Linux下也有处理处理JSON的 ...
随机推荐
- django的rest framework框架——认证、权限、节流控制
一.登录认证示例 模拟用户登录,获取token,当用户访问订单或用户中心时,判断用户携带正确的token,则允许查看订单和用户信息,否则抛出异常: from django.conf.urls impo ...
- python ratelimit使用
1.https://pypi.org/project/ratelimit/
- 深入java集合系列
http://www.cnblogs.com/ITtangtang/p/3948765.html 写的很赞 需要时常复习.
- android 之 GridView
GridView 的用法基本与ListView类似. 程序布局文件main.xml <?xml version="1.0" encoding="utf-8" ...
- enq: TX - row lock contention“等待事件的处理
enq: TX - row lock contention“等待事件的处理 session1: SQL> conn scott/triger Connected. SQL> CRE ...
- BZOJ 1879 [Sdoi2009]Bill的挑战 ——状压DP
本来打算好好写写SDOI的DP题目,但是忒难了, 太难了,就写的这三道题仿佛是可做的. 生在弱省真是兴奋. 这题目直接状压,f[i][j]表示匹配到i,状态集合为j的方案数,然后递推即可. #incl ...
- POJ 2914 Minimum Cut 全局最小割
裸的全局最小割了吧 有重边,用邻接矩阵的时候要小心 #include<iostream> #include<cstdio> #include<bitset> #in ...
- Oracle Partition 分区详细总结
此文从以下几个方面来整理关于分区表的概念及操作: 1.表空间及分区表的概念 2.表分区的具体作用 3.表分区的优缺点 4.表分区的几种类型及操作 ...
- WMAP 启动报错 PHP- 提示缺少 msvcr110.dll 的问题
问题描述: 启动 php-cgi 时如果提示缺少 msvcr110.dll 问题原因: 缺少 vc++ 2012 运行库 问题解决: 需要安装 vcredist_x64.exe 或 vcre ...
- Mountaineers
Mountaineers 时间限制: 3 Sec 内存限制: 128 MB 题目描述 The Chilean Andes have become increasingly popular as a ...