一、概念
Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,且可以通过交互式命令自定义显示内容,类似于Windows的任务管理器.

二、命令格式

[root@PCS101 logs]# top
top - :: up :, users, load average: 0.36, 0.24, 0.14
Tasks: total, running, sleeping, stopped, zombie
%Cpu(s): 5.0 us, 1.7 sy, 0.0 ni, 93.0 id, 0.0 wa, 0.3 hi, 0.0 si, 0.0 st
KiB Mem: total, used, free, buffers
KiB Swap: total, used, free. cached Mem PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
root S 1.7 3.8 :41.03 Xorg
tabalt S 1.7 10.3 :08.29 gnome-langu+
tabalt S 1.0 7.2 :07.27 compiz
root S 0.3 0.0 :36.13 kworker/:
root S 0.3 0.3 :00.93 polkitd
tabalt S 0.3 0.4 :40.27 vmtoolsd
root S 0.3 0.2 :01.12 http
tabalt S 0.3 1.9 :00.45 gnome-termi+
root S 0.0 0.2 :01.79 init
root S 0.0 0.0 :00.00 kthreadd
root S 0.0 0.0 :02.80 ksoftirqd/
root S 0.0 0.0 :00.00 kworker/:
root - S 0.0 0.0 :00.00 kworker/:0H
root S 0.0 0.0 :05.55 rcu_sched
root R 0.0 0.0 :03.43 rcuos/
root S 0.0 0.0 :00.00 rcuos/
root S 0.0 0.0 :00.00 rcuos/

1、系统信息统计

前五行是系统整体状态的统计信息展示区域。

(1)第一行显示服务器概况
如下所示,第一行列出了服务器运行了多长时间,当前有多少个用户登录,服务器的负荷情况等,使用uptime命令能获得同样的结果。

top - :: up  :,   users,  load average: 0.36, 0.24, 0.14
/ / / \
系统时间 运行时长 当前登录用户数 平均负载(1分钟、5分钟、15分钟)

平均负载的值越小代表系统压力越小,越大则代表系统压力越大。通常,我们会以最后一个数值,也就是15分钟内的平均负载作为参考来评估系统的负载情况。

对于只有单核cpu的系统,1.0是该系统所能承受负荷的边界值,大于1.0则有处理需要等待。
一个单核cpu的系统,平均负载的合适值是0.7以下。如果负载长期徘徊在1.0,则需要考虑马上处理了。超过1.0的负载,可能会带来非常严重的后果。
当然,多核cpu的系统是在前述值的基础上乘以cpu内核的个数。如对于多核cpu的系统,有N个核则所能承受的边界值为N.0。
load average数据是每隔5秒钟检查一次活跃的进程数,然后按特定算法计算出的数值。如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。

可以使用如下命令来查看每个处理器的信息:

cat /proc/cpuinfo

如果只想计算有多少个cpu内核,可以使用如下命令:

cat /proc/cpuinfo | grep 'model name' | wc -l

(2)第二行是进程信息:

Tasks:  total,    running,  sleeping,    stopped,    zombie
/ / / / /
进程总数 正运行进程数 睡眠进程数 停止进程数 僵尸进程数

(3)第三行是CPU信息:

%Cpu(s):
5.0 us 用户空间CPU占比
1.7 sy 内核空间CPU占比
0.0 ni 用户进程空间改过优先级的进程CPU占比
93.0 id 空闲CPU占比
0.0 wa IO等待占用CPU的百分比
0.3 hi 硬中断(Hardware IRQ)CPU占比
0.0 si 软中断(Software Interrupts)CPU占比
0.0 st -

(4)第四行是内存信息:

KiB Mem:    total,    used,     free,     buffers
/ / / /
物理内存总量 使用中总量 空闲总量 缓存的内存量

(5)第五行是swap交换分区信息:

KiB Swap:   total,    used,    free,    cached Mem
/ / / /
交换区总量 使用中总量 空闲总量 缓存的内存量

可用内存=free + buffer + cached

对于内存监控,在top里我们要时刻监控第五行swap交换分区的used,如果这个数值在不断的变化,说明内核在不断进行内存和swap的数据交换,这是真正的内存不够用了。
第四行中使用中的内存总量(used)指的是现在系统内核控制的内存数,
第四行中空闲内存总量(free)是内核还未纳入其管控范围的数量。
纳入内核管理的内存不见得都在使用中,还包括过去使用过的现在可以被重复利用的内存,内核并不把这些可被重新使用的内存交还到free中去,因此在linux上free内存会越来越少,但不用为此担心。

2、进程(任务)状态监控
第七行及以下显示了各进程(任务)的状态监控。各列所代表的含义如下:

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秒
COMMAND 进程名称(命令名/命令行)

三、top交互命令

[Space] 立即刷新显示
[c] 切换显示命令名称和完整命令行
[h] 显示帮助画面,给出一些简短的命令总结说明
[q] 退出程序
[k] 杀死某进程。你会被提示输入进程 ID 以及要发送给它的信号。
[n] 改变显示的进程数量。你会被提示输入数量。
[] 多核cpu分开显示 排序
[u] 按用户排序。
[M] 根据驻留内存大小进行排序
[P] 根据CPU使用百分比大小进行排序
[T] 根据时间/累计时间进行排序
[o]或者[O] 改变显示项目的顺序
[r] 重新安排一个进程的优先级别
[s] 改变两次刷新之间的延迟时间(单位为s)
[f]或者[F] 从当前显示中添加或者删除项目
[S] 切换到累计模式
[l] 切换显示平均负载和启动时间信息
[m] 切换显示内存信息
[t] 切换显示进程和CPU状态信息
[i] 忽略闲置和僵死进程。这是一个开关式命令。
[W] 将当前设置写入~/.toprc文件中

