Linux 系统监控常用命令
简介
列举操作系统级监控常用的几个方法,建议收藏使用
CPU
top 命令可用于监控系统整体负载,包括cpu、内存使用等,能够实时显示系统中各个进程的资源占用状况
输出样例
top - 19:37:41 up 192 days, 9:14, 1 user, load average: 0.39, 0.28, 0.27
Tasks: 126 total, 1 running, 125 sleeping, 0 stopped, 0 zombie
Cpu(s): 0.1%us, 0.1%sy, 0.0%ni, 99.8%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st
Mem: 32113M total, 11351M used, 20762M free, 266M buffers
Swap: 4091M total, 0M used, 4091M free, 304M cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
1 root 20 0 25280 1016 968 S 0 0.0 2:37.44 init
2 root 20 0 0 0 0 S 0 0.0 0:02.40 kthreadd
3 root 20 0 0 0 0 S 0 0.0 3:28.59 ksoftirqd/0
5 root 20 0 0 0 0 S 0 0.0 0:00.59 kworker/u:0
6 root RT 0 0 0 0 S 0 0.0 0:11.39 migration/0
指标说明
- load average: 0.06, 0.60, 0.48
系统负载,即任务队列的长度。分别为 1分钟、5分钟、15分钟内的平均值。 - Tasks
进程汇总,包括运行中、睡眠、停止、僵尸态的梳理 - Cpu(s)
| 指标 | 说明 |
|---|---|
| 0.3% us | 用户空间占用CPU百分比 |
| 1.0% sy | 内核空间占用CPU百分比 |
| 0.0% ni | 用户进程优先级调度CPU百分比 |
| 98.7% id | 空闲CPU百分比 |
| 0.0% wa | 等待输入输出的CPU时间百分比 |
| 0.0% hi | 硬件CPU中断占用百分比 |
| 0.0% si | 软中断占用百分比 |
| 0.0% st | 虚拟机占用百分比 |
Mem
内存统计,包括物理内存、已使用内存、空闲内存、内核缓存Swap
交换区统计,包括总量、已使用、空闲量、缓存量进程列表
| 指标 | 说明 |
|---|---|
| PID | 进程ID |
| USER | 进程所有者的用户名 |
| PR | 优先级 |
| NI | nice值。负值表示高优先级,正值表示低优先级 |
| VIRT | 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES |
| RES | 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA |
| SHR | 共享内存大小,单位kb |
| S | 进程状态(D=不可中断的睡眠状态,R=运行,S=睡眠,T=跟踪/停止,Z=僵尸进程) |
| %CPU | 进程使用的CPU百分比 |
| %MEM | 进程使用的物理内存百分比 |
| TIME+ | 进程使用的CPU时间总计,单位1/100秒 |
| SWAP | 进程使用的虚拟内存中,被换出的大小,单位kb |
| CODE | 可执行代码占用的物理内存大小,单位kb |
| DATA | 可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb |
| COMMAND | 命令名/命令行 |
按F键可以选择显示不同的指标,非常详细
参考文档
内存监控
vmstat 指虚拟内存统计(Virtual Meomory Statistics), 是常用的实时系统监控工具。
输出样例
~-> vmstat 2
procs -----------memory---------- ---swap-- -----io---- -system-- -----cpu------
r b swpd free buff cache si so bi bo in cs us sy id wa st
0 0 212 21250404 272916 320572 0 0 0 2 0 0 0 0 100 0 0
0 0 212 21250652 272916 320576 0 0 0 0 535 1061 0 0 100 0 0
0 0 212 21250652 272916 320576 0 0 0 0 496 1062 0 0 100 0 0
2 0 212 21250256 272916 320576 0 0 0 0 751 1107 0 0 99 0 0
0 0 212 21250404 272916 320568 0 0 0 0 496 1056 0 0 100 0 0
0 0 212 21250404 272916 320568 0 0 0 0 593 1089 0 0 100 0 0
0 0 212 21250404 272916 320568 0 0 0 56 539 1074 0 0 100 0 0
0 0 212 21250404 272916 320568 0 0 0 0 589 1137 0 0 100 0 0
0 0 212 21250404 272916 320564 0 0 0 0 608 1154 0 0 100 0 0
0 0 212 21250404 272916 320564 0 0 0 0 601 1156 0 0 100 0 0
1 0 212 21250404 272916 320564 0 0 0 0 611 1155 0 0 100 0 0
0 0 212 21250404 272916 320564 0 0 0 0 599 1151 0 0 100 0 0
指标说明
| 指标 | 说明 |
|---|---|
| procs.r | 等待cpu时间片的进程数 |
| procs.b | 等待资源的进程数,比如等待IO或内存交换等 |
| cpu.us | 用户态CPU 时间百分比 |
| cpu.sy | 内核态CPU 时间百分比,参考值us+sy<=80% |
| cpu.wa | IO等待所占用的CPU 时间百分比,参考值wa<=30 |
| cpu.id | 空闲状态CPU 时间百分比 |
| cpu.st | 虚拟机CPU占用时间百分比,存在超分时可能较高 |
| system.in | 设备中断数 |
| system.cs | 上下文切换次数 |
| memory.swpd | 内存交换区的内存数量(KB) |
| memory.free | 空闲页的内存数量(KB) |
| memory.buff | buffer cache的内存数量,一般在块设备读写使用 |
| memory.cache | 作为page cache的内存数量,一般作为文件系统的cache |
| swap.si | 由内存进入内存交换区数量 |
| swap.so | 由内存交换区进入内存数量 |
| io.bi | 从块设备读入的数据量(KB/S) |
| io.bo | 向块设备写入的数据量(KB/S) |
参考文档
关于 linux OOM Killer
free 查看可用内存
网络连接
netstat 命令用于显示各种网络相关信息,如网络连接,路由表,接口状态等。
输出样例
iotweb@kwe1000111753:~> netstat -ano |head
Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address Foreign Address State
tcp 0 0 0.0.0.0:4444 0.0.0.0:* LISTEN
tcp 0 0 0.0.0.0:19999 0.0.0.0:* LISTEN
tcp 0 0 0.0.0.0:27017 0.0.0.0:* LISTEN
tcp 0 0 0.0.0.0:6380 0.0.0.0:* LISTEN
tcp 0 0 0.0.0.0:111 0.0.0.0:* LISTEN
常见用法
- 检查出TIME_WAIT的数量
netstat -an | grep -c TIME_WAIT
- 检查全部socket状态
netstat -nat| awk '{print awk $NF}'|sort|uniq -c|sort -n
- 检查进程及socket数量
netstat -nap| awk '{print awk $NF}'|sort|uniq -c|sort -n
- 查看端口连接数
netstat -anp |grep 27071|wc -l
磁盘使用
iostat 用于监控磁盘的IO吞吐及资源占用情况
命令
iostat -d -x -k 1 10
-d为查看磁盘状况,-k表示以KB为单位,-x表示输出更多的扩展字段
Device: rrqm/s wrqm/s r/s w/s rkB/s wkB/s avgrq-sz avgqu-sz await svctm %util
xvda 0.01 8.32 0.49 4.94 6.82 53.08 22.06 0.11 19.68 1.76 0.95
xvde 0.02 841.11 33.24 304.80 331.20 4583.79 29.08 1.67 4.93 1.15 38.76
dm-0 0.00 0.00 33.26 1145.95 331.20 4583.79 8.34 0.30 2.61 0.33 38.81
指标说明
| 指标 | 说明 |
|---|---|
| rrqm/s | 每秒merge的读取请求数(同一个Block存在merge机制) |
| rrqm/s | 每秒merge的写入请求数(同一个Block存在merge机制) |
| r/s | 每秒提交的读取请求数 |
| w/s | 每秒提交的写入请求数 |
| await | IO请求的平均响应时间,参考值<=10ms |
| rkB/s | 每秒读取数据量 |
| wkb/s | 每秒写入数据量 |
| avgrq-sz | IO平均请求大小(扇区) |
| avgqu-sz | IO平均请求队列大小 |
| svctm | IO请求平均执行时间 |
| %util | CPU占用百分比 |
进程监控
ps命令能够给出当前系统中进程的快照
- 查找进程方法
ps -ef |grep nscl
- 按cpu占用排序查看前10进程
-> ps -aux --sort -pcpu |head -n 10
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
iotweb 9313 1.0 14.3 6277488 4708752 ? Sl Nov03 687:08 ./bin/mongod -f conf/mongodb.conf --auth
iotweb 16957 0.3 10.1 10208428 3322260 ? Sl Nov01 251:37 java -jar redis-stat-0.4.14.jar 127.0.0.1:6380 3 --server=63800
root 2822 0.1 0.0 133196 1288 ? Sl Jun07 431:05 /usr/bin/vm-agent
iotweb 16942 0.1 0.0 52364 13304 ? Ssl Nov01 95:57 ./bin/redis-server 0.0.0.0:6380
指标说明
| 指标 | 说明 |
|---|---|
| USER | 进程 owner |
| PID | 进程ID |
| %CPU | CPU占用率 |
| %MEM | 内存占用率 |
| TTY | 终端 |
| STAT | 进程状态 |
| VSZ | 虚拟内存占用 |
| RSS | 物理内存占用 |
| START | 开始日期 |
| TIME | 启动时长 |
| COMMAND | Bash命令 |
文件占用
lsof(list open files)用于列出当前系统打开文件句柄,包括网络套接字、设备句柄等。
输出样例
~->lsof /opt
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
mongod 9313 iotweb txt REG 252,0 36409888 761870 /opt/local/mongodb/bin/mongod
mongod 9313 iotweb 4w REG 252,0 7082638 778244 /opt/local/mongodb/log/mongodb.log
mongod 9313 iotweb 8uW REG 252,0 5 778246 /opt/local/mongodb/data/mongod.lock
mongod 9313 iotweb 9uw REG 252,0 21 778247 /opt/local/mongodb/data/WiredTiger.lock
mongod 9313 iotweb 15u REG 252,0 36864 778253 /opt/local/mongodb/data/sizeStorer.wt
指标说明
| 指标 | 说明 |
|---|---|
| COMMAND | 进程的名称 |
| PID | 进程ID |
| USER | 进程所有者 |
| FD | 文件描述符 |
| TYPE | 文件类型,如DIR、REG等 |
| DEVICE | 指定磁盘的名称 |
| SIZE | 文件的大小 |
| NODE | 文件索引节点 |
| NAME | 文件的名称 |
Linux 系统监控常用命令的更多相关文章
- linux系统监控常用工具
linux系统监控常用工具 一.系统核心工具包(coreutils) 1./bin/df 报告系统的磁盘空间用量 df -h 显示磁盘分区fdisk -l 2./bin/uname 显示系统信息 u ...
- linux系统监控sar命令
linux系统监控sar命令详解 sar(System Activity Reporter系统活动情况报告)是目前 Linux 上最为全面的系统性能分析工具之一,可以从多方面对系统的活动进行报告, 包 ...
- Linux 系统巡检常用命令
Linux系统巡检常用命令 # uname -a # 查看内核/操作系统# cat /etc/centos-release # 查看centos操作系统版本# cat /proc/cpuinfo ...
- linux系统的常用命令
linux系统中常用的命令如下(以后经常补充): cd .. 返回上一级 cd use 进入use目录
- linux系统性能监控常用命令
一.Linux服务器性能关注点 1)CPU -> load:表示cpu在一段时间内正在处理以及等待处理的任务之和统计信息,简单可理解为cpu正处理的线程数和能同时处理的线程数的比值.一般认为 ...
- 用xshell操作linux系统的常用命令
(1)命令ls——列出文件 ls -la 给出当前目录下所有文件的一个长列表,包括以句点开头的“隐藏”文件 ls a* 列出当前目录下以字母a开头的所有文件 ls -l *.doc 给出当前目录下以. ...
- linux系统学习(常用命令)
今天调休,闲来无事,研究一下linux系统. Linux常用命令: 一:文件管理 ctrl+alt:在虚拟机与windows之间切换ctrl+g:进入linux输入模式 pwd:查看当前目录 ls:列 ...
- Linux系统巡检常用命令-乾颐堂
Linux系统需要定期巡检,以检查服务器软硬件使用情况,相当于对人的体检,确保可以及时发现问题.解决问题,降低损失,常用的巡检命令如下: # uname -a # 查看内核/操作系统/CPU信息 # ...
- Linux系统之-常用命令及技巧
一. 通用命令:1.date :print or set the system date and time2. stty -a: 可以查看或者打印控制字符(Ctrl-C, Ctrl-D, Ctrl-Z ...
随机推荐
- github免密登陆
import requests import re # 一:先获取登陆页面,拿到authenticity_token: # 1 请求的url:https://github.com/login # 2 ...
- python写外网收集信息器
简单化,知道IP去扫描ip import socket from socket import * a=input('请输入域名:') try: ip=gethostbyname(a) print('[ ...
- AFO
留坑 有点绝望 状态什么的,存在么 upd at 2017/11/14还算完满地结束了OI之路了吧.
- hdu_1025(LIS Nlog(N)算法)
题意:自己慢慢读吧.大概就是道路两边建路,给出建路需求,要求两条路不能有交叉,问最多可以建多少条路. 题解:一看数据范围500000,应该是dp,再画个图模拟一下,发现实质就是求最长上升子序列,很自然 ...
- HDU_1257
最少拦截系统 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Sub ...
- flume1.8 开发指南学习感悟
概述: Apache Flume是一个分布式.可用的系统,用于从许多不同的sources有效的收集并移动大量日志数据用于集中存储数据. 架构及数据流动模型: flume实际上就是一个Agent.Age ...
- 在.Net中将RocketMQ跑起来_入门篇【2】
上一篇讲了如何再控制台将RocketMQ跑起来,本篇讲解,在asp.net mvc种跑起来,含(发布.订阅). 本次将不挨个贴源码,直接展示目录,根据上一篇文章,进行相应的调整即可. 1.新建一个类库 ...
- chorme调试Paused in debugger问题解决
最近出现的问题,使用chorme调试代码总是这个状态(Paused in debugger[debug的时候暂停了]): 一刷新就这样,非常的不舒服.当然你可以选择多按几次F8跳出,下面提供几种方式解 ...
- light oj 1184 Marriage Media
题目: You run a marriage media. You take some profiles for men and women, and your task is to arrange ...
- Vue.js 1.x 和 2.x 实例的生命周期
在Vue.js中,在实例化Vue之前,它们都是以HTML的文本形式存在文本编辑器中.当实例化后将经历创建.编译.销毁三个主要阶段. 以下是Vue.js 1.x 实例的生命周期图示: Vue.js 1 ...