二丫讲梵 二丫讲梵
首页
  • 最佳实践
  • 迎刃而解
  • Nginx
  • Php
  • Zabbix
  • AWS
  • Prometheus
  • Grafana
  • CentOS
  • Systemd
  • Docker
  • Rancher
  • Ansible
  • Ldap
  • Gitlab
  • GitHub
  • Etcd
  • Consul
  • RabbitMQ
  • Kafka
  • MySql
  • MongoDB
  • OpenVPN
  • KVM
  • VMware
  • Other
  • ELK
  • K8S
  • LLM
  • Nexus
  • Jenkins
  • 随写编年
  • 家人物语
  • 追忆青春
  • 父亲的朋友圈
  • 电影音乐
  • 效率工具
  • 博客相关
  • Shell
  • 前端实践
  • Vue学习笔记
  • Golang学习笔记
  • Golang编程技巧
  • 学习周刊
  • Obsidian插件周刊
关于
友链
  • 本站索引

    • 分类
    • 标签
    • 归档
  • 本站页面

    • 导航
    • 打赏
  • 我的工具

    • 备忘录清单 (opens new window)
    • json2go (opens new window)
    • gopher (opens new window)
    • 微信MD编辑 (opens new window)
    • 国内镜像 (opens new window)
    • 出口IP查询 (opens new window)
    • 代码高亮工具 (opens new window)
  • 外站页面

    • 开往 (opens new window)
    • ldapdoc (opens new window)
    • HowToStartOpenSource (opens new window)
    • vdoing-template (opens new window)
GitHub (opens new window)

二丫讲梵

行者常至,为者常成
首页
  • 最佳实践
  • 迎刃而解
  • Nginx
  • Php
  • Zabbix
  • AWS
  • Prometheus
  • Grafana
  • CentOS
  • Systemd
  • Docker
  • Rancher
  • Ansible
  • Ldap
  • Gitlab
  • GitHub
  • Etcd
  • Consul
  • RabbitMQ
  • Kafka
  • MySql
  • MongoDB
  • OpenVPN
  • KVM
  • VMware
  • Other
  • ELK
  • K8S
  • LLM
  • Nexus
  • Jenkins
  • 随写编年
  • 家人物语
  • 追忆青春
  • 父亲的朋友圈
  • 电影音乐
  • 效率工具
  • 博客相关
  • Shell
  • 前端实践
  • Vue学习笔记
  • Golang学习笔记
  • Golang编程技巧
  • 学习周刊
  • Obsidian插件周刊
关于
友链
  • 本站索引

    • 分类
    • 标签
    • 归档
  • 本站页面

    • 导航
    • 打赏
  • 我的工具

    • 备忘录清单 (opens new window)
    • json2go (opens new window)
    • gopher (opens new window)
    • 微信MD编辑 (opens new window)
    • 国内镜像 (opens new window)
    • 出口IP查询 (opens new window)
    • 代码高亮工具 (opens new window)
  • 外站页面

    • 开往 (opens new window)
    • ldapdoc (opens new window)
    • HowToStartOpenSource (opens new window)
    • vdoing-template (opens new window)
GitHub (opens new window)
  • 最佳实践

  • 迎刃而解

  • Nginx

  • Php

  • Zabbix

  • AWS

  • Prometheus

  • Grafana

  • Loki

  • CentOS

    • Linux好用命令之w命令
    • Linux好用命令之top命令
      • 1,执行。
      • 2,进入详解。
        • 1,top 命令的结果分为两个部分。
        • 2,统计信息说明。
        • 3,进程信息。
      • 3,top 命令选项。
      • 4,top 命令交互
    • Linux好用命令之free命令
    • Linux好用命令之lsof命令
    • Linux好用命令之expect命令
    • Linux好用命令之gzip保留原文件解压缩
    • Linux好用命令之dig命令
    • Linux好用命令之rsync命令
    • Linux好用命令之curl劫持请求的三种方式
    • Linux好用命令之base64命令
    • Linux好用命令之figlet命令
    • Linux好用命令之watch命令
    • 使用trash-cli给Linux服务器加一个回收站的功能
    • CentOS-7中tmp目录的清理规则
    • 用yum的方式快速安装lnmp环境(MySQL5-5&5-7,php5-x&7-x)
    • CentOS系统里TCP状态中TIME_WAIT超过3万的分析与建议
    • CentOS-7如何释放主机根分区的磁盘空间
    • 实践一次抓包看到TCP的三次握手与四次挥手及其他
    • CentOS-arm架构下安装docker
    • Logrotate入门了解及生产实践
    • 为什么不建议Linux用root登陆或启动服务
  • Supervisord

  • Systemd

  • Docker

  • Docker-Compose

  • Rancher

  • Ansible

  • OpenLdap

  • GitLab

  • GitHub

  • Etcd

  • Consul

  • RabbitMQ

  • Kafka

  • Mysql

  • MongoDB

  • OpenVPN

  • Kvm

  • VMware

  • 配置文件详解

  • Other

  • 运维观止
  • CentOS