【操作系统之八】Linux常用命令之top的更多相关文章

  1. linux常用命令:top 命令

    top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器.下面详细介绍它的使用方法.top是 一个动态显示过程,即可以通过用户按键来不断刷 ...

  2. linux操作系统2 linux常用命令

    知识内容: 1.目录及文件操作 2.用户.群组与权限 3.重定向.管道 4.磁盘存储管理 5.系统命令 6.其他命令 参考: http://man.linuxde.net/ Linux命令规则:目录名 ...

  3. 吴裕雄--天生自然Linux操作系统:Linux常用命令大全

    系统信息 arch 显示机器的处理器架构 uname -m 显示机器的处理器架构 uname -r 显示正在使用的内核版本 dmidecode -q 显示硬件系统部件 - (SMBIOS / DMI) ...

  4. Linux常用命令 - top命令详解(重点)

    21篇测试必备的Linux常用命令,每天敲一篇,每次敲三遍,每月一循环,全都可记住!! https://www.cnblogs.com/poloyy/category/1672457.html top ...

  5. [置顶] linux常用命令手册

    前言:整理了一份linux常用命令手册,与大家分享.这是一些比较常用的命令. 我已经整理成一份PDF带书签的手册,可以到CSDN免费下载. 下载地址:http://download.csdn.net/ ...

  6. linux常用命令 、查看日志、web排查

    linux常用命令 ps aux|grep xxx (比如 ps aux|grep tomcat ps aux|grep tomcat-portalvip ps aux|grep nginx 等) r ...

  7. linux常用命令和关闭防火墙

    linux常用命令和关闭防火墙   2.        linux常用命令 Mkdir 创建 Rm -rf 删除 Chmod -R 777 权限 Mysql -uroot -r quit退出 find ...

  8. 教老婆学Linux运维(二)Linux常用命令指南【下】

    目录 tips:紧接上一篇,Linux常用命令指南[上] 2.4 文件解压缩 2.4.1 官宣的linux压缩工具:tar tar的基本命令格式为 tar [参数选项] [文件或目录] 我们前面学的命 ...

  9. linux学习(4):linux常用命令(50个)

    linux常用命令(50个) 1. find 基本语法参数如下: find [PATH] [option] [action] # 与时间有关的参数: -mtime n : n为数字,意思为在n天之前的 ...

随机推荐

  1. Python学习笔记之使用 python -m SimpleHTTPServer 快速搭建http服务

    0x00 概述 搭建FTP,或者是搭建网络文件系统,这些方法都能够实现Linux的目录共享.但是FTP和网络文件系统的功能都过于强大,因此它们都有一些不够方便的地方.比如你想快速共享Linux系统的某 ...

  2. .net架构的浅谈

    ,net的架构有以下几种 1.两层架构:UI + 数据层 2.三层架构:UI + 业务层 + 数据层 3.三层 + 接口层 (把相关的业务层抽象成接口,下层来实现接口,中层是依赖) 4.三层 + 接口 ...

  3. NetCoreApi框架搭建三、JWT授权验证)

    1.首先还是粘贴大神的链接 虽然说大神的博客已经讲得很详细了,但是此处还是自己动手好点. 首先配置Startup Swagger的验证 2.新建一个项目存放tokenmodel和生成token并且存入 ...

  4. Service Mesh服务网格新生代--Istio

    原文: 数人云|万字解读:Service Mesh服务网格新生代--Istio 参考: istio 简介 Istio是啥?一文带你彻底了解! 使用Istio治理微服务入门 Istio 流量管理 ist ...

  5. cs1.6 人物地址查询

    打开游戏 控制台命令 增加一个BOT:bot_add 增加一个警察:bot_add_ct 增加一个匪徒:bot_add_t 让BOT站在原地不动:bot_stop 1 "-"减号: ...

  6. 更改用户host留下的坑

    前言:  我们在创建数据库用户的时候都会指定host,即一个完整的用户可描述为 'username'@'host' .创建用户时不显式指定host则默认为%,%代表所有ip段都可以使用这个用户,我们也 ...

  7. ARM开发板上查看动态库或者可执行程序的依赖关系

    以ARM32开发板为例,在/lib下有一个名为ld-linux-armhf.so.3的可执行程序(在ARM64开发板上是/lib/ld-linux-aarch64.so.1),这个程序负责加载可执行程 ...

  8. Makefile 基础语法

    1.. specify the directores , i not specified , search current directory put every folder into a list ...

  9. MATLAB之心形图绘制

    一.静态心形图绘制 (1)效果展示 (2)静态心形原始代码 clc; clear all; ; % 均布三位坐标 x=-:; y=-:; z=-:; [x,y,z]=meshgrid(x,y,z); ...

  10. httprunner学习25-文件上传multipart/form-data

    前言 httprunner上传文件接口,其实跟requests上传文件的接口是一样的,之前在python接口系列里面有案例 python接口自动化16-multipart/form-data上传图片 ...