linux下top命令详解
top - 17:32:34 up 3 days, 8:04, 5 users, load average: 0.09, 0.12, 0.19 Tasks: 287 total, 2 running, 285 sleeping, 0 stopped, 0 zombie %Cpu(s): 1.5 us, 0.9 sy, 0.0 ni, 97.5 id, 0.2 wa, 0.0 hi, 0.0 si, 0.0 st KiB Mem: 8053444 total, 7779224 used, 274220 free, 359212 buffers KiB Swap: 8265724 total, 33840 used, 8231884 free. 4358088 cached Mem PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 21471 ruanyang 20 0 2010136 710056 110396 S 3.7 8.8 187:52.22 firefox 2880 ruanyang 20 0 606996 48216 27980 S 2.3 0.6 5:32.19 gnome-terminal 1286 root 20 0 1023628 349492 295740 S 2.0 4.3 62:20.58 Xorg 2391 ruanyang 20 0 1664980 274936 74188 S 1.0 3.4 49:28.57 compiz 2157 ruanyang 20 0 40540 3896 2148 S 0.3 0.0 0:51.26 dbus-daemon 2253 ruanyang 20 0 596964 51856 25788 S 0.3 0.6 1:06.54 unity-panel-ser 2343 ruanyang 20 0 286756 10704 7516 S 0.3 0.1 0:13.33 indicator-appli
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
首先,我们将它的结果分为两大区域统计信息区和进程信息区
统计信息区
第一行:任务队列信息,与uptime命令执行结果相同。
- 17:32:34:系统当前时间
- up 3 days, 8:04:主机已运行时间
- 5 users:用户连接数(不是用户数,who命令)
- load average: 0.09, 0.12, 0.19:系统平均负载,统计最近1,5,15分钟的系统平均负载
补充:uptime -V可查询版本
第二行:进程信息
- Tasks: 287 total:进程总数
- 2 running:正在运行的进程数
- 285 sleeping:睡眠的进程数
- 0 stopped:停止的进程数
- 0 zombie:僵尸进程数
第三行:CPU信息(当有多个CPU时,这些内容可能会超过两行)
- 1.5 us:用户空间所占CPU百分比
- 0.9 sy:内核空间占用CPU百分比
- 0.0 ni:用户进程空间内改变过优先级的进程占用CPU百分比
- 97.5 id:空闲CPU百分比
- 0.2 wa:等待输入输出的CPU时间百分比
- 0.0 hi:硬件CPU中断占用百分比
- 0.0 si:软中断占用百分比
- 0.0 st:虚拟机占用百分比
第四行:内存信息(与第五行的信息类似与free命令)
- 8053444 total:物理内存总量
- 7779224 used:已使用的内存总量
- 274220 free:空闲的内存总量(free+used=total)
- 359212 buffers:用作内核缓存的内存量
第五行:swap信息
- 8265724 total:交换分区总量
- 33840 used:已使用的交换分区总量
- 8231884 free:空闲交换区总量
- 4358088 cached
Mem:缓冲的交换区总量,内存中的内容被换出到交换区,然后又被换入到内存,但是使用过的交换区没有被覆盖,交换区的这些内容已存在于内存中的交换区的大小,相应的内存再次被换出时可不必再对交换区写入。
进程信息区
- PID:进程id
- PPID:父进程id
- RUSER:Real user name(看了好多,都是这样写,也不知道和user有什么区别,欢迎补充此处)
- UID:进程所有者的id
- USER:进程所有者的用户名
- GROUP:进程所有者的组名
- TTY:启动进程的终端名。不是从终端启动的进程则显示为?
- PR:优先级
- NI:nice值。负值表示高优先级,正值表示低优先级
- P:最后使用的CPU,仅在多CPU环境下有意义
- %CPU:上次更新到现在的CPU时间占用百分比
- TIME:进程使用的CPU时间总计,单位秒
- TIME+:进程所使用的CPU时间总计,单位1/100秒
- %MEM:进程使用的物理内存百分比
- VIRT:进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
- SWAP:进程使用的虚拟内存中被被换出的大小
- RES:进程使用的、未被换出的物理内存的大小
- CODE:可执行代码占用的物理内存大小
- DATA:可执行代码以外的部分(数据段+栈)占用的物理内存大小
- SHR:共享内存大小
- nFLT:页面错误次数
- nDRT:最后一次写入到现在,被修改过的页面数
- S:进程状态(D=不可中断的睡眠状态,R=运行,S=睡眠,T=跟踪/停止,Z=僵尸进程)
- COMMAND:命令名/行
- WCHAN:若该进程在睡眠,则显示睡眠中的系统函数名
- Flags:任务标志
默认情况下,只显示比较重要的列,如果想对top的显示做点修改的话,那就继续向下看吧!
top命令的使用
top使用格式
top [-] [d] [p] [q] [c] [C] [S] [s] [n]
- 1
top参数说明
- d: 指定每两次屏幕信息刷新之间的时间间隔。当然用户可以使用s交互命令来改变之。
- p: 通过指定监控进程ID来仅仅监控某个进程的状态。
- q: 该选项将使top没有任何延迟的进行刷新。如果调用程序有超级用户权限,那么top将以尽可能高的优先级运行。
- S: 指定累计模式
- s: 使top命令在安全模式中运行。这将去除交互命令所带来的潜在危险。
- i: 使top不显示任何闲置或者僵死进程。
- c: 显示整个命令行而不只是显示命令名
交互命令
- Ctrl+L: 擦除并且重写屏幕。 h或者?: 显示帮助画面,给出一些简短的命令总结说明。
- k:
终止一个进程。系统将提示用户输入需要终止的进程PID,以及需要发送给该进程什么样的信号。一般的终止进程可以使用15信号;如果不能正常结束那就使用信号9强制结束该进程。默认值是信号15。在安全模式中此命令被屏蔽。 - i: 忽略闲置和僵死进程。这是一个开关式命令。
- q: 退出程序。
- r:
重新安排一个进程的优先级别。系统提示用户输入需要改变的进程PID以及需要设置的进程优先级值。输入一个正值将使优先级降低,反之则可以使该进程拥有更高的优先权。默认值是10。 - S: 切换到累计模式。
- s: 改变两次刷新之间的延迟时间。系统将提示用户输入新的时间,单位为s。如果有小数,就换算成m s。输入0值则系统将不断刷新,默认值是5
s。需要注意的是如果设置太小的时间,很可能会引起不断刷新,从而根本来不及看清显示的情况,而且系统负载也会大大增加。 - f或者F: 从当前显示中添加或者删除项目。
- o或者O: 改变显示项目的顺序。
- l: 切换显示平均负载和启动时间信息。
- m: 切换显示内存信息。
- t: 切换显示进程和CPU状态信息。
- c: 切换显示命令名称和完整命令行。
- M: 根据驻留内存大小进行排序。
- P: 根据CPU使用百分比大小进行排序。
- T: 根据时间/累计时间进行排序。
- W: 将当前设置写入~/.toprc文件中。这是写top配置文件的推荐方法。
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
基于linux下的iscsi网络磁盘共享
iSCSI 主要是通过 TCP/IP 的技术,将储存设备端通过 iSCSI target 功能,做成服务端,再通过 iSCSI initiator (iSCSI 初始化用戶) 功能,做成使用 iSCSI target 的用戶端。 客户端可以通过局域网连接服务器上的iSCSI 服务器,在本地虚拟出一块硬盘,以达到通过网络共享服务器硬盘的效果。 iSCSI target:就是储存设备端,它能够为用户提供可用的存储资源。 iSCSI客户端则是用户使用的软件,用于获取远程服务端的存储资源, 配置服务端 [root@server ~]# yum install targetcli -y //策略编写工具; [root@server ~]# systemctl start target //启动服务 [root@server ~]# fdisk /dev/vdb //建立一个2G普通分区; [root@server ~]# partprobe //刷新 [root@server ~]# targetcli //进入编辑环境: /> /backstores/block creat...
- 下一篇
centeros安装python3过程
本人初次学习linux。直接在网上买的云服务器。腾讯的学生体验版CENTEROS7.想要将自己的django项目部署上去。以下是刚开始使用center安装python3的过程。网上有的写的模糊,本人尽量描述清楚。 1.首先查看自己原装python所在文件位置: whichpython 2.然后安装所依赖的包 yum-ygroupinstall"Developmenttools" yum-yinstallzlib-develbzip2-developenssl-develncurses-develsqlite-develreadline-develtk-develgdbm-develdb4-devellibpcap-develxz-devel 按着输入进入会自动安装好,这一步只要不是输入错误,不会出现问题。 3.根据自己的需求。安装python的制定版本。本次下载的是python 3.6.2 wgethttps://www.python.org/ftp/python/3.6.2/Python-3.6.2.tar.xz 下载完毕之后,可以使用WinSCP软件将软件放到自己方便的目录下。本次...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- CentOS7,CentOS8安装Elasticsearch6.8.6
- CentOS7安装Docker,走上虚拟化容器引擎之路
- CentOS6,CentOS7官方镜像安装Oracle11G
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Linux系统CentOS6、CentOS7手动修改IP地址
- Docker安装Oracle12C,快速搭建Oracle学习环境