二丫讲梵
2020-10-24
目录

Linux好用命令之top命令

文章发布较早,内容可能过时,阅读注意甄别。

top 命令是 Linux 下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,常用于服务端性能分析。

# 1,执行。

[root@fbtest4 ~]# top
top - 17:56:13 up 161 days,  3:11,  3 users,  load average: 0.23, 0.37, 0.18
Tasks: 129 total,   1 running, 128 sleeping,   0 stopped,   0 zombie
Cpu(s):  0.7%us,  0.5%sy,  0.0%ni, 98.3%id,  0.2%wa,  0.2%hi,  0.2%si,  0.0%st
Mem:   3924744k total,  3164944k used,   759800k free,   183256k buffers
Swap:  6291452k total,   545464k used,  5745988k free,   965616k cached
  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND
12991 root      20   0 3521m 486m  13m S  1.0 12.7   2:07.28 java
 5521 zabbix    20   0 79548 1140 1032 S  0.3  0.0   3:41.13 zabbix_agentd
10595 root      20   0 1428m 7052 2324 S  0.3  0.2  37:49.02 agentWorker
12291 nobody    20   0 60316  12m 2104 S  0.3  0.3   1:12.91 nginx
17913 root      20   0 3793m 689m  11m S  0.3 18.0  14:35.05 java
    1 root      20   0 19232  668  528 S  0.0  0.0   0:02.70 init
    2 root      20   0     0    0    0 S  0.0  0.0   0:00.00 kthreadd
    3 root      RT   0     0    0    0 S  0.0  0.0   1:36.53 migration/0
    4 root      20   0     0    0    0 S  0.0  0.0   1:59.82 ksoftirqd/0
    5 root      RT   0     0    0    0 S  0.0  0.0   0:00.00 stopper/0
    6 root      RT   0     0    0    0 S  0.0  0.0   0:31.77 watchdog/0
    7 root      RT   0     0    0    0 S  0.0  0.0   1:14.78 migration/1
    8 root      RT   0     0    0    0 S  0.0  0.0   0:00.00 stopper/1
    9 root      20   0     0    0    0 S  0.0  0.0   1:48.74 ksoftirqd/1
   10 root      RT   0     0    0    0 S  0.0  0.0   0:20.99 watchdog/1
   11 root      20   0     0    0    0 S  0.0  0.0  13:29.31 events/0
   12 root      20   0     0    0    0 S  0.0  0.0  22:37.27 events/1
   13 root      20   0     0    0    0 S  0.0  0.0   0:00.00 cgroup
   14 root      20   0     0    0    0 S  0.0  0.0   0:00.00 khelper
   15 root      20   0     0    0    0 S  0.0  0.0   0:00.00 netns
   16 root      20   0     0    0    0 S  0.0  0.0   0:00.00 async/mgr
   17 root      20   0     0    0    0 S  0.0  0.0   0:00.00 pm
   18 root      20   0     0    0    0 S  0.0  0.0   0:45.72 sync_supers
   19 root      20   0     0    0    0 S  0.0  0.0   1:01.11 bdi-default
   20 root      20   0     0    0    0 S  0.0  0.0   0:00.00 kintegrityd/0
   21 root      20   0     0    0    0 S  0.0  0.0   0:00.00 kintegrityd/1
   22 root      20   0     0    0    0 S  0.0  0.0  53:51.93 kblockd/0
   23 root      20   0     0    0    0 S  0.0  0.0   7:06.67 kblockd/1
   24 root      20   0     0    0    0 S  0.0  0.0   0:00.00 kacpid
   25 root      20   0     0    0    0 S  0.0  0.0   0:00.00 kacpi_notify
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37

# 2,进入详解。

# 1,top 命令的结果分为两个部分。

  • 统计信息:前五行是系统整体的统计信息;
  • 进程信息:统计信息下方类似表格区域显示的是各个进程的详细信息,默认 5 秒刷新一次。

