Linux中强大的top命令
top命令算是最直观、好用的查看服务器负载的命令了。它实时动态刷新显示服务器状态信息,且可以通过交互式命令自定义显示内容,非常强大。
在终端中输入top,回车后会显示如下内容:
top - 21:48:39 up 8:57, 2 users, load average: 0.36, 0.24, 0.14Tasks: 322 total, 2 running, 320 sleeping, 0 stopped, 0 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 stKiB Mem: 1010504 total, 937416 used, 73088 free, 23708 buffersKiB Swap: 1046524 total, 280708 used, 765816 free. 365556 cached MemPID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND8096 root 20 0 320624 38508 21192 S 1.7 3.8 0:41.03 Xorg13536 tabalt 20 0 697336 104272 56776 S 1.7 10.3 0:08.29 gnome-langu+9426 tabalt 20 0 1213228 72976 16860 S 1.0 7.2 2:07.27 compiz197 root 20 0 0 0 0 S 0.3 0.0 0:36.13 kworker/0:21009 root 20 0 303112 3392 1500 S 0.3 0.3 0:00.93 polkitd9670 tabalt 20 0 325932 4300 2256 S 0.3 0.4 0:40.27 vmtoolsd14016 root 25 5 43940 2408 2000 S 0.3 0.2 0:01.12 http14149 tabalt 20 0 591180 19504 12820 S 0.3 1.9 0:00.45 gnome-termi+1 root 20 0 33648 1972 744 S 0.0 0.2 0:01.79 init2 root 20 0 0 0 0 S 0.0 0.0 0:00.00 kthreadd3 root 20 0 0 0 0 S 0.0 0.0 0:02.80 ksoftirqd/04 root 20 0 0 0 0 S 0.0 0.0 0:00.00 kworker/0:05 root 0 -20 0 0 0 S 0.0 0.0 0:00.00 kworker/0:0H7 root 20 0 0 0 0 S 0.0 0.0 0:05.55 rcu_sched8 root 20 0 0 0 0 R 0.0 0.0 0:03.43 rcuos/09 root 20 0 0 0 0 S 0.0 0.0 0:00.00 rcuos/110 root 20 0 0 0 0 S 0.0 0.0 0:00.00 rcuos/2
一、系统信息统计
前五行是系统整体状态的统计信息展示区域。下面分别介绍每一行中的内容:
1、第一行显示服务器概况
如下所示,第一行列出了服务器运行了多长时间,当前有多少个用户登录,服务器的负荷情况等,使用uptime命令能获得同样的结果。
top - 21:48:39 up 8:57, 2 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。
可以使用如下命令来查看每个处理器的信息:
cat /proc/cpuinfo
如果只想计算有多少个cpu内核,可以使用如下命令:
cat /proc/cpuinfo | grep 'model name' | wc -l
2、第二行是进程信息:
- Tasks: 322 total, 2 running, 320 sleeping, 0 stopped, 0 zombie
- / / / / /
- 进程总数 正运行进程数 睡眠进程数 停止进程数 僵尸进程数
3、第三行是CPU信息:
- %Cpu(s):
- 5.0 us 用户空间CPU占比
- 1.7 sy 内核空间CPU占比
- 0.0 ni 用户进程空间改过优先级的进程CPU占比
- 93.0 id 空闲CPU占比
- 0.0 wa 待输入输出CPU占比
- 0.3 hi 硬中断(Hardware IRQ)CPU占比
- 0.0 si 软中断(Software Interrupts)CPU占比
- 0.0 st -
4、第四行是内存信息:
- KiB Mem: 1010504 total, 937416 used, 73088 free, 23708 buffers
- / / / /
- 物理内存总量 使用中总量 空闲总量 缓存的内存量
5、第五行是swap交换分区信息:
- KiB Swap: 1046524 total, 280708 used, 765816 free, 365556 cached Mem
- / / / /
- 交换区总量 使用中总量 空闲总量 缓存的内存量
二、进程(任务)状态监控
第七行及以下显示了各进程(任务)的状态监控。各列所代表的含义如下:
- 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交互
按键
b打开或关闭 运行中进程的高亮效果按键
x打开或关闭 排序列的高亮效果shift + >或shift + <可以向右或左改变排序列f键,可以进入编辑要显示字段的视图,有 * 号的字段会显示,无 * 号不显示,可根据页面提示选择或取消字段。- https://blog.csdn.net/heybob/article/details/52032829
Linux中强大的top命令的更多相关文章
- [转]linux中强大的screen命令
[转]linux中强大的screen命令 http://pythonorg.diandian.com/post/2012-01-05/40027464147 今天用SCREEN用点生了,有几个功能不知 ...
- [转帖]「日常小记」linux中强大且常用命令:find、grep
「日常小记」linux中强大且常用命令:find.grep https://zhuanlan.zhihu.com/p/74379265 在linux下面工作,有些命令能够大大提高效率.本文就向大家介绍 ...
- 【日常小记】linux中强大且常用命令:find、grep【转】
转自:http://www.cnblogs.com/skynet/archive/2010/12/25/1916873.html 在linux下面工作,有些命令能够大大提高效率.本文就向大家介绍fin ...
- Linux 中强大且常用命令:find、grep
在linux下面工作,有些命令能够大大提高效率.本文就向大家介绍find.grep命令,他哥俩可以算是必会的linux命令,我几乎每天都要用到他们.本文结构如下: find命令 f ...
- 【转载】Linux中强大且常用命令:find、grep
转载自:http://www.linuxeden.com/html/softuse/20130804/142065.html 在linux下面工作,有些命令能够大大提高效率.本文就向大家介绍find. ...
- linux中强大且常用命令:find、grep
在linux下面工作,有些命令能够大大提高效率.本文就向大家介绍find.grep命令,他哥俩可以算是必会的linux命令,我几乎每天都要用到他们. 本文结构如下: find命令 find命令的一般形 ...
- linux中强大的screen命令
今天发现了一个“宝贝”,就是Linux的screen命令,对于远程登录来说,不仅提供了类似于nohup的功能,而且提供了我非常喜欢的“多个桌面”的功能. 平常开一个putty远程登录,经常需要在两个程 ...
- Linux中find、grep命令详细用法
在linux下面工作,有些命令能够大大提高效率.本文就向大家介绍find.grep命令,他哥俩可以算是必会的linux命令,我几乎每天都要用到他们.本文结构如下: find命令 find命令的一般形式 ...
- linux分析工具之top命令详解
Linux系统可以通过top命令查看系统的CPU.内存.运行时间.交换分区.执行的线程等信息.通过top命令可以有效的发现系统的缺陷出在哪里.是内存不够.CPU处理能力不够.IO读写过高. 一.top ...
随机推荐
- dubbo和mq的使用场景
MQ:消息队列.生产者消费者模式,可用于对消息实时性要求不高的场景.多进程之间间接调用关系 Dubbo:RPC实现.多进程之间直接调用关系 dubbo 1,rpc的分布式集群支持:负载均衡是对外提供一 ...
- Java中关于String类型的一些思考
作为初学者在学习Java的时候,变量类型是不可避免会遇到的,在以往我们的印象中字符串String都是作为基本类型而存在的,但是在Java中String类型确是一个实实在在的引用类型,是可以通过new关 ...
- dstat 监控工具
dstat 监控工具 Linux 自带的监控工具.界面相当友好,可以替代其他的监控工具. 安装 yum install -y dstat 命令使用 dstat -h # 帮助 dstat -tpcdr ...
- java.lang.NoClassDefFoundError: Could not initialize class xxx
感慨:啊啊啊啊啊啊啊啊啊啊,这个问题弄了我好久,整整一天!!! 概述:原本是调用公司自己写的jar包的工具类.在其他项目都能调用,一模一样的套用过来就是不行.问了一些同事他们也不知道怎么解决. 然后百 ...
- 【OF框架】缓存Session/Cookies/Cache代码调用api,切换缓存到Redis
准备 缓存服务在应用开发中最常用的功能,特别是Session和Cookies,Cache部分业务开发过程会使用到. 在负载均衡环境下,缓存服务需要存储到服务器. 缓存默认实现在内存在,可以通过配置切换 ...
- Java学习笔记——第1篇
Java程序运行机制 Java程序要经过先编译,后解释两个步骤 编译型:高级语言源码 -->机器码(一次性) 生成可执行程序,脱离开发环境,在指定平台上运行.(C/C++/Objectiv ...
- vue---子调父 $emit (把子组件的数据传给父组件)
ps:App.vue 父组件 Hello.vue 子组件 ps:App.vue 父组件 Hello.vue 子组件 <!--App.vue :--> <template> & ...
- 神经网络(1)--Non-linear hypotheses,为什么我们要学习神经网络这种算法来处理non-linear hypotheses
神经网络(1)--No-linear hypotheses 为什么我们已经有了linear regression与logistic regression算法还要来学习神经网络这个另外的算法呢,让我们来 ...
- 2019-2020-1 20199312《Linux内核原理与分析》第二周作业
c语言代码 // main.c int g(int x) { return x + 4; } int f(int x) { return g(x); } int main(void) { return ...
- BZOJ 3698: XWW的难题(有源汇上下界最大流)
题面 XWW是个影响力很大的人,他有很多的追随者.这些追随者都想要加入XWW教成为XWW的教徒.但是这并不容易,需要通过XWW的考核. XWW给你出了这么一个难题:XWW给你一个N*N的正实数矩阵A, ...