# 2,统计信息说明。

  • 第 1 行:Top 任务队列信息(系统运行状态及平均负载),与 uptime 命令结果相同。
    • 第 1 列:系统当前时间,例如:16:07:37
    • 第 2 列:系统运行时间,未重启的时间,时间越长系统越稳定。
    • 格式:up xx days, HH:MM
    • 例如:241 days, 20:11, 表示连续运行了 241 天 20 小时 11 分钟
    • 第 3 列:当前登录用户数,例如:1 user,表示当前只有 1 个用户登录
    • 第 4 列:系统负载,即任务队列的平均长度,3 个数值分别统计最近 1,5,15 分钟的系统平均负载
    • 系统平均负载:单核 CPU 情况下,0.00 表示没有任何负荷,1.00 表示刚好满负荷,超过 1 侧表示超负荷,理想值是 0.7;
    • 多核 CPU 负载:CPU 核数 * 理想值 0.7 = 理想负荷,例如:4 核 CPU 负载不超过 2.8 何表示没有出现高负载。
  • 第 2 行:Tasks 进程相关信息
    • 第 1 列:进程总数,例如:Tasks: 231 total, 表示总共运行 231 个进程
    • 第 2 列:正在运行的进程数,例如:1 running,
    • 第 3 列:睡眠的进程数,例如:230 sleeping,
    • 第 4 列:停止的进程数,例如:0 stopped,
    • 第 5 列:僵尸进程数,例如:0 zombie
  • 第 3 行:Cpus CPU 相关信息,如果是多核 CPU,按数字 1 可显示各核 CPU 信息,此时 1 行将转为 Cpu 核数行,数字 1 可以来回切换。
    • 第 1 列:us 用户空间占用 CPU 百分比,例如:Cpu(s): 12.7%us,
    • 第 2 列:sy 内核空间占用 CPU 百分比,例如:8.4%sy,
    • 第 3 列:ni 用户进程空间内改变过优先级的进程占用 CPU 百分比,例如:0.0%ni,
    • 第 4 列:id 空闲 CPU 百分比,例如:77.1%id,
    • 第 5 列:wa 等待输入输出的 CPU 时间百分比,例如:0.0%wa,
    • 第 6 列:hi CPU 服务于硬件中断所耗费的时间总额,例如:0.0%hi,
    • 第 7 列:si CPU 服务软中断所耗费的时间总额,例如:1.8%si,
    • 第 8 列:st Steal time 虚拟机被 hypervisor 偷去的 CPU 时间(如果当前处于一个 hypervisor 下的 vm,实际上 hypervisor 也是要消耗一部分 CPU 处理时间的)
  • 第 4 行:Mem 内存相关信息(Mem: 12196436k total, 12056552k used, 139884k free, 64564k buffers)
    • 第 1 列:物理内存总量,例如:Mem: 12196436k total,
    • 第 2 列:使用的物理内存总量,例如:12056552k used,
    • 第 3 列:空闲内存总量,例如:Mem: 139884k free,
    • 第 4 列:用作内核缓存的内存量,例如:64564k buffers
  • 第 5 行:Swap 交换分区相关信息(Swap: 2097144k total, 151016k used, 1946128k free, 3120236k cached)
    • 第 1 列:交换区总量,例如:Swap: 2097144k total,
    • 第 2 列:使用的交换区总量,例如:151016k used,
    • 第 3 列:空闲交换区总量,例如:1946128k free,
    • 第 4 列:缓冲的交换区总量,3120236k cached

img

# 3,进程信息。

在 top 命令中按 f 按可以查看显示的列信息,按对应字母来开启/关闭列,大写字母表示开启,小写字母表示关闭。带*号的是默认列。

  • A: PID = (Process Id) 进程 Id;
  • E: USER = (User Name) 进程所有者的用户名;
  • H: PR = (Priority) 优先级
  • I: NI = (Nice value) nice 值。负值表示高优先级,正值表示低优先级
  • O: VIRT = (Virtual Image (kb)) 进程使用的虚拟内存总量,单位 kb。VIRT=SWAP+RES
  • Q: RES = (Resident size (kb)) 进程使用的、未被换出的物理内存大小,单位 kb。RES=CODE+DATA
  • T: SHR = (Shared Mem size (kb)) 共享内存大小,单位 kb
  • W: S = (Process Status) 进程状态。D=不可中断的睡眠状态,R=运行,S=睡眠,T=跟踪/停止,Z=僵尸进程
  • K: %CPU = (CPU usage) 上次更新到现在的 CPU 时间占用百分比
  • N: %MEM = (Memory usage (RES)) 进程使用的物理内存百分比
  • M: TIME+ = (CPU Time, hundredths) 进程使用的 CPU 时间总计,单位 1/100 秒
  • b: PPID = (Parent Process Pid) 父进程 Id
  • c: RUSER = (Real user name)
  • d: UID = (User Id) 进程所有者的用户 id
  • f: GROUP = (Group Name) 进程所有者的组名
  • g: TTY = (Controlling Tty) 启动进程的终端名。不是从终端启动的进程则显示为 ?
  • j: P = (Last used cpu (SMP)) 最后使用的 CPU,仅在多 CPU 环境下有意义
  • p: SWAP = (Swapped size (kb)) 进程使用的虚拟内存中,被换出的大小,单位 kb
  • l: TIME = (CPU Time) 进程使用的 CPU 时间总计,单位秒
  • r: CODE = (Code size (kb)) 可执行代码占用的物理内存大小,单位 kb
  • s: DATA = (Data+Stack size (kb)) 可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位 kb
  • u: nFLT = (Page Fault count) 页面错误次数
  • v: nDRT = (Dirty Pages count) 最后一次写入到现在,被修改过的页面数
  • y: WCHAN = (Sleeping in Function) 若该进程在睡眠,则显示睡眠中的系统函数名
  • z: Flags = (Task Flags <sched.h>) 任务标志,参考 sched.h
  • X: COMMAND = (Command name/line) 命令名/命令行

# 3,top 命令选项。

  • -b:以批处理模式操作;
  • -c:显示完整的治命令;
  • -d:屏幕刷新间隔时间;
  • -I:忽略失效过程;
  • -s:保密模式;
  • -S:累积模式;
  • -i<时间>:设置间隔时间;
  • -u<用户名>:指定用户名;
  • -p<进程号>:指定进程;
  • -n<次数>:循环显示的次数。

# 4,top 命令交互

  • 常用交互操作
    • 基础操作
      • 1:显示 CPU 详细信息,每核显示一行
      • d / s :修改刷新频率,单位为秒
      • h:可显示帮助界面
      • n:指定进程列表显示行数,默认为满屏行数
      • q:退出 top
    • 面板隐藏显示
      • l:隐藏/显示第 1 行负载信息;
      • t:隐藏/显示第 2~3 行 CPU 信息;
      • m:隐藏/显示第 4~5 行内存信息;
    • 进程列表排序
      • M:根据驻留内存大小进行排序;
      • P:根据 CPU 使用百分比大小进行排序;
      • T:根据时间/累计时间进行排序;
  • 详细交互指令:h / ? 可显示帮助界面,原始为英文版,简单翻译如下:
Help for Interactive Commands - procps version 3.2.8
Window 1:Def: Cumulative mode Off.  System: Delay 3.0 secs; Secure mode Off.
  Z,B       Global: 'Z' change color mappings; 'B' disable/enable bold
            Z:修改颜色配置;B:关闭/开启粗体
  l,t,m     Toggle Summaries: 'l' load avg; 't' task/cpu stats; 'm' mem info
            l:隐藏/显示第1行负载信息;t:隐藏/显示第2~3行CPU信息;m:隐藏/显示第4~5行内存信息;
  1,I       Toggle SMP view: '1' single/separate states; 'I' Irix/Solaris mode
            1:单行/多行显示CPU信息;I:Irix/Solaris模式切换
  f,o     . Fields/Columns: 'f' add or remove; 'o' change display order
            f:列显示控制;o:列排序控制,按字母进行调整
  F or O  . Select sort field  选择排序列
  <,>     . Move sort field: '<' next col left; '>' next col right 上下移动内容
  R,H     . Toggle: 'R' normal/reverse sort; 'H' show threads
            R:内容排序;H:显示线程
  c,i,S   . Toggle: 'c' cmd name/line; 'i' idle tasks; 'S' cumulative time
            c:COMMAND列命令名称与完整命令行路径切换;i:忽略闲置和僵死进程开关;S:累计模式切换
  x,y     . Toggle highlights: 'x' sort field; 'y' running tasks
            x:列排序;y:运行任务
  z,b     . Toggle: 'z' color/mono; 'b' bold/reverse (only if 'x' or 'y')
            z:颜色模式;b:粗体开关 仅适用于x,y模式中
  u       . Show specific user only 按用户进行过滤,当输入错误可按Ctrl + Backspace进行删除
  n or #  . Set maximum tasks displayed 设置进程最大显示条数
  k,r       Manipulate tasks: 'k' kill; 'r' renice
            k:终止一个进程;r:重新设置一个进程的优先级别
  d or s    Set update interval  改变两次刷新之间的延迟时间(单位为s),如果有小数,就换算成ms。输入0值则系统将不断刷新,默认值是5s;
  W         Write configuration file 将当前设置写入~/.toprc文件中
  q         Quit       退出
          ( commands shown with '.' require a visible task display window )
            注意:带.的命令需要一个可见的任务显示窗口
Press 'h' or '?' for help with Windows, any other key to continue
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
微信 支付宝
#centos#linux
上次更新: 2024/07/04, 22:40:37
Linux好用命令之w命令
Linux好用命令之free命令

← Linux好用命令之w命令 Linux好用命令之free命令→

最近更新
01
睡着的人不关灯
06-12
02
学习周刊-总第215期-2025年第24周
06-12
03
学习周刊-总第214期-2025年第23周
06-05
更多文章>
Theme by Vdoing | Copyright © 2017-2025 | 点击查看十年之约 | 浙ICP备18057030号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式